-
Notifications
You must be signed in to change notification settings - Fork 14
06.dockergen
Использование jwilder/docker-gen
на сервере с Docker позволит автоматически
конфигурировать внешний Nginx.
Метка docker-gen.host
сервиса nginx
будет использоваться docker-gen
для генерации конфигурации по шаблону
Инструкция по установке docker-gen на хост находится в файле README.md проекта.
Поместите исполняемый файл docker-gen
куда-либо в PATH, например, в /usr/bin/docker-gen
.
Конфигурацию docker-gen
можно положить в файл /etc/docker-gen.cfg
[[config]]
template = "/etc/nginx/docker-gen.tmpl"
dest = "/etc/nginx/sites-available/docker-gen"
onlypublished = true
watch = true
notifycmd = "service nginx reload"
Шаблон для генерации конфигурации nginx
можно положить в /etc/nginx/docker-gen.tmpl
#
# NOTE: THIS FILE IS GENERATED VIA docker-gen
#
# PLEASE DO NOT EDIT IT DIRECTLY.
#
{{ range $host, $containers := groupByLabel $ "docker-gen.host" }}
upstream {{ $host }}.docker {
{{ range $index, $value := $containers }}
{{ $addrLen := len $value.Addresses }}
{{ $network := index $value.Networks 0 }}
{{/* If only 1 port exposed, use that */}}
{{ if eq $addrLen 1 }}
{{ with $address := index $value.Addresses 0 }}
# {{$value.Name}}
server {{ $network.IP }}:{{ $address.Port }};
{{ end }}
{{/* Else default to standard web port 80 */}}
{{ else }}
{{ range $i, $address := $value.Addresses }}
{{ if eq $address.Port "80" }}
# {{$value.Name}}
server {{ $network.IP }}:{{ $address.Port }};
{{ end }}
{{ end }}
{{ end }}
{{ end }}
}
server {
listen 80;
server_name {{ $host }};
access_log off;
error_log off;
location ^~ /.well-known {
allow all;
alias /var/www/.well-known;
}
location / {
return 301 https://$host$request_uri;
}
}
server {
listen 443 ssl;
server_name {{ $host }};
ssl_certificate /etc/letsencrypt/live/{{ $host }}/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/{{ $host }}/privkey.pem;
location / {
proxy_pass http://{{ trim $host }}.docker;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
client_max_body_size 100m;
}
access_log off;
error_log off;
}
{{ end }}
Тогда при запуске docker-gen -config /etc/docker-gen.cfg
будет сформирован
файл /etc/nginx/sites-available/docker-gen
, который можно подключать к конфигурации nginx
.
В данном случае, SSL-сертификат уже должен быть выпущен. Порядок действий может быть следующим:
- Добавить
location ^~ /.well-known
в конфигурацию сервера по умолчанию внешнегоnginx
- Создать домен и направить его в сервер с Docker
- Создать SSL-сертификат через LetsEncrypt
- Запустить pipeline в GitLab и выложить код проекта на сервер