2018-01-10 23:40:01 +01:00
Ansible NGINX Role
==================
[![Ansible Galaxy ](https://img.shields.io/badge/galaxy-nginxinc.nginx-5bbdbf.svg )](https://galaxy.ansible.com/nginxinc/nginx)
[![Build Status ](https://travis-ci.org/nginxinc/ansible-role-nginx.svg?branch=master )](https://travis-ci.org/nginxinc/ansible-role-nginx)
2018-06-25 23:35:09 +02:00
This role installs NGINX Open Source, NGINX Plus, or NGINX Unit on your target host.
2018-01-10 23:40:01 +01:00
Requirements
------------
This role was developed using Ansible 2.4.0.0. Backwards compatibility is not guaranteed.
Use `ansible-galaxy install nginxinc.nginx` to install the role on your system.
2018-04-12 19:20:39 +02:00
It supports all platforms supported by [NGINX Open Source ](https://nginx.org/en/linux_packages.html#mainline ) and [NGINX Plus ](https://www.nginx.com/products/technical-specs/ ):
2018-01-10 23:40:01 +01:00
2018-04-12 19:20:39 +02:00
**NGINX Open Source:**
2018-01-10 23:40:01 +01:00
CentOS:
versions:
- 6
- 7
RedHat:
versions:
- 6
- 7
Debian:
versions:
- jessie
- stretch
Ubuntu:
versions:
- trusty
- xenial
- zesty
SUSE/SLES:
versions:
- 12
2018-01-20 22:18:59 +01:00
**NGINX Plus:**
2018-01-10 23:40:01 +01:00
Debian:
versions:
- jessie
- stretch
Ubuntu:
versions:
- trusty
- xenial
- zesty
2018-04-09 23:22:13 +02:00
- artful
CentOS:
versions:
- 6.5
- 7
RedHat:
versions:
- 6.5
- 7
Oracle Linux:
versions:
- 6.5
- 7
Amazon Linux:
versions:
- 2016.09
2018-01-10 23:40:01 +01:00
SUSE/SLES:
versions:
- 12
FreeBSD:
versions:
- 10.3
- 11
2018-04-09 23:22:13 +02:00
**NGINX Unit:**
CentOS:
2018-01-10 23:40:01 +01:00
versions:
2018-04-09 23:22:13 +02:00
- 6
2018-01-10 23:40:01 +01:00
- 7
2018-04-09 23:22:13 +02:00
RedHat:
versions:
- 6
- 7
Debian:
versions:
- jessie
- stretch
Ubuntu:
versions:
- xenial
- artful
2018-06-27 01:29:31 +02:00
- bionic
2018-01-10 23:40:01 +01:00
Amazon Linux:
versions:
- 2016.09
Role Variables
--------------
This role has multiple variables. The defaults for all these variables are the following:
2018-01-26 20:00:26 +01:00
---
2018-07-12 00:41:10 +02:00
# Install NGINX.
# Default is true.
nginx_enable: true
2018-01-10 23:40:01 +01:00
# Specify which version of NGINX you want to install.
# Options are 'opensource' or 'plus'.
# Default is 'opensource'.
type: opensource
2018-03-02 02:12:28 +01:00
2018-05-12 00:12:06 +02:00
# Specify repository origin for NGINX Open Source.
2018-05-11 22:31:31 +02:00
# Options are 'nginx_repository' or 'os_repository'.
2018-05-12 00:12:06 +02:00
# Only works if 'type' is set to 'opensource'.
2018-05-11 22:31:31 +02:00
# Default is nginx_repository.
install_from: nginx_repository
2018-05-12 00:12:06 +02:00
# Specify source repository for NGINX Open Source.
# Only works if 'install_from' is set to 'nginx_repository'.
# Defaults are the official NGINX repositories.
nginx_repository:
debian:
2018-06-28 02:12:14 +02:00
- deb https://nginx.org/packages/{{ (branch == 'mainline') | ternary('mainline/','') }}{{ ansible_distribution|lower }}/ {{ ansible_distribution_release }} nginx
- deb-src https://nginx.org/packages/{{ (branch == 'mainline') | ternary('mainline/','') }}{{ ansible_distribution|lower }}/ {{ ansible_distribution_release }} nginx
2018-05-12 00:12:06 +02:00
redhat:
2018-06-28 02:12:14 +02:00
- https://nginx.org/packages/{{ (branch == 'mainline') | ternary('mainline/','') }}{{ (ansible_distribution == "RedHat") | ternary('rhel/', 'centos/') }}{{ ansible_distribution_major_version|int }}/$basearch/
2018-05-12 00:12:06 +02:00
suse:
2018-06-28 02:12:14 +02:00
- https://nginx.org/packages/{{ (branch == 'mainline') | ternary('mainline/','') }}sles/12
2018-05-12 00:12:06 +02:00
2018-04-12 19:20:39 +02:00
# Specify which branch of NGINX Open Source you want to install.
2018-01-10 23:40:01 +01:00
# Options are 'mainline' or 'stable'.
2018-05-11 22:31:31 +02:00
# Only works if 'install_from' is set to 'nginx_repository'.
2018-02-20 21:28:14 +01:00
# Default is mainline.
2018-01-10 23:40:01 +01:00
branch: mainline
2018-03-02 02:12:28 +01:00
2018-06-28 02:12:14 +02:00
# Install NGINX JavaScript, Perl, ModSecurity WAF (NGINX Plus only), GeoIP, Image-Filter, RTMP Media Streaming, and/or XSLT modules.
# Default is false.
2018-01-20 22:18:59 +01:00
modules:
njs: false
perl: false
waf: false
2018-02-20 21:28:14 +01:00
geoip: false
image_filter: false
rtmp: false
xslt: false
2018-03-02 02:12:28 +01:00
2018-01-10 23:40:01 +01:00
# Install NGINX Amplify.
# Use your NGINX Amplify API key.
# Default is null.
2018-02-20 21:28:14 +01:00
amplify_enable: false
amplify_key: null
2018-03-02 02:12:28 +01:00
2018-01-10 23:40:01 +01:00
# Enable NGINX status data.
2018-04-12 19:20:39 +02:00
# Will enable 'stub_status' in NGINX Open Source and 'status' in NGINX Plus.
2018-01-10 23:40:01 +01:00
# Default is false.
2018-02-20 21:28:14 +01:00
status_enable: false
2018-03-02 02:12:28 +01:00
2018-04-09 19:52:24 +02:00
# Enable NGINX Plus REST API, write access to the REST API, and NGINX Plus dashboard.
2018-02-20 21:28:14 +01:00
# Default is false.
rest_api_enable: false
rest_api_write: false
2018-04-09 19:52:24 +02:00
rest_api_dashboard: false
2018-03-02 02:12:28 +01:00
2018-01-10 23:40:01 +01:00
# Location of your NGINX Plus license in your local machine.
2018-01-20 22:18:59 +01:00
# Default is the files folder within the NGINX Ansible role.
2018-01-10 23:40:01 +01:00
license:
2018-01-26 20:00:26 +01:00
certificate: license/nginx-repo.crt
key: license/nginx-repo.key
2018-03-02 02:12:28 +01:00
2018-02-20 21:28:14 +01:00
# Enable uploading NGINX configuration files to your system.
# Default for uploading files is false.
# Default location of files is the files folder within the NGINX Ansible role.
main_push_enable: false
main_push_location: conf/nginx.conf
http_push_enable: false
http_push_location: conf/http/*.conf
stream_push_enable: false
stream_push_location: conf/stream/*.conf
2018-03-02 02:12:28 +01:00
2018-01-26 20:00:26 +01:00
# Configuration variables to create a templated NGINX configuration.
# Defaults are the values found in a fresh NGINX installation.
2018-02-20 21:28:14 +01:00
main_template_enable: false
main_template_user: nginx
main_template_worker_processes: auto
main_template_error_level: warn
main_template_worker_connections: 1024
http_template_enable: false
2018-04-09 19:52:24 +02:00
http_template_keepalive_timeout: 65
2018-02-20 21:28:14 +01:00
http_template_listen: 80
http_template_server_name: localhost
stream_template_enable: false
stream_template_listen: 12345
2018-01-20 22:18:59 +01:00
2018-07-12 00:41:10 +02:00
# Install NGINX Unit and NGINX Unit modules.
# Use a list of supported NGINX Unit modules.
# Default is false.
unit_enable: false
unit_modules: null
2018-01-10 23:40:01 +01:00
Dependencies
------------
None
Example Playbook
----------------
This is a sample playbook file for deploying the Ansible Galaxy NGINX role in a localhost and installing the open source version of NGINX.
---
- hosts: localhost
become: true
roles:
- role: nginxinc.nginx
This is a sample playbook file for deploying the Ansible Galaxy NGINX role in a localhost and installing NGINX Plus.
---
- hosts: localhost
become: true
roles:
- role: nginxinc.nginx
vars:
2018-07-12 03:02:42 +02:00
type: plus
2018-01-10 23:40:01 +01:00
This is a sample playbook file for deploying the Ansible Galaxy NGINX role to a dynamic inventory containing the `nginx` tag.
---
- hosts: tag_nginx
remote_user: root
roles:
- role: nginxinc.nginx
2018-07-12 03:02:42 +02:00
This is a sample playbook file for deploying the Ansible Galaxy NGINX role in a localhost to install NGINX Unit and the PHP/Perl NGINX Unit language modules.
2018-04-09 23:22:13 +02:00
---
- hosts: localhost
become: true
roles:
- role: nginxinc.nginx
vars:
2018-07-12 03:02:42 +02:00
nginx_enable: false
unit_enable: true
unit_packages:
- unit-php
- unit-perl
2018-04-09 23:22:13 +02:00
2018-01-10 23:40:01 +01:00
To run any of the above sample playbooks create a `setup-nginx.yml` file and paste the contents. Executing the Ansible Playbook is then as simple as executing `ansible-playbook setup-nginx.yml` .
Alternatively, you can also clone this repository instead of installing it from Ansible Galaxy. If you decide to do so, replace the role variable in the previous sample playbooks from `nginxinc.nginx` to `ansible-role-nginx` .
License
-------
[Apache License, Version 2.0 ](https://github.com/nginxinc/ansible-role-nginx/blob/master/LICENSE )
Author Information
------------------
Alessandro Fael Garcia
[NGINX Inc ](https://www.nginx.com/ )