Build from source with nginx.ng

Build NGINX from source with nginx.ng state with support for passing
compile time flags necessary for installing modules such as more headers
by the openresty project.
This commit is contained in:
George Robinson 2016-05-09 16:31:29 +01:00
parent 89d07fed8b
commit f24b066c43
6 changed files with 102 additions and 3 deletions

View File

@ -0,0 +1,15 @@
[Unit]
Description=The NGINX HTTP and reverse proxy server
After=syslog.target network.target remote-fs.target nss-lookup.target
[Service]
Type=forking
PIDFile=/run/nginx.pid
ExecStartPre=/usr/sbin/nginx -t
ExecStart=/usr/sbin/nginx
ExecReload=/bin/kill -s HUP $MAINPID
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true
[Install]
WantedBy=multi-user.target

View File

@ -2,6 +2,8 @@
# #
# Meta-state to fully install nginx. # Meta-state to fully install nginx.
{% from 'nginx/ng/map.jinja' import nginx, sls_block with context %}
include: include:
- nginx.ng.config - nginx.ng.config
- nginx.ng.service - nginx.ng.service
@ -18,4 +20,8 @@ extend:
nginx_config: nginx_config:
file: file:
- require: - require:
{% if nginx.install_from_source %}
- cmd: nginx_install
{% else %}
- pkg: nginx_install - pkg: nginx_install
{% endif %}

View File

@ -4,15 +4,73 @@
{% from 'nginx/ng/map.jinja' import nginx, sls_block with context %} {% from 'nginx/ng/map.jinja' import nginx, sls_block with context %}
{% if nginx.install_from_source %}
nginx_build_dep:
{% if salt['grains.get']('os_family') == 'Debian' %}
cmd.run:
- name: apt-get -y build-dep nginx
{% elif salt['grains.get']('os_family') == 'RedHat' %}
cmd.run:
- name: yum-builddep -y nginx
{% else %}
## install build deps for other distros
{% endif %}
nginx_download:
archive.extracted:
- name: /tmp/
- source: http://nginx.org/download/nginx-{{ nginx.source_version }}.tar.gz
- source_hash: sha256={{ nginx.source_hash }}
- archive_format: tar
- if_missing: /usr/sbin/nginx-{{ nginx.source_version }}
- require:
- cmd: nginx_build_dep
- onchanges:
- cmd: nginx_build_dep
nginx_configure:
cmd.run:
- name: ./configure --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx --conf-path=/etc/nginx/nginx.conf {{ nginx.source.opts | join(' ') }}
- cwd: /tmp/nginx-{{ nginx.source_version }}
- require:
- archive: nginx_download
- onchanges:
- archive: nginx_download
nginx_compile:
cmd.run:
- name: make
- cwd: /tmp/nginx-{{ nginx.source_version }}
- require:
- cmd: nginx_configure
{% endif %}
nginx_install: nginx_install:
{% if nginx.install_from_source %} {% if nginx.install_from_source %}
## add source compilation here cmd.run:
- name: make install
- cwd: /tmp/nginx-{{ nginx.source_version }}
- require:
- cmd: nginx_compile
- onchanges:
- cmd: nginx_compile
{% else %} {% else %}
pkg.installed: pkg.installed:
{{ sls_block(nginx.package.opts) }} {{ sls_block(nginx.package.opts) }}
- name: {{ nginx.lookup.package }} - name: {{ nginx.lookup.package }}
{% endif %} {% endif %}
{% if nginx.install_from_source %}
nginx_link:
file.copy:
- name: /usr/sbin/nginx-{{ nginx.source_version }}
- source: /usr/sbin/nginx
- require:
- cmd: nginx_install
- onchanges:
- cmd: nginx_install
{% endif %}
{% if salt['grains.get']('os_family') == 'Debian' %} {% if salt['grains.get']('os_family') == 'Debian' %}
{%- if nginx.install_from_repo %} {%- if nginx.install_from_repo %}
nginx-official-repo: nginx-official-repo:

View File

@ -77,6 +77,11 @@
'install_from_ppa': False, 'install_from_ppa': False,
'install_from_repo': False, 'install_from_repo': False,
'ppa_version': 'stable', 'ppa_version': 'stable',
'source_version': '1.10.0',
'source_hash': '8ed647c3dd65bc4ced03b0e0f6bf9e633eff6b01bac772bcf97077d58bc2be4d',
'source': {
'opts': {},
},
'package': { 'package': {
'opts': {}, 'opts': {},
}, },

View File

@ -7,6 +7,12 @@
include: include:
- nginx.ng.install - nginx.ng.install
{% if nginx.install_from_source %}
/lib/systemd/system/nginx.service:
file.managed:
- source: salt://nginx/ng/files/nginx.service
{% endif %}
nginx_service: nginx_service:
service.{{ service_function }}: service.{{ service_function }}:
@ -16,6 +22,8 @@ nginx_service:
- require: - require:
- sls: nginx.ng.install - sls: nginx.ng.install
- watch: - watch:
{% if not nginx.install_from_source %} {% if nginx.install_from_source %}
- cmd: nginx_install
{% else %}
- pkg: nginx_install - pkg: nginx_install
{% endif %} {% endif %}

View File

@ -21,10 +21,14 @@ nginx:
nginx: nginx:
ng: ng:
# PPA installing # PPA install
install_from_ppa: True install_from_ppa: True
# Set to 'stable', 'development' (mainline), 'community', or 'nightly' for each build accordingly ( https://launchpad.net/~nginx ) # Set to 'stable', 'development' (mainline), 'community', or 'nightly' for each build accordingly ( https://launchpad.net/~nginx )
ppa_version: 'stable' ppa_version: 'stable'
# Source install
source_version: '1.10.0'
source_hash: ''
# These are usually set by grains in map.jinja # These are usually set by grains in map.jinja
lookup: lookup:
@ -43,6 +47,9 @@ nginx:
# Source compilation is not currently a part of nginx.ng # Source compilation is not currently a part of nginx.ng
from_source: False from_source: False
source:
opts: {}
package: package:
opts: {} # this partially exposes parameters of pkg.installed opts: {} # this partially exposes parameters of pkg.installed