Add role to setup nginx with HTTPS forward capabilities
This commit is contained in:
parent
75a84d1d43
commit
68619b80b5
7 changed files with 175 additions and 0 deletions
4
roles/nginx-https-ingress/files/apt-preference-99nginx
Normal file
4
roles/nginx-https-ingress/files/apt-preference-99nginx
Normal file
|
@ -0,0 +1,4 @@
|
|||
Package: *
|
||||
Pin: origin nginx.org
|
||||
Pin: release o=nginx
|
||||
Pin-Priority: 900
|
34
roles/nginx-https-ingress/files/nginx.conf
Normal file
34
roles/nginx-https-ingress/files/nginx.conf
Normal file
|
@ -0,0 +1,34 @@
|
|||
user nginx;
|
||||
worker_processes auto;
|
||||
|
||||
error_log /var/log/nginx/error.log notice;
|
||||
pid /var/run/nginx.pid;
|
||||
|
||||
|
||||
events {
|
||||
worker_connections 1024;
|
||||
}
|
||||
|
||||
|
||||
include /etc/nginx/passthrough.conf;
|
||||
|
||||
http {
|
||||
include /etc/nginx/mime.types;
|
||||
default_type application/octet-stream;
|
||||
|
||||
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
|
||||
'$status $body_bytes_sent "$http_referer" '
|
||||
'"$http_user_agent" "$http_x_forwarded_for"';
|
||||
|
||||
access_log /var/log/nginx/access.log main;
|
||||
|
||||
sendfile on;
|
||||
#tcp_nopush on;
|
||||
|
||||
keepalive_timeout 65;
|
||||
|
||||
#gzip on;
|
||||
|
||||
include /etc/nginx/conf.d/*.conf;
|
||||
include /etc/nginx/dehydrated-hosts/*;
|
||||
}
|
7
roles/nginx-https-ingress/handlers/main.yml
Normal file
7
roles/nginx-https-ingress/handlers/main.yml
Normal file
|
@ -0,0 +1,7 @@
|
|||
# Handlers für nginx-https-proxy
|
||||
---
|
||||
- name: restart nginx
|
||||
service:
|
||||
name: nginx
|
||||
state: restarted
|
||||
enabled: yes
|
89
roles/nginx-https-ingress/tasks/main.yml
Normal file
89
roles/nginx-https-ingress/tasks/main.yml
Normal file
|
@ -0,0 +1,89 @@
|
|||
# Tasks für nginx-https-proxy
|
||||
---
|
||||
### Install required packages
|
||||
#
|
||||
# At this point, we also check that apt is available,
|
||||
# which is assumed for all future operations.
|
||||
- name: Install nginx prerequisites
|
||||
ansible.builtin.apt:
|
||||
state: present
|
||||
name:
|
||||
- apt-transport-https
|
||||
- ca-certificates
|
||||
- gnupg2
|
||||
|
||||
### Setup APT cache for the nginx repository
|
||||
#
|
||||
# We need the nginx repository to get the ngx_stream_core_module
|
||||
# for SSL passthrough.
|
||||
|
||||
- name: Add nginx apt-key
|
||||
apt_key:
|
||||
url: https://nginx.org/keys/nginx_signing.key
|
||||
state: present
|
||||
|
||||
- name: Add nginx's APT repository
|
||||
ansible.builtin.template:
|
||||
src: templates/nginx.list.j2
|
||||
dest: /etc/apt/sources.list.d/nginx.list
|
||||
register: apt_repo
|
||||
|
||||
- name: Set nginx APT preference
|
||||
ansible.builtin.copy:
|
||||
src: files/apt-preference-99nginx
|
||||
dest: /etc/apt/preferences.d/99nginx
|
||||
|
||||
- name: Update package cache
|
||||
ansible.builtin.apt:
|
||||
update_cache: true
|
||||
when: apt_repo.changed
|
||||
|
||||
### Install nginx
|
||||
|
||||
- name: Install nginx
|
||||
ansible.builtin.apt:
|
||||
state: present
|
||||
name:
|
||||
# This version of nginx comes with the ngx_stream_core_module module
|
||||
- nginx
|
||||
|
||||
|
||||
### Configuration
|
||||
- name: Setup passthrough matrix
|
||||
ansible.builtin.template:
|
||||
src: templates/passthrough.conf.j2
|
||||
dest: /etc/nginx/passthrough.conf
|
||||
owner: root
|
||||
group: root
|
||||
mode: '0644'
|
||||
notify: restart nginx
|
||||
|
||||
- name: Create directory for dehydrated forwardings
|
||||
ansible.builtin.file:
|
||||
path: /etc/nginx/dehydrated-hosts
|
||||
state: directory
|
||||
owner: root
|
||||
group: root
|
||||
mode: '0755'
|
||||
|
||||
- name: Setup dehydrated forwardings
|
||||
ansible.builtin.template:
|
||||
src: templates/dehydrated-host.conf.j2
|
||||
dest: "/etc/nginx/dehydrated-hosts/{{ item.server }}.conf"
|
||||
owner: root
|
||||
group: root
|
||||
mode: '0644'
|
||||
loop: "{{ ingress }}"
|
||||
notify: restart nginx
|
||||
|
||||
- name: Setup nginx configuration
|
||||
# Note the order here: The nginx configuration _needs_ he dehydrated-hosts
|
||||
# directory and the passthrough.conf file, so we do them first to ensure
|
||||
# a valid configuration in case the playbook is cancelled mid-way.
|
||||
ansible.builtin.copy:
|
||||
src: files/nginx.conf
|
||||
dest: /etc/nginx/nginx.conf
|
||||
owner: root
|
||||
group: root
|
||||
mode: '0644'
|
||||
notify: restart nginx
|
14
roles/nginx-https-ingress/templates/dehydrated-host.conf.j2
Normal file
14
roles/nginx-https-ingress/templates/dehydrated-host.conf.j2
Normal file
|
@ -0,0 +1,14 @@
|
|||
# Dehydrated forwardings for server {{ item.server }}
|
||||
{% if 'hosts' in item %}
|
||||
{% for host in item.hosts %}
|
||||
server {
|
||||
listen 80;
|
||||
listen [::]:80;
|
||||
server_name {{ host }};
|
||||
|
||||
location /.well-known/acme-challenge {
|
||||
proxy_pass http://{{ item.server }}.n39.eu:80;
|
||||
}
|
||||
}
|
||||
{% endfor %}
|
||||
{% endif %}
|
2
roles/nginx-https-ingress/templates/nginx.list.j2
Normal file
2
roles/nginx-https-ingress/templates/nginx.list.j2
Normal file
|
@ -0,0 +1,2 @@
|
|||
deb https://nginx.org/packages/debian/ {{ ansible_distribution_release }} nginx
|
||||
deb-src https://nginx.org/packages/debian/ {{ ansible_distribution_release }} nginx
|
25
roles/nginx-https-ingress/templates/passthrough.conf.j2
Normal file
25
roles/nginx-https-ingress/templates/passthrough.conf.j2
Normal file
|
@ -0,0 +1,25 @@
|
|||
# SSL passthrough matrix
|
||||
|
||||
stream {
|
||||
map $ssl_preread_server_name $name {
|
||||
{% for i in ingress %}
|
||||
{% if 'hosts' in i %}
|
||||
{% for host in i.hosts %}
|
||||
{{ host }} {{ i.server }};
|
||||
{% endfor %}
|
||||
{% endif %}
|
||||
{% endfor %}
|
||||
}
|
||||
|
||||
{% for i in ingress %}
|
||||
upstream {{ i.server }} {
|
||||
server {{ i.server }}.n39.eu:443;
|
||||
}
|
||||
{% endfor %}
|
||||
|
||||
server {
|
||||
listen 443;
|
||||
proxy_pass $name;
|
||||
ssl_preread on;
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue