Просмотр исходного кода

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.
susefix
George Robinson 8 лет назад
Родитель
Сommit
f24b066c43
6 измененных файлов: 102 добавлений и 3 удалений
  1. +15
    -0
      nginx/ng/files/nginx.service
  2. +6
    -0
      nginx/ng/init.sls
  3. +59
    -1
      nginx/ng/install.sls
  4. +5
    -0
      nginx/ng/map.jinja
  5. +9
    -1
      nginx/ng/service.sls
  6. +8
    -1
      pillar.example

+ 15
- 0
nginx/ng/files/nginx.service Просмотреть файл

@@ -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

+ 6
- 0
nginx/ng/init.sls Просмотреть файл

@@ -2,6 +2,8 @@
#
# Meta-state to fully install nginx.

{% from 'nginx/ng/map.jinja' import nginx, sls_block with context %}

include:
- nginx.ng.config
- nginx.ng.service
@@ -18,4 +20,8 @@ extend:
nginx_config:
file:
- require:
{% if nginx.install_from_source %}
- cmd: nginx_install
{% else %}
- pkg: nginx_install
{% endif %}

+ 59
- 1
nginx/ng/install.sls Просмотреть файл

@@ -4,15 +4,73 @@

{% 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:
{% 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 %}
pkg.installed:
{{ sls_block(nginx.package.opts) }}
- name: {{ nginx.lookup.package }}
{% 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 nginx.install_from_repo %}
nginx-official-repo:

+ 5
- 0
nginx/ng/map.jinja Просмотреть файл

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

+ 9
- 1
nginx/ng/service.sls Просмотреть файл

@@ -7,6 +7,12 @@

include:
- 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:
service.{{ service_function }}:
@@ -16,6 +22,8 @@ nginx_service:
- require:
- sls: nginx.ng.install
- watch:
{% if not nginx.install_from_source %}
{% if nginx.install_from_source %}
- cmd: nginx_install
{% else %}
- pkg: nginx_install
{% endif %}

+ 8
- 1
pillar.example Просмотреть файл

@@ -21,10 +21,14 @@ nginx:

nginx:
ng:
# PPA installing
# PPA install
install_from_ppa: True
# Set to 'stable', 'development' (mainline), 'community', or 'nightly' for each build accordingly ( https://launchpad.net/~nginx )
ppa_version: 'stable'

# Source install
source_version: '1.10.0'
source_hash: ''
# These are usually set by grains in map.jinja
lookup:
@@ -43,6 +47,9 @@ nginx:
# Source compilation is not currently a part of nginx.ng
from_source: False

source:
opts: {}

package:
opts: {} # this partially exposes parameters of pkg.installed


Загрузка…
Отмена
Сохранить