Refactor templating
* Add more advanced HTTP templating options * Let users choose the upload destination when uploading files * Implement the ability to print your NGINX configuration to your terminal after running a playbook
This commit is contained in:
parent
44a74aad75
commit
13a847234e
@ -3,6 +3,9 @@
|
|||||||
# Default is true.
|
# Default is true.
|
||||||
nginx_enable: true
|
nginx_enable: true
|
||||||
|
|
||||||
|
# Print NGINX configuration file to terminal after executing playbook.
|
||||||
|
nginx_debug_output: false
|
||||||
|
|
||||||
# Specify which version of NGINX you want to install.
|
# Specify which version of NGINX you want to install.
|
||||||
# Options are 'opensource' or 'plus'.
|
# Options are 'opensource' or 'plus'.
|
||||||
# Default is 'opensource'.
|
# Default is 'opensource'.
|
||||||
@ -78,34 +81,108 @@ nginx_unit_modules: null
|
|||||||
# Will enable 'stub_status' in NGINX Open Source and 'status' in NGINX Plus.
|
# Will enable 'stub_status' in NGINX Open Source and 'status' in NGINX Plus.
|
||||||
# Default is false.
|
# Default is false.
|
||||||
nginx_status_enable: false
|
nginx_status_enable: false
|
||||||
|
nginx_status_port: 8080
|
||||||
|
|
||||||
# Enable NGINX Plus REST API, write access to the REST API, and NGINX Plus dashboard.
|
# Enable NGINX Plus REST API, write access to the REST API, and NGINX Plus dashboard.
|
||||||
# Requires NGINX Plus.
|
# Requires NGINX Plus.
|
||||||
# Default is false.
|
# Default is false.
|
||||||
nginx_rest_api_enable: false
|
nginx_rest_api_enable: false
|
||||||
|
nginx_rest_api_location: /etc/nginx/conf.d/api.conf
|
||||||
|
nginx_rest_api_port: 8080
|
||||||
nginx_rest_api_write: false
|
nginx_rest_api_write: false
|
||||||
nginx_rest_api_dashboard: false
|
nginx_rest_api_dashboard: false
|
||||||
|
|
||||||
# Enable uploading NGINX configuration files to your system.
|
# Enable uploading NGINX configuration files to your system.
|
||||||
# Default for uploading files is false.
|
# Default for uploading files is false.
|
||||||
# Default location of files is the files folder within the NGINX Ansible role.
|
# Default location of files is the files folder within the NGINX Ansible role.
|
||||||
nginx_main_push_enable: false
|
# Upload the main NGINX configuration file.
|
||||||
nginx_main_push_location: conf/nginx.conf
|
nginx_main_upload_enable: false
|
||||||
nginx_http_push_enable: false
|
nginx_main_upload_src: conf/nginx.conf
|
||||||
nginx_http_push_location: conf/http/*.conf
|
nginx_main_upload_dest: /etc/nginx
|
||||||
nginx_stream_push_enable: false
|
# Upload HTTP NGINX configuration files.
|
||||||
nginx_stream_push_location: conf/stream/*.conf
|
nginx_http_upload_enable: false
|
||||||
|
nginx_http_upload_src: conf/http/*.conf
|
||||||
|
nginx_http_upload_dest: /etc/nginx/conf.d
|
||||||
|
# Upload Stream NGINX configuration files.
|
||||||
|
nginx_stream_upload_enable: false
|
||||||
|
nginx_stream_upload_src: conf/stream/*.conf
|
||||||
|
nginx_stream_upload_dest: /etc/nginx/conf.d
|
||||||
|
# Upload HTML files.
|
||||||
|
nginx_html_upload_enable: false
|
||||||
|
nginx_html_upload_src: www/*
|
||||||
|
nginx_html_upload_dest: /usr/share/nginx/html
|
||||||
|
# Upload SSL certificates and keys.
|
||||||
|
nginx_ssl_upload_enable: false
|
||||||
|
nginx_ssl_crt_upload_src: ssl/*.crt
|
||||||
|
nginx_ssl_crt_upload_dest: /etc/ssl/certs/
|
||||||
|
nginx_ssl_key_upload_src: ssl/*.key
|
||||||
|
nginx_ssl_key_upload_dest: /etc/ssl/private/
|
||||||
|
|
||||||
# Configuration variables to create a templated NGINX configuration.
|
# Enable crating dynamic templated NGINX HTMK demo websites.
|
||||||
|
nginx_html_demo_template_enable: false
|
||||||
|
nginx_html_demo_template:
|
||||||
|
default:
|
||||||
|
template_file: www/index.html.j2
|
||||||
|
html_file_name: index.html
|
||||||
|
html_file_location: /usr/share/nginx/html
|
||||||
|
app_name: default
|
||||||
|
|
||||||
|
# Enable creating dynamic templated NGINX configuration files.
|
||||||
# Defaults are the values found in a fresh NGINX installation.
|
# Defaults are the values found in a fresh NGINX installation.
|
||||||
nginx_main_template_enable: false
|
nginx_main_template_enable: false
|
||||||
nginx_main_template_user: nginx
|
nginx_main_template:
|
||||||
nginx_main_template_worker_processes: auto
|
template_file: nginx.conf.j2
|
||||||
nginx_main_template_error_level: warn
|
conf_file_name: nginx.conf
|
||||||
nginx_main_template_worker_connections: 1024
|
conf_file_location: /etc/nginx/
|
||||||
|
user: nginx
|
||||||
|
worker_processes: auto
|
||||||
|
error_level: warn
|
||||||
|
worker_connections: 1024
|
||||||
|
http_enable: true
|
||||||
|
http_settings:
|
||||||
|
keepalive_timeout: 65
|
||||||
|
cache: false
|
||||||
|
rate_limit: false
|
||||||
|
keyval: false
|
||||||
|
stream_enable: false
|
||||||
|
|
||||||
|
# Enable creating dynamic templated NGINX HTTP configuration files.
|
||||||
|
# Defaults will not produce a valid configuration. Instead they are meant to showcase
|
||||||
|
# the options available for templating. Each key represents a new configuration file.
|
||||||
|
# Comment out load_balancer or web_server depending on whether you wish to create a web server
|
||||||
|
# or load balancer configuration file.
|
||||||
nginx_http_template_enable: false
|
nginx_http_template_enable: false
|
||||||
nginx_http_template_keepalive_timeout: 65
|
nginx_http_template:
|
||||||
nginx_http_template_listen: 80
|
default:
|
||||||
nginx_http_template_server_name: localhost
|
template_file: http/default.conf.j2
|
||||||
|
conf_file_name: default.conf
|
||||||
|
conf_file_location: /etc/nginx/conf.d/
|
||||||
|
port: 8081
|
||||||
|
server_name: localhost
|
||||||
|
error_page: /usr/share/nginx/html
|
||||||
|
ssl:
|
||||||
|
cert: ssl/default.crt
|
||||||
|
key: ssl/default.key
|
||||||
|
web_server:
|
||||||
|
html_file_location: /usr/share/nginx/html
|
||||||
|
html_file_name: index.html
|
||||||
|
http_demo_conf: false
|
||||||
|
load_balancer:
|
||||||
|
proxy_pass: backend
|
||||||
|
health_check_plus: false
|
||||||
|
upstreams:
|
||||||
|
upstream1:
|
||||||
|
name: backend
|
||||||
|
lb_method: least_conn
|
||||||
|
zone_name: backend
|
||||||
|
zone_size: 64k
|
||||||
|
sticky_cookie: false
|
||||||
|
servers:
|
||||||
|
server1:
|
||||||
|
address: localhost
|
||||||
|
port: 8081
|
||||||
|
weight: 1
|
||||||
|
|
||||||
|
# Enable creating dynamic templated NGINX stream configuration files.
|
||||||
nginx_stream_template_enable: false
|
nginx_stream_template_enable: false
|
||||||
nginx_stream_template_listen: 12345
|
nginx_stream_template_listen: 12345
|
||||||
|
0
files/ssl/.gitkeep
Normal file
0
files/ssl/.gitkeep
Normal file
0
files/www/.gitkeep
Normal file
0
files/www/.gitkeep
Normal file
9
tasks/conf/debug-output.yml
Normal file
9
tasks/conf/debug-output.yml
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
---
|
||||||
|
- name: "(Setup: All OSs) Register NGINX configuration"
|
||||||
|
command: nginx -T
|
||||||
|
changed_when: false
|
||||||
|
register: nginx_configuration
|
||||||
|
|
||||||
|
- name: "(Setup: All OSs) Print NGINX configuration"
|
||||||
|
debug:
|
||||||
|
var: nginx_configuration.stdout_lines
|
@ -1,40 +0,0 @@
|
|||||||
---
|
|
||||||
- name: "(Setup: All NGINX) Upload NGINX Main Configuration File"
|
|
||||||
copy:
|
|
||||||
src: "{{ nginx_main_push_location }}"
|
|
||||||
dest: /etc/nginx/nginx.conf
|
|
||||||
backup: yes
|
|
||||||
notify: "(Handler: All OSs) Reload NGINX"
|
|
||||||
when: nginx_main_push_enable
|
|
||||||
|
|
||||||
- name: "(Setup: All NGINX) Ensure NGINX HTTP Directory Exists"
|
|
||||||
file:
|
|
||||||
path: /etc/nginx/conf.d/http
|
|
||||||
state: directory
|
|
||||||
when: nginx_http_push_enable
|
|
||||||
|
|
||||||
- name: "(Setup: All NGINX) Upload NGINX HTTP Configuration Files"
|
|
||||||
copy:
|
|
||||||
src: "{{ item }}"
|
|
||||||
dest: /etc/nginx/conf.d/http
|
|
||||||
backup: yes
|
|
||||||
with_fileglob:
|
|
||||||
- "{{ nginx_http_push_location }}"
|
|
||||||
notify: "(Handler: All OSs) Reload NGINX"
|
|
||||||
when: nginx_http_push_enable
|
|
||||||
|
|
||||||
- name: "(Setup: All NGINX) Ensure NGINX Stream Directory Exists"
|
|
||||||
file:
|
|
||||||
path: /etc/nginx/conf.d/stream
|
|
||||||
state: directory
|
|
||||||
when: nginx_stream_push_enable
|
|
||||||
|
|
||||||
- name: "(Setup: All NGINX) Upload NGINX Stream Configuration Files"
|
|
||||||
copy:
|
|
||||||
src: "{{ item }}"
|
|
||||||
dest: /etc/nginx/conf.d/stream
|
|
||||||
backup: yes
|
|
||||||
with_fileglob:
|
|
||||||
- "{{ nginx_stream_push_location }}"
|
|
||||||
notify: "(Handler: All OSs) Reload NGINX"
|
|
||||||
when: nginx_stream_push_enable
|
|
@ -1,11 +1,11 @@
|
|||||||
---
|
---
|
||||||
- name: "(Setup: NGINX Plus) Setup NGINX Plus API"
|
- name: "(Setup: NGINX Plus) Setup NGINX Plus API"
|
||||||
blockinfile:
|
blockinfile:
|
||||||
path: "{{ (nginx_http_template_enable) | ternary('/etc/nginx/conf.d/http/api.conf','/etc/nginx/conf.d/api.conf') }}"
|
path: "{{ nginx_rest_api_location }}"
|
||||||
create: yes
|
create: yes
|
||||||
block: |
|
block: |
|
||||||
server {
|
server {
|
||||||
listen 8080;
|
listen {{ nginx_rest_api_port }};
|
||||||
location /api {
|
location /api {
|
||||||
{% if nginx_rest_api_write %}
|
{% if nginx_rest_api_write %}
|
||||||
api write=on;
|
api write=on;
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
create: yes
|
create: yes
|
||||||
block: |
|
block: |
|
||||||
server {
|
server {
|
||||||
listen 127.0.0.1:80;
|
listen 127.0.0.1:{{ nginx_status_port }};
|
||||||
location /nginx_status {
|
location /nginx_status {
|
||||||
stub_status on;
|
stub_status on;
|
||||||
allow 127.0.0.1;
|
allow 127.0.0.1;
|
||||||
@ -21,7 +21,7 @@
|
|||||||
create: yes
|
create: yes
|
||||||
block: |
|
block: |
|
||||||
server {
|
server {
|
||||||
listen 127.0.0.1:80;
|
listen 127.0.0.1:{{ nginx_status_port }};
|
||||||
location /status {
|
location /status {
|
||||||
status;
|
status;
|
||||||
allow 127.0.0.1;
|
allow 127.0.0.1;
|
||||||
|
@ -1,25 +1,39 @@
|
|||||||
---
|
---
|
||||||
|
- name: "(Setup: All NGINX) Ensure HTML Directory Exists"
|
||||||
|
file:
|
||||||
|
path: "{{ item.value.html_file_location }}"
|
||||||
|
state: directory
|
||||||
|
with_dict: "{{ nginx_html_demo_template }}"
|
||||||
|
when: nginx_html_demo_template_enable
|
||||||
|
|
||||||
|
- name: "(Setup: All NGINX) Dynamically Generate HTML Files"
|
||||||
|
template:
|
||||||
|
src: "{{ item.value.template_file }}"
|
||||||
|
dest: "{{ item.value.html_file_location }}/{{ item.value.html_file_name }}"
|
||||||
|
with_dict: "{{ nginx_html_demo_template }}"
|
||||||
|
when: nginx_html_demo_template_enable
|
||||||
|
|
||||||
- name: "(Setup: All NGINX) Dynamically Generate NGINX Main Configuration File"
|
- name: "(Setup: All NGINX) Dynamically Generate NGINX Main Configuration File"
|
||||||
template:
|
template:
|
||||||
src: nginx.conf.j2
|
src: "{{ nginx_main_template.template_file }}"
|
||||||
dest: /etc/nginx/nginx.conf
|
dest: "{{ nginx_main_template.conf_file_location }}/{{ nginx_main_template.conf_file_name }}"
|
||||||
backup: yes
|
backup: yes
|
||||||
when: nginx_main_template_enable
|
when: nginx_main_template_enable
|
||||||
notify: "(Handler: All OSs) Reload NGINX"
|
notify: "(Handler: All OSs) Reload NGINX"
|
||||||
|
|
||||||
- name: "(Setup: All NGINX) Ensure NGINX HTTP Directory Exists"
|
- name: "(Setup: All NGINX) Ensure NGINX HTTP Directory Exists"
|
||||||
file:
|
file:
|
||||||
path: /etc/nginx/conf.d/http
|
path: "{{ item.value.conf_file_location }}"
|
||||||
state: directory
|
state: directory
|
||||||
|
with_dict: "{{ nginx_http_template }}"
|
||||||
when: nginx_http_template_enable
|
when: nginx_http_template_enable
|
||||||
|
|
||||||
- name: "(Setup: All NGINX) Dynamically Generate NGINX HTTP Configuration Files"
|
- name: "(Setup: All NGINX) Dynamically Generate NGINX HTTP Configuration Files"
|
||||||
template:
|
template:
|
||||||
src: "{{ item }}"
|
src: "{{ item.value.template_file }}"
|
||||||
dest: /etc/nginx/conf.d/http/{{ item | basename | regex_replace('\.j2','') }}
|
dest: "{{ item.value.conf_file_location }}/{{ item.value.conf_file_name }}"
|
||||||
backup: yes
|
backup: yes
|
||||||
with_fileglob:
|
with_dict: "{{ nginx_http_template }}"
|
||||||
- "../templates/http/*.j2"
|
|
||||||
when: nginx_http_template_enable
|
when: nginx_http_template_enable
|
||||||
notify: "(Handler: All OSs) Reload NGINX"
|
notify: "(Handler: All OSs) Reload NGINX"
|
||||||
|
|
||||||
|
81
tasks/conf/upload-config.yml
Normal file
81
tasks/conf/upload-config.yml
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
---
|
||||||
|
- name: "(Setup: All NGINX) Upload NGINX Main Configuration File"
|
||||||
|
copy:
|
||||||
|
src: "{{ nginx_main_upload_src }}"
|
||||||
|
dest: "{{ nginx_main_upload_dest }}"
|
||||||
|
backup: yes
|
||||||
|
notify: "(Handler: All OSs) Reload NGINX"
|
||||||
|
when: nginx_main_upload_enable
|
||||||
|
|
||||||
|
- name: "(Setup: All NGINX) Ensure NGINX HTTP Directory Exists"
|
||||||
|
file:
|
||||||
|
path: "{{ nginx_http_upload_dest }}"
|
||||||
|
state: directory
|
||||||
|
when: nginx_http_upload_enable
|
||||||
|
|
||||||
|
- name: "(Setup: All NGINX) Upload NGINX HTTP Configuration Files"
|
||||||
|
copy:
|
||||||
|
src: "{{ item }}"
|
||||||
|
dest: "{{ nginx_http_upload_dest }}"
|
||||||
|
backup: yes
|
||||||
|
with_fileglob: "{{ nginx_http_upload_src }}"
|
||||||
|
notify: "(Handler: All OSs) Reload NGINX"
|
||||||
|
when: nginx_http_upload_enable
|
||||||
|
|
||||||
|
- name: "(Setup: All NGINX) Ensure NGINX Stream Directory Exists"
|
||||||
|
file:
|
||||||
|
path: "{{ nginx_stream_upload_dest }}"
|
||||||
|
state: directory
|
||||||
|
when: nginx_stream_upload_enable
|
||||||
|
|
||||||
|
- name: "(Setup: All NGINX) Upload NGINX Stream Configuration Files"
|
||||||
|
copy:
|
||||||
|
src: "{{ item }}"
|
||||||
|
dest: "{{ nginx_stream_upload_dest }}"
|
||||||
|
backup: yes
|
||||||
|
with_fileglob: "{{ nginx_stream_upload_src }}"
|
||||||
|
notify: "(Handler: All OSs) Reload NGINX"
|
||||||
|
when: nginx_stream_upload_enable
|
||||||
|
|
||||||
|
- name: "(Setup: All NGINX) Ensure NGINX HTML Directory Exists"
|
||||||
|
file:
|
||||||
|
path: "{{ nginx_html_upload_dest }}"
|
||||||
|
state: directory
|
||||||
|
when: nginx_html_upload_enable
|
||||||
|
|
||||||
|
- name: "(Setup: All NGINX) Upload NGINX HTML Files"
|
||||||
|
copy:
|
||||||
|
src: "{{ item }}"
|
||||||
|
dest: "{{ nginx_html_upload_dest }}"
|
||||||
|
backup: yes
|
||||||
|
with_fileglob: "{{ nginx_html_upload_src }}"
|
||||||
|
notify: "(Handler: All OSs) Reload NGINX"
|
||||||
|
when: nginx_html_upload_enable
|
||||||
|
|
||||||
|
- name: "(Setup: All NGINX) Ensure SSL Certificate Directory Exists"
|
||||||
|
file:
|
||||||
|
path: "{{ nginx_ssl_crt_upload_dest }}"
|
||||||
|
state: directory
|
||||||
|
when: nginx_ssl_upload_enable
|
||||||
|
|
||||||
|
- name: "(Setup: All NGINX) Ensure SSL Key Directory Exists"
|
||||||
|
file:
|
||||||
|
path: "{{ nginx_ssl_key_upload_dest }}"
|
||||||
|
state: directory
|
||||||
|
when: nginx_ssl_upload_enable
|
||||||
|
|
||||||
|
- name: "(Setup: All NGINX) Upload NGINX SSL Certificates"
|
||||||
|
copy:
|
||||||
|
src: "{{ item }}"
|
||||||
|
dest: "{{ nginx_ssl_crt_upload_dest }}"
|
||||||
|
backup: yes
|
||||||
|
with_fileglob: "{{ nginx_ssl_crt_upload_src }}"
|
||||||
|
when: nginx_ssl_upload_enable
|
||||||
|
|
||||||
|
- name: "(Setup: All NGINX) Upload NGINX SSL Keys"
|
||||||
|
copy:
|
||||||
|
src: "{{ item }}"
|
||||||
|
dest: "{{ nginx_ssl_key_upload_dest }}"
|
||||||
|
backup: yes
|
||||||
|
with_fileglob: "{{ nginx_ssl_key_upload_src }}"
|
||||||
|
when: nginx_ssl_upload_enable
|
@ -19,8 +19,8 @@
|
|||||||
- import_tasks: modules/install-modules.yml
|
- import_tasks: modules/install-modules.yml
|
||||||
when: true in nginx_modules.values()
|
when: true in nginx_modules.values()
|
||||||
|
|
||||||
- import_tasks: conf/push-config.yml
|
- import_tasks: conf/upload-config.yml
|
||||||
when: nginx_main_push_enable or nginx_http_push_enable or nginx_stream_push_enable
|
when: nginx_main_upload_enable or nginx_http_upload_enable or nginx_stream_upload_enable or nginx_html_upload_enable or nginx_ssl_upload_enable
|
||||||
|
|
||||||
- import_tasks: conf/template-config.yml
|
- import_tasks: conf/template-config.yml
|
||||||
when: nginx_main_template_enable or nginx_http_template_enable or nginx_stream_template_enable
|
when: nginx_main_template_enable or nginx_http_template_enable or nginx_stream_template_enable
|
||||||
@ -29,7 +29,10 @@
|
|||||||
when: nginx_status_enable
|
when: nginx_status_enable
|
||||||
|
|
||||||
- import_tasks: conf/setup-rest-api.yml
|
- import_tasks: conf/setup-rest-api.yml
|
||||||
when: nginx_rest_api_enable and nginx_type == "plus"
|
when: nginx_rest_api_enable
|
||||||
|
|
||||||
|
- import_tasks: conf/debug-output.yml
|
||||||
|
when: nginx_debug_output
|
||||||
|
|
||||||
when: nginx_enable
|
when: nginx_enable
|
||||||
|
|
||||||
|
@ -9,5 +9,5 @@
|
|||||||
src: "{{ item }}"
|
src: "{{ item }}"
|
||||||
dest: /etc/ssl/nginx
|
dest: /etc/ssl/nginx
|
||||||
with_items:
|
with_items:
|
||||||
- "{{ license.certificate }}"
|
- "{{ nginx_license.certificate }}"
|
||||||
- "{{ license.key }}"
|
- "{{ nginx_license.key }}"
|
||||||
|
@ -1,44 +1,64 @@
|
|||||||
server {
|
{% if item.value.upstreams is defined %}
|
||||||
listen {{ nginx_http_template_listen }};
|
{% for upstream in item.value.upstreams %}
|
||||||
server_name {{ nginx_http_template_server_name }};
|
upstream {{ item.value.upstreams[upstream].name }} {
|
||||||
|
{{ item.value.upstreams[upstream].lb_method }};
|
||||||
#charset koi8-r;
|
zone {{ item.value.upstreams[upstream].zone_name }} {{ item.value.upstreams[upstream].zone_size }};
|
||||||
#access_log /var/log/nginx/host.access.log main;
|
{% for server in item.value.upstreams[upstream].servers %}
|
||||||
|
server {{ item.value.upstreams[upstream].servers[server].address }}:{{ item.value.upstreams[upstream].servers[server].port }} weight={{ item.value.upstreams[upstream].servers[server].weight|default("1") }};
|
||||||
location / {
|
{% endfor %}
|
||||||
root /usr/share/nginx/html;
|
{% if item.value.upstreams[upstream].sticky_cookie %}
|
||||||
index index.html index.htm;
|
sticky cookie srv_id expires=1h path=/;
|
||||||
|
{% endif %}
|
||||||
}
|
}
|
||||||
|
{% endfor %}
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
#error_page 404 /404.html;
|
server {
|
||||||
|
{% if item.value.ssl is defined %}
|
||||||
|
listen 443 ssl;
|
||||||
|
ssl_certificate /etc/ssl/certs/{{ item.value.ssl.cert }};
|
||||||
|
ssl_certificate_key /etc/ssl/private/{{ item.value.ssl.key }};
|
||||||
|
{% else %}
|
||||||
|
listen {{ item.value.port }};
|
||||||
|
{% endif %}
|
||||||
|
server_name {{ item.value.server_name }};
|
||||||
|
{% if item.value.load_balancer is defined %}
|
||||||
|
location / {
|
||||||
|
proxy_pass http://{{ item.value.load_balancer.proxy_pass }};
|
||||||
|
{% if item.value.load_balancer.health_check_plus %}
|
||||||
|
health_check;
|
||||||
|
{% endif %}
|
||||||
|
proxy_set_header Host $host;
|
||||||
|
proxy_set_header X-Real-IP $remote_addr;
|
||||||
|
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
||||||
|
proxy_set_header X-Forwarded-Proto $scheme;
|
||||||
|
}
|
||||||
|
{% endif %}
|
||||||
|
{% if item.value.web_server is defined %}
|
||||||
|
location / {
|
||||||
|
root {{ item.value.web_server.html_file_location }};
|
||||||
|
index {{ item.value.web_server.html_file_name }};
|
||||||
|
}
|
||||||
|
{% if item.value.web_server.http_demo_conf %}
|
||||||
|
sub_filter_once off;
|
||||||
|
sub_filter 'server_hostname' '$hostname';
|
||||||
|
sub_filter 'server_address' '$server_addr:$server_port';
|
||||||
|
sub_filter 'server_url' '$request_uri';
|
||||||
|
sub_filter 'remote_addr' '$remote_addr:$remote_port';
|
||||||
|
sub_filter 'server_date' '$time_local';
|
||||||
|
sub_filter 'client_browser' '$http_user_agent';
|
||||||
|
sub_filter 'request_id' '$request_id';
|
||||||
|
sub_filter 'nginx_version' '$nginx_version';
|
||||||
|
sub_filter 'document_root' '$document_root';
|
||||||
|
sub_filter 'proxied_for_ip' '$http_x_forwarded_for';
|
||||||
|
{% endif %}
|
||||||
|
{% endif %}
|
||||||
|
{% if item.value.error_page is defined %}
|
||||||
# redirect server error pages to the static page /50x.html
|
# redirect server error pages to the static page /50x.html
|
||||||
#
|
#
|
||||||
error_page 500 502 503 504 /50x.html;
|
error_page 500 502 503 504 /50x.html;
|
||||||
location = /50x.html {
|
location = /50x.html {
|
||||||
root /usr/share/nginx/html;
|
root {{ item.value.error_page }};
|
||||||
}
|
}
|
||||||
|
{% endif %}
|
||||||
# proxy the PHP scripts to Apache listening on 127.0.0.1:80
|
|
||||||
#
|
|
||||||
#location ~ \.php$ {
|
|
||||||
# proxy_pass http://127.0.0.1;
|
|
||||||
#}
|
|
||||||
|
|
||||||
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
|
|
||||||
#
|
|
||||||
#location ~ \.php$ {
|
|
||||||
# root html;
|
|
||||||
# fastcgi_pass 127.0.0.1:9000;
|
|
||||||
# fastcgi_index index.php;
|
|
||||||
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
|
|
||||||
# include fastcgi_params;
|
|
||||||
#}
|
|
||||||
|
|
||||||
# deny access to .htaccess files, if Apache's document root
|
|
||||||
# concurs with nginx's one
|
|
||||||
#
|
|
||||||
#location ~ /\.ht {
|
|
||||||
# deny all;
|
|
||||||
#}
|
|
||||||
}
|
}
|
||||||
|
@ -1,15 +1,15 @@
|
|||||||
user {{ nginx_main_template_user }};
|
user {{ nginx_main_template.user }};
|
||||||
worker_processes {{ nginx_main_template_worker_processes }};
|
worker_processes {{ nginx_main_template.worker_processes }};
|
||||||
|
|
||||||
error_log /var/log/nginx/error.log {{ nginx_main_template_error_level }};
|
error_log /var/log/nginx/error.log {{ nginx_main_template.error_level }};
|
||||||
pid /var/run/nginx.pid;
|
pid /var/run/nginx.pid;
|
||||||
|
|
||||||
|
|
||||||
events {
|
events {
|
||||||
worker_connections {{ nginx_main_template_worker_connections }};
|
worker_connections {{ nginx_main_template.worker_connections }};
|
||||||
}
|
}
|
||||||
|
|
||||||
{% if nginx_http_template_enable %}
|
{% if nginx_main_template.http_enable %}
|
||||||
http {
|
http {
|
||||||
include /etc/nginx/mime.types;
|
include /etc/nginx/mime.types;
|
||||||
default_type application/octet-stream;
|
default_type application/octet-stream;
|
||||||
@ -23,15 +23,24 @@ http {
|
|||||||
sendfile on;
|
sendfile on;
|
||||||
#tcp_nopush on;
|
#tcp_nopush on;
|
||||||
|
|
||||||
keepalive_timeout {{ nginx_http_template_keepalive_timeout }};
|
keepalive_timeout {{ nginx_main_template.http_settings.keepalive_timeout }};
|
||||||
|
|
||||||
#gzip on;
|
#gzip on;
|
||||||
|
{% if nginx_main_template.http_settings.cache %}
|
||||||
include /etc/nginx/conf.d/http/*.conf;
|
proxy_cache_path /tmp/cache keys_zone=one:10m;
|
||||||
|
{% endif %}
|
||||||
|
{% if nginx_main_template.http_settings.rate_limit %}
|
||||||
|
limit_req_zone $binary_remote_addr zone=mylimit:10m rate=10r/s;
|
||||||
|
{% endif %}
|
||||||
|
{% if nginx_main_template.http_settings.keyval %}
|
||||||
|
keyval_zone zone={{nginx_main_template.http_settings.keyval.zone}}:32k state=one.keyval;
|
||||||
|
keyval $arg_text $text zone=one;
|
||||||
|
{% endif %}
|
||||||
|
include /etc/nginx/conf.d/*.conf;
|
||||||
}
|
}
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
{% if nginx_stream_template_enable %}
|
{% if nginx_main_template.stream_enable %}
|
||||||
stream {
|
stream {
|
||||||
include /etc/nginx/conf.d/stream/*.conf;
|
include /etc/nginx/conf.d/stream/*.conf;
|
||||||
}
|
}
|
||||||
|
101
templates/www/index.html.j2
Normal file
101
templates/www/index.html.j2
Normal file
@ -0,0 +1,101 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>Hello World - App {{ item.value.name }}</title>
|
||||||
|
<link href="" rel="icon" type="image/png" />
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
margin: 0px;
|
||||||
|
font: 20px 'RobotoRegular', Arial, sans-serif;
|
||||||
|
font-weight: 100;
|
||||||
|
height: 100%;
|
||||||
|
color: #0f1419;
|
||||||
|
background-color: {{ item.value.name }};
|
||||||
|
}
|
||||||
|
div.info {
|
||||||
|
display: table;
|
||||||
|
background: #e8eaec;
|
||||||
|
padding: 20px 20px 20px 20px;
|
||||||
|
border: 1px dashed black;
|
||||||
|
border-radius: 10px;
|
||||||
|
margin: 0px auto auto auto;
|
||||||
|
}
|
||||||
|
div.info p {
|
||||||
|
display: table-row;
|
||||||
|
margin: 5px auto auto auto;
|
||||||
|
}
|
||||||
|
div.info p span {
|
||||||
|
display: table-cell;
|
||||||
|
padding: 10px;
|
||||||
|
}
|
||||||
|
img {
|
||||||
|
width: 176px;
|
||||||
|
margin: 36px auto 36px auto;
|
||||||
|
display:block;
|
||||||
|
}
|
||||||
|
div.smaller p span {
|
||||||
|
color: #3D5266;
|
||||||
|
}
|
||||||
|
h1, h2 {
|
||||||
|
font-weight: 100;
|
||||||
|
}
|
||||||
|
div.check {
|
||||||
|
padding: 0px 0px 0px 0px;
|
||||||
|
display: table;
|
||||||
|
margin: 36px auto auto auto;
|
||||||
|
font: 12px 'RobotoRegular', Arial, sans-serif;
|
||||||
|
}
|
||||||
|
#footer {
|
||||||
|
position: fixed;
|
||||||
|
bottom: 36px;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
#center {
|
||||||
|
width: 400px;
|
||||||
|
margin: 0 auto;
|
||||||
|
font: 18px Courier;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
<script>
|
||||||
|
var ref;
|
||||||
|
function checkRefresh(){
|
||||||
|
if (document.cookie == "refresh=1") {
|
||||||
|
document.getElementById("check").checked = true;
|
||||||
|
ref = setTimeout(function(){location.reload();}, 1000);
|
||||||
|
} else {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function changeCookie() {
|
||||||
|
if (document.getElementById("check").checked) {
|
||||||
|
document.cookie = "refresh=1";
|
||||||
|
ref = setTimeout(function(){location.reload();}, 1000);
|
||||||
|
} else {
|
||||||
|
document.cookie = "refresh=0";
|
||||||
|
clearTimeout(ref);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
</head>
|
||||||
|
<body onload="checkRefresh();">
|
||||||
|
<img alt="NGINX Logo" src=""/>
|
||||||
|
<div class="info">
|
||||||
|
<p><span>Web Server name:</span> <span> {{ item.value.name }} </span></p>
|
||||||
|
<p><span>Server name:</span> <span> {{ ansible_hostname }} </span></p>
|
||||||
|
<p><span>Server address:</span> <span> {{ ansible_eth0.ipv4.address }} </span></p>
|
||||||
|
<p><span>User Agent:</span> <span><small>client_browser</small></span></p>
|
||||||
|
<p class="smaller"><span>URI:</span> <span>server_url</span></p>
|
||||||
|
<p class="smaller"><span>Doc Root:</span> <span>document_root</span></p>
|
||||||
|
<p class="smaller"><span>Date:</span> <span>server_date</span></p>
|
||||||
|
<p class="smaller"><span>NGINX Front-End Load Balancer IP:</span><span>remote_addr</span></p>
|
||||||
|
<p class="smaller"><span>Client IP:</span> <span>proxied_for_ip</span></p>
|
||||||
|
<p class="smaller"><span>NGINX Version:</span> <span>nginx_version</span></p>
|
||||||
|
</div>
|
||||||
|
<div class="check"><input type="checkbox" id="check" onchange="changeCookie()"> Auto Refresh</div>
|
||||||
|
<div id="footer">
|
||||||
|
<div id="center" align="center">
|
||||||
|
Request ID: request_id<br/>
|
||||||
|
© NGINX, Inc. 2018
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
@ -5,7 +5,7 @@
|
|||||||
roles:
|
roles:
|
||||||
- ansible-role-nginx
|
- ansible-role-nginx
|
||||||
vars:
|
vars:
|
||||||
nginx_main_push_enable: true
|
nginx_main_upload_enable: true
|
||||||
nginx_main_push_location: ../files/nginx.conf
|
nginx_main_upload_src: ../files/nginx.conf
|
||||||
nginx_http_push_enable: true
|
nginx_http_upload_enable: true
|
||||||
nginx_http_push_location: ../files/http/*.conf
|
nginx_http_upload_src: ../files/http/*.conf
|
||||||
|
@ -6,5 +6,15 @@
|
|||||||
- ansible-role-nginx
|
- ansible-role-nginx
|
||||||
vars:
|
vars:
|
||||||
nginx_http_template_enable: true
|
nginx_http_template_enable: true
|
||||||
nginx_http_template_keepalive_timeout: 70
|
nginx_http_template:
|
||||||
nginx_http_template_listen: 82
|
default:
|
||||||
|
template_file: http/default.conf.j2
|
||||||
|
conf_file_name: default.conf
|
||||||
|
conf_file_location: /etc/nginx/conf.d/
|
||||||
|
port: 80
|
||||||
|
server_name: localhost
|
||||||
|
error_page: /usr/share/nginx/html
|
||||||
|
web_server:
|
||||||
|
html_file_location: /usr/share/nginx/html
|
||||||
|
html_file_name: index.html
|
||||||
|
http_demo_conf: false
|
||||||
|
Loading…
Reference in New Issue
Block a user