1
0
mirror of https://github.com/vimagick/dockerfiles.git synced 2025-01-26 05:27:31 +02:00

66 lines
1.5 KiB
Markdown
Raw Normal View History

2015-12-21 22:50:38 +08:00
letsencrypt
===========
[Let’s Encrypt][1] is a new Certificate Authority:
It’s free, automated, and open.
## docker-compose.yml
```
letsencrypt:
image: quay.io/letsencrypt/letsencrypt
command: auth
ports:
- "80:80"
- "443:443"
volumes:
2016-01-16 13:39:09 +08:00
- "./etc/letsencrypt:/etc/letsencrypt"
- "./var/lib/letsencrypt:/var/lib/letsencrypt"
2015-12-21 22:50:38 +08:00
```
## up and running
```
2016-01-16 13:39:09 +08:00
# stop nginx (release 80/tcp and 443/tcp)
2015-12-21 22:50:38 +08:00
$ systemctl stop nginx
# generate keys
$ docker-compose run --rm --service-ports letsencrypt
>>> email: admin@datageek.info
2016-01-16 13:39:09 +08:00
>>> domains: datageek.info,bbs.datageek.info,blog.datageek.info,wiki.datageek.info
2015-12-21 22:50:38 +08:00
# copy keys
$ mkdir -p /etc/nginx/ssl/
2016-01-16 13:39:09 +08:00
$ cp ./etc/letsencrypt/live/datageek.info/fullchain.pem /etc/nginx/ssl/datageek.info.crt
$ cp ./etc/letsencrypt/live/datageek.info/privkey.pem /etc/nginx/ssl/datageek.info.key
2015-12-21 22:50:38 +08:00
# reconfig nginx
$ vi /etc/nginx/sites-enabled/default
server {
2016-01-16 13:39:09 +08:00
listen 80 default;
server_name _;
return 301 https://$host$request_uri;
2015-12-21 22:50:38 +08:00
}
server {
2016-01-16 13:39:09 +08:00
listen 443 ssl;
server_name datageek.info blog.datageek.info;
ssl_certificate ssl/datageek.info.crt;
ssl_certificate_key ssl/datageek.info.key;
location / {
proxy_pass http://127.0.0.1:8000;
}
2015-12-21 22:50:38 +08:00
}
# start nginx
$ systemctl start nginx
```
## references
- https://letsencrypt.readthedocs.org/en/latest/using.html#running-with-docker
- https://docs.docker.com/compose/reference/run/
- http://nginx.org/en/docs/http/configuring_https_servers.html
[1]: https://letsencrypt.org/