Compare commits
No commits in common. "master" and "2.4.0" have entirely different histories.
|
@ -1,8 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
# TODO: enable later
|
|
||||||
enable_list:
|
|
||||||
- fqcn-builtins
|
|
||||||
|
|
||||||
skip_list:
|
|
||||||
- role-name
|
|
|
@ -1,43 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
name: ci
|
|
||||||
'on':
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
|
|
||||||
yaml-lint:
|
|
||||||
name: YAML Lint
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
|
|
||||||
- name: Fetch code
|
|
||||||
uses: actions/checkout@v3
|
|
||||||
|
|
||||||
- name: Set up Python 3.
|
|
||||||
uses: actions/setup-python@v2
|
|
||||||
with:
|
|
||||||
python-version: '3.x'
|
|
||||||
|
|
||||||
- name: Install test dependencies.
|
|
||||||
run: pip3 install yamllint
|
|
||||||
|
|
||||||
- name: Lint code.
|
|
||||||
run: |
|
|
||||||
yamllint .
|
|
||||||
|
|
||||||
ansible-lint:
|
|
||||||
name: Ansible Lint
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Fetch code
|
|
||||||
uses: actions/checkout@v3
|
|
||||||
with:
|
|
||||||
fetch-depth: 0
|
|
||||||
|
|
||||||
- name: Run ansible-lint
|
|
||||||
uses: ansible/ansible-lint-action@v6.15.0
|
|
|
@ -1,17 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
name: Deploy on Ansible Galaxy
|
|
||||||
|
|
||||||
'on':
|
|
||||||
- push
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: checkout
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- name: galaxy
|
|
||||||
uses: robertdebock/galaxy-action@1.2.0
|
|
||||||
with:
|
|
||||||
galaxy_api_key: ${{ secrets.galaxy_api_key }}
|
|
|
@ -1,35 +0,0 @@
|
||||||
---
|
|
||||||
name: Molecule
|
|
||||||
|
|
||||||
'on':
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
strategy:
|
|
||||||
fail-fast: false
|
|
||||||
matrix:
|
|
||||||
scenario:
|
|
||||||
- debian-10
|
|
||||||
- debian-11
|
|
||||||
- debian-12
|
|
||||||
- ubuntu-18.04
|
|
||||||
- ubuntu-20.04
|
|
||||||
- ubuntu-22.04
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Checkout
|
|
||||||
uses: actions/checkout@v3
|
|
||||||
with:
|
|
||||||
path: "${{ github.repository }}"
|
|
||||||
|
|
||||||
- name: Molecule
|
|
||||||
uses: gofrolist/molecule-action@v2.3.19
|
|
||||||
with:
|
|
||||||
molecule_options: --base-config molecule/_shared/base.yml
|
|
||||||
molecule_args: --scenario-name ${{ matrix.scenario }}
|
|
||||||
molecule_working_dir: "HanXHX/ansible-php"
|
|
|
@ -2,6 +2,3 @@
|
||||||
*.swp
|
*.swp
|
||||||
*.retry
|
*.retry
|
||||||
*.log
|
*.log
|
||||||
/filter_plugins/*.pyc
|
|
||||||
/filter_plugins/__pycache__
|
|
||||||
/.idea
|
|
||||||
|
|
|
@ -0,0 +1,46 @@
|
||||||
|
env:
|
||||||
|
- PLATFORM='docker-debian-stretch-php70' ANSIBLE_VERSION='ansible>=2.6,<2.7'
|
||||||
|
- PLATFORM='docker-debian-stretch-php71' ANSIBLE_VERSION='ansible>=2.6,<2.7'
|
||||||
|
- PLATFORM='docker-debian-stretch-php72' ANSIBLE_VERSION='ansible>=2.6,<2.7'
|
||||||
|
- PLATFORM='docker-debian-stretch-php73' ANSIBLE_VERSION='ansible>=2.6,<2.7'
|
||||||
|
- PLATFORM='docker-debian-buster-php73' ANSIBLE_VERSION='ansible>=2.6,<2.7'
|
||||||
|
- PLATFORM='docker-ubuntu-xenial-php70' ANSIBLE_VERSION='ansible>=2.6,<2.7'
|
||||||
|
- PLATFORM='docker-ubuntu-bionic-php72' ANSIBLE_VERSION='ansible>=2.6,<2.7'
|
||||||
|
- PLATFORM='docker-ubuntu-bionic-php72' ANSIBLE_VERSION='ansible>=2.6,<2.7'
|
||||||
|
- PLATFORM='docker-debian-stretch-php70' ANSIBLE_VERSION='ansible>=2.7,<2.8'
|
||||||
|
- PLATFORM='docker-debian-stretch-php71' ANSIBLE_VERSION='ansible>=2.7,<2.8'
|
||||||
|
- PLATFORM='docker-debian-stretch-php72' ANSIBLE_VERSION='ansible>=2.7,<2.8'
|
||||||
|
- PLATFORM='docker-debian-stretch-php73' ANSIBLE_VERSION='ansible>=2.7,<2.8'
|
||||||
|
- PLATFORM='docker-debian-buster-php73' ANSIBLE_VERSION='ansible>=2.7,<2.8'
|
||||||
|
- PLATFORM='docker-ubuntu-xenial-php70' ANSIBLE_VERSION='ansible>=2.7,<2.8'
|
||||||
|
- PLATFORM='docker-ubuntu-bionic-php72' ANSIBLE_VERSION='ansible>=2.7,<2.8'
|
||||||
|
- PLATFORM='docker-ubuntu-bionic-php72' ANSIBLE_VERSION='ansible>=2.7,<2.8'
|
||||||
|
|
||||||
|
sudo: required
|
||||||
|
|
||||||
|
dist: trusty
|
||||||
|
|
||||||
|
language: python
|
||||||
|
python: 2.7
|
||||||
|
|
||||||
|
services:
|
||||||
|
- docker
|
||||||
|
|
||||||
|
before_install:
|
||||||
|
- wget https://releases.hashicorp.com/vagrant/2.0.1/vagrant_2.0.1_x86_64.deb
|
||||||
|
- sudo dpkg -i vagrant_2.0.1_x86_64.deb
|
||||||
|
|
||||||
|
install:
|
||||||
|
- pip install "$ANSIBLE_VERSION"
|
||||||
|
|
||||||
|
script:
|
||||||
|
- VAGRANT_DEFAULT_PROVIDER=docker vagrant up $PLATFORM
|
||||||
|
- >
|
||||||
|
VAGRANT_DEFAULT_PROVIDER=docker vagrant provision $PLATFORM
|
||||||
|
| grep -q 'changed=0.*failed=0'
|
||||||
|
&& (echo 'Idempotence test: pass' && exit 0)
|
||||||
|
|| (echo 'Idempotence test: fail' && exit 1)
|
||||||
|
- VAGRANT_DEFAULT_PROVIDER=docker vagrant status
|
||||||
|
|
||||||
|
notifications:
|
||||||
|
webhooks: https://galaxy.ansible.com/api/v1/notifications/
|
|
@ -1,6 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
extends: default
|
|
||||||
|
|
||||||
rules:
|
|
||||||
line-length: disable
|
|
34
README.md
34
README.md
|
@ -1,22 +1,21 @@
|
||||||
Ansible PHP (+FPM) role for Debian / Ubuntu / FreeBSD
|
Ansible PHP (+FPM) role for Debian / Ubuntu / FreeBSD
|
||||||
=====================================================
|
=====================================================
|
||||||
|
|
||||||
[](https://galaxy.ansible.com/hanxhx.php) 
|
[](https://galaxy.ansible.com/HanXHX/php) [](https://travis-ci.org/HanXHX/ansible-php)
|
||||||
|
|
||||||
Install PHP on Debian / Ubuntu / FreeBSD. Manage PHP-FPM, APCu, Opcache and Xdebug.
|
Install PHP on Debian / Ubuntu / FreeBSD. Manage PHP-FPM, APCu, Opcache and Xdebug.
|
||||||
|
|
||||||
Managed OS / Versions
|
Managed OS / Versions
|
||||||
---------------------
|
---------------------
|
||||||
|
|
||||||
On all Debian versions, you can install all PHP versions by using [Sury's APT repository](https://deb.sury.org/).
|
| OS | PHP 7.0 | PHP 7.1 | PHP 7.2 | PHP 7.3 |
|
||||||
|
|:---------------------:|:-------------------:|:--------------------------:|:--------------------------:|:-------------------------:|
|
||||||
Other cases:
|
| Debian Stretch (9) | :heavy_check_mark: | :heavy_check_mark: (Sury) | :heavy_check_mark: (Sury) | :heavy_check_mark: (Sury) |
|
||||||
|
| Debian Buster (10) | :x: | :x: | :x: | :heavy_check_mark: |
|
||||||
| OS | PHP 7.0 | PHP 7.1 | PHP 7.2 | PHP 7.3 | PHP >= 7.4 |
|
| Ubuntu Xenial (16.04) | :heavy_check_mark: | :x: | :x: | :x: |
|
||||||
|:---------------------:|:-------------------:|:--------------------:|:--------------------:|:--------------------:|:--------------------:
|
| Ubuntu Bionic (18.04) | :x: | :x: | :heavy_check_mark: | :x: |
|
||||||
| Ubuntu Bionic (18.04) | :x: | :x: | :heavy_check_mark: | :x: | :x: |
|
| FreeBSD 11 | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: |
|
||||||
| FreeBSD 11 | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | Need tests... |
|
| FreeBSD 12 | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: |
|
||||||
| FreeBSD 12 | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | Need tests... |
|
|
||||||
|
|
||||||
Links:
|
Links:
|
||||||
- [Sury](https://deb.sury.org/)
|
- [Sury](https://deb.sury.org/)
|
||||||
|
@ -24,15 +23,13 @@ Links:
|
||||||
Requirements
|
Requirements
|
||||||
------------
|
------------
|
||||||
|
|
||||||
- Ansible >= 2.11
|
If you need PHP-FPM, you must install a webserver with FastCGI support. You can use my [nginx role](https://github.com/HanXHX/ansible-nginx).
|
||||||
- Collections: [community.general](https://galaxy.ansible.com/community/general)
|
|
||||||
- If you need PHP-FPM, you must install a webserver with FastCGI support. You can use my [nginx role](https://github.com/HanXHX/ansible-nginx).
|
|
||||||
|
|
||||||
FreeBSD limitations
|
FreeBSD limitations
|
||||||
-------------------
|
-------------------
|
||||||
|
|
||||||
- It doesn't split ini file for FPM/CLI. It's hardcoded as `/usr/local/etc/php.ini`.
|
- It doesn't split ini file for FPM/CLI. It's hardcoded as `/usr/local/etc/php.ini`.
|
||||||
- It can't manage multiple PHP versions at the time (like legacy Debian versions)
|
- It can't manage multiple PHP versions at the time (like old Debian versions)
|
||||||
- You must explicitely set xdebug package name (use `pkg search xdebug` to find the good one)
|
- You must explicitely set xdebug package name (use `pkg search xdebug` to find the good one)
|
||||||
|
|
||||||
Role Variables
|
Role Variables
|
||||||
|
@ -42,7 +39,7 @@ You should look at [default vars](defaults/main.yml).
|
||||||
|
|
||||||
### Writable vars
|
### Writable vars
|
||||||
|
|
||||||
- `php_version`: 7.3, 7.4... depending OS (see above)
|
- `php_version`: 7.0, 7.1, 7.2, 7.3
|
||||||
- `php_install_fpm`: boolean, install and manage php-fpm (default is true)
|
- `php_install_fpm`: boolean, install and manage php-fpm (default is true)
|
||||||
- `php_install_xdebug`: boolean, install [Xdebug](http://xdebug.org)
|
- `php_install_xdebug`: boolean, install [Xdebug](http://xdebug.org)
|
||||||
- `php_extra_packages`: additional php packages to install (default is an empty list).
|
- `php_extra_packages`: additional php packages to install (default is an empty list).
|
||||||
|
@ -59,6 +56,7 @@ Note:
|
||||||
- Put specific configuration in `php_ini_fpm`/`php_ini_cli`.
|
- Put specific configuration in `php_ini_fpm`/`php_ini_cli`.
|
||||||
- You can override with `php_ini_fpm`/`php_ini_cli`, but it breaks idempotence.
|
- You can override with `php_ini_fpm`/`php_ini_cli`, but it breaks idempotence.
|
||||||
|
|
||||||
|
|
||||||
#### OpCache settings
|
#### OpCache settings
|
||||||
|
|
||||||
See [Opcache doc](https://secure.php.net/manual/en/opcache.configuration.php)
|
See [Opcache doc](https://secure.php.net/manual/en/opcache.configuration.php)
|
||||||
|
@ -161,14 +159,14 @@ Example Playbook
|
||||||
|
|
||||||
- hosts: servers
|
- hosts: servers
|
||||||
roles:
|
roles:
|
||||||
- { role: hanxhx.php }
|
- { role: HanXHX.php }
|
||||||
|
|
||||||
### Debian Bullseye with PHP 8.0 CLI (no FPM)
|
### Debian Stretch with PHP 7.2 CLI (no FPM)
|
||||||
|
|
||||||
- hosts: servers
|
- hosts: servers
|
||||||
roles:
|
roles:
|
||||||
- { role: HanXHX.sury }
|
- { role: HanXHX.sury }
|
||||||
- { role: hanxhx.php, php_version: '8.0', php_install_fpm: false }
|
- { role: HanXHX.php, php_version: '7.2', php_install_fpm: false }
|
||||||
|
|
||||||
License
|
License
|
||||||
-------
|
-------
|
||||||
|
|
|
@ -6,11 +6,13 @@
|
||||||
Vagrant.configure("2") do |config|
|
Vagrant.configure("2") do |config|
|
||||||
|
|
||||||
vms_debian = [
|
vms_debian = [
|
||||||
{ :name => "debian-buster-php73", :box => "debian/buster64", :vars => { }},
|
{ :name => "debian-stretch-php70", :box => "debian/stretch64", :vars => { }},
|
||||||
{ :name => "debian-buster-php74", :box => "debian/buster64", :vars => { "php_version": '7.4' }},
|
{ :name => "debian-stretch-php71", :box => "debian/stretch64", :vars => { "php_version": '7.1' }},
|
||||||
{ :name => "debian-bullseye-php74", :box => "debian/bullseye64", :vars => { }},
|
{ :name => "debian-stretch-php72", :box => "debian/stretch64", :vars => { "php_version": '7.2' }},
|
||||||
{ :name => "debian-bullseye-php80", :box => "debian/bullseye64", :vars => { "php_version": '8.0' }},
|
{ :name => "debian-stretch-php73", :box => "debian/stretch64", :vars => { "php_version": '7.3' }},
|
||||||
{ :name => "ubuntu-bionic-php72", :box => "ubuntu/bionic64", :vars => { }},
|
{ :name => "debian-buster-php73", :box => "debian/buster64", :vars => { }},
|
||||||
|
{ :name => "ubuntu-xenial-php70", :box => "ubuntu/xenial64", :vars => { }},
|
||||||
|
{ :name => "ubuntu-bionic-php72", :box => "ubuntu/bionic64", :vars => { }},
|
||||||
]
|
]
|
||||||
|
|
||||||
vms_freebsd = [
|
vms_freebsd = [
|
||||||
|
@ -19,11 +21,13 @@ Vagrant.configure("2") do |config|
|
||||||
]
|
]
|
||||||
|
|
||||||
conts = [
|
conts = [
|
||||||
{ :name => "docker-debian-buster-php73", :docker => "hanxhx/vagrant-ansible:debian10", :vars => { }},
|
{ :name => "docker-debian-stretch-php70", :docker => "hanxhx/vagrant-ansible:debian9", :vars => { }},
|
||||||
{ :name => "docker-debian-buster-php74", :docker => "hanxhx/vagrant-ansible:debian10", :vars => { "php_version": '7.4' }},
|
{ :name => "docker-debian-stretch-php71", :docker => "hanxhx/vagrant-ansible:debian9", :vars => { "php_version": '7.1' }},
|
||||||
{ :name => "docker-debian-bullseye-php74", :docker => "hanxhx/vagrant-ansible:debian11", :vars => { }},
|
{ :name => "docker-debian-stretch-php72", :docker => "hanxhx/vagrant-ansible:debian9", :vars => { "php_version": '7.2' }},
|
||||||
{ :name => "docker-debian-bullseye-php80", :docker => "hanxhx/vagrant-ansible:debian11", :vars => { "php_version": '8.0' }},
|
{ :name => "docker-debian-stretch-php73", :docker => "hanxhx/vagrant-ansible:debian9", :vars => { "php_version": '7.3' }},
|
||||||
{ :name => "docker-ubuntu-bionic-php72", :docker => "hanxhx/vagrant-ansible:ubuntu18.04", :vars => { }},
|
{ :name => "docker-debian-buster-php73", :docker => "hanxhx/vagrant-ansible:debian10", :vars => { }},
|
||||||
|
{ :name => "docker-ubuntu-xenial-php70", :docker => "hanxhx/vagrant-ansible:ubuntu16.04", :vars => { }},
|
||||||
|
{ :name => "docker-ubuntu-bionic-php72", :docker => "hanxhx/vagrant-ansible:ubuntu18.04", :vars => { }},
|
||||||
]
|
]
|
||||||
|
|
||||||
config.vm.network "private_network", type: "dhcp"
|
config.vm.network "private_network", type: "dhcp"
|
||||||
|
@ -35,8 +39,7 @@ Vagrant.configure("2") do |config|
|
||||||
d.remains_running = true
|
d.remains_running = true
|
||||||
d.has_ssh = true
|
d.has_ssh = true
|
||||||
end
|
end
|
||||||
|
m.vm.provision "shell", inline: "apt-get update && apt-get install -y python python-apt"
|
||||||
#m.vm.provision "shell", inline: "apt-get update && apt-get install -y python python-apt"
|
|
||||||
m.vm.provision "ansible" do |ansible|
|
m.vm.provision "ansible" do |ansible|
|
||||||
ansible.playbook = "tests/test.yml"
|
ansible.playbook = "tests/test.yml"
|
||||||
ansible.verbose = 'vv'
|
ansible.verbose = 'vv'
|
||||||
|
@ -54,7 +57,6 @@ Vagrant.configure("2") do |config|
|
||||||
v.memory = 256
|
v.memory = 256
|
||||||
end
|
end
|
||||||
m.vm.provision "shell", inline: "apt-get update && apt-get install -y ifupdown python"
|
m.vm.provision "shell", inline: "apt-get update && apt-get install -y ifupdown python"
|
||||||
|
|
||||||
m.vm.provision "ansible" do |ansible|
|
m.vm.provision "ansible" do |ansible|
|
||||||
ansible.playbook = "tests/test.yml"
|
ansible.playbook = "tests/test.yml"
|
||||||
ansible.verbose = 'vv'
|
ansible.verbose = 'vv'
|
||||||
|
|
|
@ -5,7 +5,6 @@ php_install_fpm: true
|
||||||
php_install_xdebug: false
|
php_install_xdebug: false
|
||||||
php_extra_packages: []
|
php_extra_packages: []
|
||||||
php_xdebug_package: null
|
php_xdebug_package: null
|
||||||
php_autoremove_default_pool: false
|
|
||||||
|
|
||||||
# php.ini config
|
# php.ini config
|
||||||
php_ini:
|
php_ini:
|
||||||
|
@ -91,10 +90,10 @@ php_xdebug_var_display_max_depth: '3'
|
||||||
|
|
||||||
# PHP-FPM
|
# PHP-FPM
|
||||||
php_fpm_poold:
|
php_fpm_poold:
|
||||||
- name: 'www'
|
- pool_name: 'www'
|
||||||
listen: '{{ php_default_fpm_sock }}'
|
listen: '{{ php_default_fpm_sock }}'
|
||||||
pm: 'dynamic'
|
pm: 'dynamic'
|
||||||
pm_max_children: 100
|
pm_max_children: 250
|
||||||
pm_start_servers: 10
|
pm_start_servers: 10
|
||||||
pm_min_spare_servers: 10
|
pm_min_spare_servers: 10
|
||||||
pm_max_spare_servers: 20
|
pm_max_spare_servers: 20
|
||||||
|
|
|
@ -1,10 +0,0 @@
|
||||||
def php_socket(php_version, pool_name):
|
|
||||||
return '/run/php/php%s-%s-fpm.sock' % (php_version, pool_name)
|
|
||||||
|
|
||||||
class FilterModule(object):
|
|
||||||
''' PHP module '''
|
|
||||||
|
|
||||||
def filters(self):
|
|
||||||
return {
|
|
||||||
'php_socket': php_socket,
|
|
||||||
}
|
|
|
@ -1,12 +1,14 @@
|
||||||
---
|
---
|
||||||
|
|
||||||
- name: Restart php-fpm
|
- name: restart php-fpm
|
||||||
ansible.builtin.service:
|
service:
|
||||||
name: '{{ php_fpm_service }}'
|
name: '{{ php_fpm_service }}'
|
||||||
state: restarted
|
state: restarted
|
||||||
when: php_install_fpm
|
when: php_install_fpm
|
||||||
notify: Docker restart php-fpm
|
notify: docker restart php-fpm
|
||||||
|
|
||||||
- name: Docker restart php-fpm # noqa: command-instead-of-module no-changed-when
|
- name: docker restart php-fpm
|
||||||
ansible.builtin.command: 'service {{ php_fpm_service }} restart'
|
command: 'service {{ php_fpm_service }} restart'
|
||||||
|
args:
|
||||||
|
warn: false
|
||||||
when: ansible_virtualization_type == 'docker'
|
when: ansible_virtualization_type == 'docker'
|
||||||
|
|
|
@ -1,6 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
argument_specs:
|
|
||||||
main:
|
|
||||||
short_description: Main entry point
|
|
||||||
options: {}
|
|
|
@ -1,35 +1,32 @@
|
||||||
---
|
---
|
||||||
galaxy_info:
|
galaxy_info:
|
||||||
author: Emilien Mantel
|
author: Emilien Mantel
|
||||||
role_name: php
|
description: Install and configure PHP 7.0/7.1/7.2/7.3
|
||||||
namespace: hanxhx
|
company:
|
||||||
description: Install and configure PHP 7.x/8.x
|
|
||||||
company: TripleStack
|
|
||||||
license: GPLv2
|
license: GPLv2
|
||||||
min_ansible_version: '2.11'
|
min_ansible_version: 2.6
|
||||||
platforms:
|
platforms:
|
||||||
- name: Debian
|
- name: Debian
|
||||||
versions:
|
versions:
|
||||||
- buster
|
- stretch
|
||||||
- bullseye
|
- buster
|
||||||
- bookworm
|
- name: Ubuntu
|
||||||
- name: Ubuntu
|
versions:
|
||||||
versions:
|
- xenial
|
||||||
- bionic
|
- bionic
|
||||||
- name: FreeBSD
|
- name: FreeBSD
|
||||||
versions:
|
versions:
|
||||||
- '11.0'
|
- 11.0
|
||||||
- '11.1'
|
- 11.1
|
||||||
- '12.0'
|
- 12.0
|
||||||
galaxy_tags:
|
galaxy_tags:
|
||||||
- development
|
- development
|
||||||
- web
|
- web
|
||||||
- php
|
- php
|
||||||
- fpm
|
- php-fpm
|
||||||
- php7
|
- php7
|
||||||
- php8
|
- debian
|
||||||
- debian
|
- ubuntu
|
||||||
- ubuntu
|
- freebsd
|
||||||
- freebsd
|
|
||||||
|
|
||||||
dependencies: []
|
dependencies: []
|
||||||
|
|
||||||
|
|
|
@ -1,19 +0,0 @@
|
||||||
# Molecule managed
|
|
||||||
|
|
||||||
{% if item.registry is defined %}
|
|
||||||
FROM {{ item.registry.url }}/{{ item.image }}
|
|
||||||
{% else %}
|
|
||||||
FROM {{ item.image }}
|
|
||||||
{% endif %}
|
|
||||||
|
|
||||||
{% if item.env is defined %}
|
|
||||||
{% for var, value in item.env.items() %}
|
|
||||||
{% if value %}
|
|
||||||
ENV {{ var }} {{ value }}
|
|
||||||
{% endif %}
|
|
||||||
{% endfor %}
|
|
||||||
{% endif %}
|
|
||||||
|
|
||||||
RUN apt-get update && \
|
|
||||||
apt-get install -y python3 sudo bash ca-certificates iproute2 python-apt-common \
|
|
||||||
&& apt-get clean
|
|
|
@ -1,36 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
scenario:
|
|
||||||
test_sequence:
|
|
||||||
- dependency
|
|
||||||
- syntax
|
|
||||||
- create
|
|
||||||
- prepare
|
|
||||||
- converge
|
|
||||||
- idempotence
|
|
||||||
- verify
|
|
||||||
- destroy
|
|
||||||
dependency:
|
|
||||||
name: galaxy
|
|
||||||
options:
|
|
||||||
requirements-file: ../../requirements.yml
|
|
||||||
driver:
|
|
||||||
name: docker
|
|
||||||
role_name_check: 1
|
|
||||||
provisioner:
|
|
||||||
name: ansible
|
|
||||||
config_options:
|
|
||||||
defaults:
|
|
||||||
deprecation_warnings: false
|
|
||||||
callback_whitelist: timer,profile_tasks
|
|
||||||
fact_caching: jsonfile
|
|
||||||
fact_caching_connection: ./cache
|
|
||||||
forks: 100
|
|
||||||
connection:
|
|
||||||
pipelining: true
|
|
||||||
playbooks:
|
|
||||||
converge: ../_shared/converge.yml
|
|
||||||
prepare: ../_shared/prepare.yml
|
|
||||||
verify: ../_shared/verify.yml
|
|
||||||
verifier:
|
|
||||||
name: ansible
|
|
|
@ -1,25 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
- name: Converge
|
|
||||||
hosts: all
|
|
||||||
gather_facts: true
|
|
||||||
handlers:
|
|
||||||
- name: Reload nginx
|
|
||||||
ansible.builtin.service:
|
|
||||||
name: nginx
|
|
||||||
state: reloaded
|
|
||||||
tasks:
|
|
||||||
- name: Include role
|
|
||||||
ansible.builtin.include_role:
|
|
||||||
name: "hanxhx.php"
|
|
||||||
post_tasks:
|
|
||||||
- name: TEMPLATE | Nginx site config
|
|
||||||
ansible.builtin.template:
|
|
||||||
src: "../../tests/templates/nginx.conf.j2"
|
|
||||||
dest: "{{ __nginx_conf }}"
|
|
||||||
mode: 0644
|
|
||||||
owner: root
|
|
||||||
group: root
|
|
||||||
notify: Reload nginx
|
|
||||||
vars_files:
|
|
||||||
- vars/misc.yml
|
|
|
@ -1,67 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
- name: Prepare
|
|
||||||
hosts: all
|
|
||||||
gather_facts: true
|
|
||||||
vars_files:
|
|
||||||
- vars/misc.yml
|
|
||||||
|
|
||||||
handlers:
|
|
||||||
- name: Reload nginx
|
|
||||||
ansible.builtin.service:
|
|
||||||
name: nginx
|
|
||||||
state: reloaded
|
|
||||||
|
|
||||||
tasks:
|
|
||||||
|
|
||||||
- name: INCLUDE_TASKS | Pre tasks related to OS
|
|
||||||
ansible.builtin.include_tasks: "../../tests/includes/pre_{{ ansible_os_family }}.yml"
|
|
||||||
|
|
||||||
- name: USER | Create PHP user
|
|
||||||
ansible.builtin.user:
|
|
||||||
name: 'foo'
|
|
||||||
system: true
|
|
||||||
create_home: false
|
|
||||||
shell: '/usr/sbin/nologin'
|
|
||||||
|
|
||||||
- name: COMMAND | Fix nginx config
|
|
||||||
ansible.builtin.command: "cp {{ __nginx_conf | dirname }}/fastcgi_params {{ __nginx_conf | dirname }}/fastcgi.conf"
|
|
||||||
args:
|
|
||||||
creates: "{{ __nginx_conf | dirname }}/fastcgi.conf"
|
|
||||||
notify: Reload nginx
|
|
||||||
|
|
||||||
- name: LINEINFILE | Fix nginx config (second step)
|
|
||||||
ansible.builtin.lineinfile:
|
|
||||||
regexp: '^fastcgi_param\s+SCRIPT_FILENAME'
|
|
||||||
line: "fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;"
|
|
||||||
dest: "{{ __nginx_conf | dirname }}/fastcgi.conf"
|
|
||||||
notify: Reload nginx
|
|
||||||
|
|
||||||
- name: SERVICE | Ensure nginx is started
|
|
||||||
ansible.builtin.service:
|
|
||||||
name: nginx
|
|
||||||
state: started
|
|
||||||
|
|
||||||
- name: FILE | Create /var/www
|
|
||||||
ansible.builtin.file:
|
|
||||||
dest: /var/www
|
|
||||||
state: directory
|
|
||||||
owner: root
|
|
||||||
group: root
|
|
||||||
mode: 0755
|
|
||||||
|
|
||||||
- name: COPY | Add phpinfo
|
|
||||||
ansible.builtin.copy:
|
|
||||||
dest: /var/www/phpinfo.php
|
|
||||||
content: '<?php phpinfo();'
|
|
||||||
owner: root
|
|
||||||
group: root
|
|
||||||
mode: 0644
|
|
||||||
|
|
||||||
- name: COPY | Add ini test file
|
|
||||||
ansible.builtin.copy:
|
|
||||||
dest: /var/www/ini.php
|
|
||||||
content: '<?php echo ini_get("memory_limit") . "\n";'
|
|
||||||
owner: root
|
|
||||||
group: root
|
|
||||||
mode: 0644
|
|
|
@ -1,36 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
# Force SysVinit, since systemd won't work in a Docker container
|
|
||||||
ansible_service_mgr: "sysvinit"
|
|
||||||
|
|
||||||
# ----------------------------------------
|
|
||||||
# Copied from {role_dir}/tests/test.yml
|
|
||||||
# ----------------------------------------
|
|
||||||
vhost: 'test.local'
|
|
||||||
php_extra_packages:
|
|
||||||
- '{{ php_package_prefix }}pgsql'
|
|
||||||
php_install_xdebug: true
|
|
||||||
php_autoremove_default_pool: true
|
|
||||||
php_ini_fpm:
|
|
||||||
display_errors: 'Off'
|
|
||||||
php_ini_cli:
|
|
||||||
error_reporting: 'E_ALL'
|
|
||||||
php_fpm_poold:
|
|
||||||
- pool_name: 'test_ansible'
|
|
||||||
listen: '/run/php/php-ansible1.sock'
|
|
||||||
pm: 'dynamic'
|
|
||||||
pm_max_children: 250
|
|
||||||
pm_start_servers: 10
|
|
||||||
pm_min_spare_servers: 10
|
|
||||||
pm_max_spare_servers: 20
|
|
||||||
status_path: '/status'
|
|
||||||
ping_path: '/ping'
|
|
||||||
ping_response: 'ok'
|
|
||||||
- name: 'test_ansible2'
|
|
||||||
user: 'foo'
|
|
||||||
php_env:
|
|
||||||
foo: bar
|
|
||||||
php_value:
|
|
||||||
display_errors: 'Off'
|
|
||||||
php_admin_value:
|
|
||||||
memory_limit: '98M'
|
|
|
@ -1,74 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
- name: Verify
|
|
||||||
hosts: all
|
|
||||||
gather_facts: true
|
|
||||||
vars_files:
|
|
||||||
- vars/misc.yml
|
|
||||||
tasks:
|
|
||||||
|
|
||||||
- name: COMMAND | Test php-cli
|
|
||||||
ansible.builtin.command: php -v
|
|
||||||
changed_when: false
|
|
||||||
|
|
||||||
- name: SHELL | Check vhost
|
|
||||||
ansible.builtin.shell: "set -o pipefail && curl -v -H 'Host: {{ vhost }}' http://127.0.0.1/phpinfo.php 2> /dev/null | grep h1 | grep 'PHP Version'"
|
|
||||||
args:
|
|
||||||
executable: /bin/bash
|
|
||||||
changed_when: false
|
|
||||||
register: c
|
|
||||||
failed_when: c.stdout == ''
|
|
||||||
|
|
||||||
- name: BLOCK | Test explicit version
|
|
||||||
when: php_version is defined
|
|
||||||
block:
|
|
||||||
|
|
||||||
- name: SHELL | Test php-cli (explicit version)
|
|
||||||
ansible.builtin.shell: set -o pipefail && php -i | grep '^PHP Version => {{ php_version }}' | head -n 1
|
|
||||||
changed_when: false
|
|
||||||
register: p
|
|
||||||
failed_when: p.stdout == ''
|
|
||||||
args:
|
|
||||||
executable: /bin/bash
|
|
||||||
|
|
||||||
- name: SHELL | Check vhost
|
|
||||||
ansible.builtin.shell: "set -o pipefail && curl -v -H 'Host: {{ vhost }}' http://127.0.0.1/phpinfo.php 2> /dev/null | grep h1 | grep -o 'PHP Version {{ php_version }}' | sed -r 's/<//g'"
|
|
||||||
args:
|
|
||||||
executable: /bin/bash
|
|
||||||
changed_when: false
|
|
||||||
register: c
|
|
||||||
failed_when: c.stdout == ''
|
|
||||||
|
|
||||||
- name: SHELL | Check custom php value # noqa: command-instead-of-module
|
|
||||||
ansible.builtin.shell: "curl -H 'Host: {{ vhost }}' http://127.0.0.1/ini.php 2> /dev/null"
|
|
||||||
changed_when: false
|
|
||||||
register: c
|
|
||||||
failed_when: 'php_fpm_poold.1.php_admin_value.memory_limit not in c.stdout'
|
|
||||||
|
|
||||||
- name: URI | Check ping
|
|
||||||
ansible.builtin.uri:
|
|
||||||
url: "http://localhost{{ php_fpm_poold.0.ping_path }}"
|
|
||||||
when: php_fpm_poold.0.ping_path is defined
|
|
||||||
|
|
||||||
- name: URI | Check status
|
|
||||||
ansible.builtin.uri:
|
|
||||||
url: "http://localhost{{ php_fpm_poold.0.status_path }}"
|
|
||||||
when: php_fpm_poold.0.status_path is defined
|
|
||||||
|
|
||||||
- name: Debian extra checks
|
|
||||||
when: ansible_os_family == 'Debian'
|
|
||||||
block:
|
|
||||||
|
|
||||||
- name: SHELL | Check if we installed multiple PHP versions
|
|
||||||
ansible.builtin.shell: set -o pipefail && (dpkg -l | grep 'php[[:digit:]].*common' | wc -l)
|
|
||||||
args:
|
|
||||||
executable: /bin/bash
|
|
||||||
failed_when: false
|
|
||||||
changed_when: false
|
|
||||||
register: check_multiple_php
|
|
||||||
|
|
||||||
|
|
||||||
- name: FAIL | If we have multiple PHP version
|
|
||||||
ansible.builtin.fail:
|
|
||||||
msg: "Multiple PHP versions detected"
|
|
||||||
when: check_multiple_php.stdout != '1'
|
|
|
@ -1,32 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
platforms:
|
|
||||||
- name: debian-10
|
|
||||||
image: dokken/debian-10
|
|
||||||
command: /lib/systemd/systemd
|
|
||||||
dockerfile: ../_shared/Dockerfile.j2
|
|
||||||
capabilities:
|
|
||||||
- SYS_ADMIN
|
|
||||||
cgroupns_mode: host
|
|
||||||
volumes:
|
|
||||||
- /sys/fs/cgroup:/sys/fs/cgroup:rw
|
|
||||||
privileged: true
|
|
||||||
- name: debian-10-php-7.4
|
|
||||||
image: dokken/debian-10
|
|
||||||
command: /lib/systemd/systemd
|
|
||||||
dockerfile: ../_shared/Dockerfile.j2
|
|
||||||
capabilities:
|
|
||||||
- SYS_ADMIN
|
|
||||||
cgroupns_mode: host
|
|
||||||
volumes:
|
|
||||||
- /sys/fs/cgroup:/sys/fs/cgroup:rw
|
|
||||||
privileged: true
|
|
||||||
|
|
||||||
provisioner:
|
|
||||||
inventory:
|
|
||||||
group_vars:
|
|
||||||
all:
|
|
||||||
__nginx_conf: /etc/nginx/nginx.conf
|
|
||||||
host_vars:
|
|
||||||
debian-10-php-7.4:
|
|
||||||
php_version: '7.4'
|
|
|
@ -1,32 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
platforms:
|
|
||||||
- name: debian-11
|
|
||||||
image: dokken/debian-11
|
|
||||||
command: /lib/systemd/systemd
|
|
||||||
dockerfile: ../_shared/Dockerfile.j2
|
|
||||||
capabilities:
|
|
||||||
- SYS_ADMIN
|
|
||||||
cgroupns_mode: host
|
|
||||||
volumes:
|
|
||||||
- /sys/fs/cgroup:/sys/fs/cgroup:rw
|
|
||||||
privileged: true
|
|
||||||
- name: debian-11-php-8.0
|
|
||||||
image: dokken/debian-11
|
|
||||||
command: /lib/systemd/systemd
|
|
||||||
dockerfile: ../_shared/Dockerfile.j2
|
|
||||||
capabilities:
|
|
||||||
- SYS_ADMIN
|
|
||||||
cgroupns_mode: host
|
|
||||||
volumes:
|
|
||||||
- /sys/fs/cgroup:/sys/fs/cgroup:rw
|
|
||||||
privileged: true
|
|
||||||
|
|
||||||
provisioner:
|
|
||||||
inventory:
|
|
||||||
group_vars:
|
|
||||||
all:
|
|
||||||
__nginx_conf: /etc/nginx/nginx.conf
|
|
||||||
host_vars:
|
|
||||||
debian-11-php-8.0:
|
|
||||||
php_version: '8.0'
|
|
|
@ -1,19 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
platforms:
|
|
||||||
- name: debian-12
|
|
||||||
image: dokken/debian-12
|
|
||||||
command: /lib/systemd/systemd
|
|
||||||
dockerfile: ../_shared/Dockerfile.j2
|
|
||||||
capabilities:
|
|
||||||
- SYS_ADMIN
|
|
||||||
cgroupns_mode: host
|
|
||||||
volumes:
|
|
||||||
- /sys/fs/cgroup:/sys/fs/cgroup:rw
|
|
||||||
privileged: true
|
|
||||||
|
|
||||||
provisioner:
|
|
||||||
inventory:
|
|
||||||
group_vars:
|
|
||||||
all:
|
|
||||||
__nginx_conf: /etc/nginx/nginx.conf
|
|
|
@ -1,19 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
platforms:
|
|
||||||
- name: ubuntu-18.04
|
|
||||||
image: dokken/ubuntu-18.04
|
|
||||||
command: /lib/systemd/systemd
|
|
||||||
dockerfile: ../_shared/Dockerfile.j2
|
|
||||||
capabilities:
|
|
||||||
- SYS_ADMIN
|
|
||||||
cgroupns_mode: host
|
|
||||||
volumes:
|
|
||||||
- /sys/fs/cgroup:/sys/fs/cgroup:rw
|
|
||||||
privileged: true
|
|
||||||
|
|
||||||
provisioner:
|
|
||||||
inventory:
|
|
||||||
group_vars:
|
|
||||||
all:
|
|
||||||
__nginx_conf: /etc/nginx/nginx.conf
|
|
|
@ -1,19 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
platforms:
|
|
||||||
- name: ubuntu-20.04
|
|
||||||
image: dokken/ubuntu-20.04
|
|
||||||
command: /lib/systemd/systemd
|
|
||||||
dockerfile: ../_shared/Dockerfile.j2
|
|
||||||
capabilities:
|
|
||||||
- SYS_ADMIN
|
|
||||||
cgroupns_mode: host
|
|
||||||
volumes:
|
|
||||||
- /sys/fs/cgroup:/sys/fs/cgroup:rw
|
|
||||||
privileged: true
|
|
||||||
|
|
||||||
provisioner:
|
|
||||||
inventory:
|
|
||||||
group_vars:
|
|
||||||
all:
|
|
||||||
__nginx_conf: /etc/nginx/nginx.conf
|
|
|
@ -1,19 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
platforms:
|
|
||||||
- name: ubuntu-22.04
|
|
||||||
image: dokken/ubuntu-22.04
|
|
||||||
command: /lib/systemd/systemd
|
|
||||||
dockerfile: ../_shared/Dockerfile.j2
|
|
||||||
capabilities:
|
|
||||||
- SYS_ADMIN
|
|
||||||
cgroupns_mode: host
|
|
||||||
volumes:
|
|
||||||
- /sys/fs/cgroup:/sys/fs/cgroup:rw
|
|
||||||
privileged: true
|
|
||||||
|
|
||||||
provisioner:
|
|
||||||
inventory:
|
|
||||||
group_vars:
|
|
||||||
all:
|
|
||||||
__nginx_conf: /etc/nginx/nginx.conf
|
|
|
@ -1,4 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
collections:
|
|
||||||
- community.general
|
|
|
@ -1,46 +1,36 @@
|
||||||
---
|
---
|
||||||
|
|
||||||
- name: APT | Install PHP-FPM for Debian based systems
|
- name: APT | Install PHP-FPM for Debian based systems
|
||||||
ansible.builtin.apt:
|
apt:
|
||||||
pkg: "{{ php_fpm_service }}"
|
pkg: "{{ php_fpm_service }}"
|
||||||
state: "{{ 'present' if php_install_fpm else 'absent' }}"
|
state: "{{ 'present' if php_install_fpm else 'absent' }}"
|
||||||
when: ansible_os_family == 'Debian'
|
when: ansible_os_family == 'Debian'
|
||||||
|
|
||||||
- name: SERVICE | Enable service on FreeBSD
|
- name: SERVICE | Enable service on FreeBSD
|
||||||
ansible.builtin.service:
|
service:
|
||||||
name: "{{ php_fpm_service }}"
|
name: "{{ php_fpm_service }}"
|
||||||
enabled: "{{ 'true' if php_install_fpm else 'false' }}"
|
enabled: "{{ 'yes' if php_install_fpm else 'no' }}"
|
||||||
when: ansible_os_family == 'FreeBSD'
|
when: ansible_os_family == 'FreeBSD'
|
||||||
|
|
||||||
- name: LINEINFILE | PHP configuration
|
- name: LINEINFILE | PHP configuration
|
||||||
ansible.builtin.lineinfile:
|
lineinfile:
|
||||||
dest: '{{ php_fpm_ini }}'
|
dest: '{{ php_cli_ini }}'
|
||||||
regexp: '^;?{{ item.key }}'
|
regexp: '^;?{{ item.key }}'
|
||||||
line: '{{ item.key }} = {{ item.value }}'
|
line: '{{ item.key }} = {{ item.value }}'
|
||||||
create: true
|
create: yes
|
||||||
owner: root
|
|
||||||
group: root
|
|
||||||
mode: 0644
|
|
||||||
loop: "{{ php_ini | combine(php_ini_fpm) | dict2items }}"
|
loop: "{{ php_ini | combine(php_ini_fpm) | dict2items }}"
|
||||||
when: php_install_fpm | bool
|
notify: restart php-fpm
|
||||||
notify: Restart php-fpm
|
|
||||||
|
|
||||||
- name: TEMPLATE | Deploy pool configuration
|
- name: TEMPLATE | Deploy pool configuration
|
||||||
ansible.builtin.template:
|
template:
|
||||||
src: etc/__php__/fpm/pool.d/pool.conf.j2
|
src: etc/__php__/fpm/pool.d/pool.conf.j2
|
||||||
dest: '{{ php_fpm_pool_dir }}/{{ item.name }}.conf'
|
dest: '{{ php_fpm_pool_dir }}/{{ item.pool_name }}.conf'
|
||||||
owner: root
|
loop: "{{ php_fpm_poold }}"
|
||||||
group: root
|
notify: restart php-fpm
|
||||||
mode: 0644
|
|
||||||
loop: "{{ ansible_local.hanxhx_php.fpm_pool }}"
|
|
||||||
when: php_install_fpm | bool
|
|
||||||
notify: Restart php-fpm
|
|
||||||
|
|
||||||
- name: FILE | Delete default pool if necessary
|
- name: FILE | Delete default pool if necessary
|
||||||
ansible.builtin.file:
|
file:
|
||||||
path: "{{ php_fpm_pool_dir }}/www.conf"
|
path: "{{ php_fpm_pool_dir }}/www.conf"
|
||||||
state: absent
|
state: absent
|
||||||
when:
|
when: '"www" not in (php_fpm_poold | map(attribute="pool_name") | list)'
|
||||||
- '"www" not in (ansible_local.hanxhx_php.fpm_pool | map(attribute="name") | list) and php_autoremove_default_pool'
|
notify: restart php-fpm
|
||||||
- php_install_fpm | bool
|
|
||||||
notify: Restart php-fpm
|
|
||||||
|
|
124
tasks/main.yml
124
tasks/main.yml
|
@ -1,125 +1,73 @@
|
||||||
---
|
---
|
||||||
|
|
||||||
- name: SHELL | Check if we are in multiple PHP distribution
|
- name: SET_FACT | Bypass https://github.com/ansible/ansible/issues/19874
|
||||||
ansible.builtin.shell: set -o pipefail && apt-cache search php xdebug | grep 'php[[:digit:]].[[:digit:]]'
|
set_fact:
|
||||||
args:
|
ansible_distribution_release: 'buster'
|
||||||
executable: /bin/bash
|
when: ansible_facts.distribution_major_version == "buster/sid"
|
||||||
failed_when: false
|
|
||||||
changed_when: false
|
|
||||||
register: multiple_php
|
|
||||||
when: ansible_os_family == 'Debian'
|
|
||||||
|
|
||||||
- name: INCLUDE_VARS | Related to OS family
|
- name: INCLUDE_VARS | Related to OS family
|
||||||
ansible.builtin.include_vars: "OS_Family_{{ ansible_os_family }}.yml"
|
include_vars: "OS_Family_{{ ansible_os_family }}.yml"
|
||||||
|
|
||||||
- name: INCLUDE_VARS | Related to OS version
|
- name: INCLUDE_VARS | Related to OS version
|
||||||
ansible.builtin.include_vars: "{{ item }}"
|
include_vars: "{{ item }}"
|
||||||
with_first_found:
|
with_first_found:
|
||||||
- "{{ ansible_distribution }}-{{ ansible_distribution_release }}.yml"
|
- "{{ ansible_distribution }}-{{ ansible_distribution_release }}.yml"
|
||||||
- "{{ ansible_distribution }}-{{ ansible_distribution_version }}.yml"
|
- "{{ ansible_distribution }}-{{ ansible_distribution_version }}.yml"
|
||||||
- "{{ ansible_distribution }}-{{ ansible_distribution_major_version }}.yml"
|
- "{{ ansible_distribution }}-{{ ansible_distribution_major_version }}.yml"
|
||||||
|
|
||||||
- name: SET_FACT | Transform data
|
|
||||||
ansible.builtin.set_fact:
|
|
||||||
__php_fpm_full_pool: |
|
|
||||||
[
|
|
||||||
{% for p in php_fpm_poold %}
|
|
||||||
{
|
|
||||||
name: "{{ p.name | default(p.pool_name) }}",
|
|
||||||
listen: "{{ p.listen | default(php_version | php_socket(p.name | default(p.pool_name))) }}",
|
|
||||||
user: "{{ p.user | default(php_default_user_group) }}",
|
|
||||||
group: "{% if p.user is defined %}{{ p.group | default(p.user) }}{% else %}{{ p.group | default(php_default_user_group) }}{% endif %}",
|
|
||||||
php_env: {% if p.php_env is defined %}{{ p.php_env | to_nice_json }}{% else %}{}{% endif %},
|
|
||||||
php_value: {% if p.php_value is defined %}{{ p.php_value | to_nice_json }}{% else %}{}{% endif %},
|
|
||||||
php_admin_value: {% if p.php_admin_value is defined %}{{ p.php_admin_value | to_nice_json }}{% else %}{}{% endif %},
|
|
||||||
{% for k, v in p.items() | list %}
|
|
||||||
{% if k not in ['name', 'pool_name', 'listen', 'user', 'group', 'php_env', 'php_value', 'php_admin_value'] %}
|
|
||||||
{{ k }}: "{{ v }}"{% if not loop.last %},{% endif %}
|
|
||||||
{% endif %}
|
|
||||||
{% endfor %}
|
|
||||||
}{% if not loop.last %},{% endif %}
|
|
||||||
{% endfor %}
|
|
||||||
]
|
|
||||||
|
|
||||||
- name: SET_FACT | To YAML
|
|
||||||
ansible.builtin.set_fact:
|
|
||||||
php_fpm_full_pool: "{{ __php_fpm_full_pool | from_yaml }}"
|
|
||||||
|
|
||||||
- name: FILE | Creates ansible facts.d
|
|
||||||
ansible.builtin.file:
|
|
||||||
path: /etc/ansible/facts.d
|
|
||||||
state: directory
|
|
||||||
owner: root
|
|
||||||
group: root
|
|
||||||
mode: 0755
|
|
||||||
|
|
||||||
- name: COPY | Manage facts
|
|
||||||
ansible.builtin.copy:
|
|
||||||
content: "{ \"fpm_pool\": {{ php_fpm_full_pool | to_nice_json }} }"
|
|
||||||
dest: /etc/ansible/facts.d/hanxhx_php.fact
|
|
||||||
owner: root
|
|
||||||
group: root
|
|
||||||
mode: 0644
|
|
||||||
register: f
|
|
||||||
tags:
|
|
||||||
- skip_ansible_lint
|
|
||||||
|
|
||||||
- name: SETUP | Gathers new facts
|
|
||||||
ansible.builtin.setup:
|
|
||||||
when: f.changed
|
|
||||||
tags:
|
|
||||||
- skip_ansible_lint
|
|
||||||
|
|
||||||
- name: APT | Install PHP packages
|
- name: APT | Install PHP packages
|
||||||
ansible.builtin.apt:
|
apt:
|
||||||
pkg: "{{ pkgs }}"
|
pkg: "{{ item }}"
|
||||||
state: present
|
state: present
|
||||||
update_cache: true
|
update_cache: yes
|
||||||
cache_valid_time: 3600
|
cache_valid_time: 3600
|
||||||
install_recommends: false
|
loop: "{{ php_packages + php_extra_packages | flatten }}"
|
||||||
vars:
|
notify: restart php-fpm
|
||||||
pkgs: "{{ php_packages + php_extra_packages | flatten }}"
|
|
||||||
notify: Restart php-fpm
|
|
||||||
when: ansible_os_family == 'Debian'
|
when: ansible_os_family == 'Debian'
|
||||||
|
|
||||||
- name: PKGNG | Install PHP packages
|
- name: PKGNG | Install PHP packages
|
||||||
community.general.pkgng:
|
pkgng:
|
||||||
name: "{{ php_packages + php_extra_packages | flatten | join(',') }}"
|
name: "{{ item }}"
|
||||||
notify: Restart php-fpm
|
loop: "{{ php_packages + php_extra_packages | flatten }}"
|
||||||
|
notify: restart php-fpm
|
||||||
when: ansible_os_family == 'FreeBSD'
|
when: ansible_os_family == 'FreeBSD'
|
||||||
|
|
||||||
- name: IMPORT_TASKS | PHP-FPM
|
- name: IMPORT_TASKS | PHP-FPM
|
||||||
ansible.builtin.import_tasks: fpm.yml
|
import_tasks: fpm.yml
|
||||||
|
|
||||||
- name: LINEINFILE | PHP CLI configuration
|
- name: LINEINFILE | PHP CLI configuration
|
||||||
ansible.builtin.lineinfile:
|
lineinfile:
|
||||||
dest: '{{ php_cli_ini }}'
|
dest: '{{ php_cli_ini }}'
|
||||||
regexp: '^;?{{ item.key }}'
|
regexp: '^;?{{ item.key }}'
|
||||||
line: '{{ item.key }} = {{ item.value }}'
|
line: '{{ item.key }} = {{ item.value }}'
|
||||||
loop: "{{ php_ini | combine(php_ini_cli) | dict2items }}"
|
loop: "{{ php_ini | combine(php_ini_cli) | dict2items }}"
|
||||||
|
|
||||||
- name: IMPORT_TASKS | Xdebug
|
- name: IMPORT_TASKS | Xdebug
|
||||||
ansible.builtin.import_tasks: xdebug.yml
|
import_tasks: xdebug.yml
|
||||||
|
|
||||||
- name: APT | Install and configure opcache
|
- name: APT | Install and configure opcache
|
||||||
ansible.builtin.import_tasks: opcache.yml
|
import_tasks: opcache.yml
|
||||||
|
|
||||||
- name: SERVICE | Ensure PHP-FPM is started
|
- name: SERVICE | Ensure PHP-FPM is started
|
||||||
ansible.builtin.service:
|
service:
|
||||||
name: '{{ php_fpm_service }}'
|
name: '{{ php_fpm_service }}'
|
||||||
state: started
|
state: started
|
||||||
when: php_install_fpm and ansible_virtualization_type != 'docker'
|
when: php_install_fpm and ansible_virtualization_type != 'docker'
|
||||||
|
|
||||||
- name: BLOCK | Ensure PHP-FPM is started if running on Docker
|
- block:
|
||||||
|
|
||||||
|
- name: COMMAND | Check if PHP-FPM is started (Docker)
|
||||||
|
command: 'service {{ php_fpm_service }} status'
|
||||||
|
args:
|
||||||
|
warn: false
|
||||||
|
register: dps
|
||||||
|
changed_when: false
|
||||||
|
failed_when: false
|
||||||
|
|
||||||
|
- name: COMMAND | Ensure PHP-FPM is started (Docker)
|
||||||
|
command: 'service {{ php_fpm_service }} start'
|
||||||
|
args:
|
||||||
|
warn: false
|
||||||
|
when: dps.stdout.find('is not running') != -1
|
||||||
|
|
||||||
when: php_install_fpm and ansible_virtualization_type == 'docker'
|
when: php_install_fpm and ansible_virtualization_type == 'docker'
|
||||||
block:
|
|
||||||
|
|
||||||
- name: COMMAND | Check if PHP-FPM is started (Docker) # noqa: command-instead-of-module
|
|
||||||
ansible.builtin.command: 'service {{ php_fpm_service }} status'
|
|
||||||
register: dps
|
|
||||||
changed_when: false
|
|
||||||
failed_when: false
|
|
||||||
|
|
||||||
- name: COMMAND | Ensure PHP-FPM is started (Docker) # noqa: command-instead-of-module no-changed-when
|
|
||||||
ansible.builtin.command: 'service {{ php_fpm_service }} start'
|
|
||||||
when: dps.stdout.find('is not running') != -1
|
|
||||||
|
|
|
@ -1,46 +1,37 @@
|
||||||
---
|
---
|
||||||
|
|
||||||
- name: Install opcache/apcu on Debian
|
- block:
|
||||||
|
|
||||||
|
- name: APT | Install APCu
|
||||||
|
apt:
|
||||||
|
pkg: "php-apcu"
|
||||||
|
|
||||||
|
- name: APT | Install Opcache
|
||||||
|
apt:
|
||||||
|
pkg: "{{ php_package_prefix }}opcache"
|
||||||
|
|
||||||
when: ansible_os_family == 'Debian'
|
when: ansible_os_family == 'Debian'
|
||||||
block:
|
|
||||||
|
|
||||||
- name: APT | Install APCu
|
- block:
|
||||||
ansible.builtin.apt:
|
|
||||||
pkg: "{{ php_apcu_package }}"
|
|
||||||
install_recommends: false
|
|
||||||
|
|
||||||
- name: APT | Install Opcache
|
- name: PKGNG | Install APCu
|
||||||
ansible.builtin.apt:
|
pkgng:
|
||||||
pkg: "{{ php_package_prefix }}opcache"
|
name: "php{{ php_version | replace('.', '') }}-pecl-APCu"
|
||||||
install_recommends: false
|
|
||||||
|
|
||||||
|
- name: PKGNG | Install Opcache
|
||||||
|
pkgng:
|
||||||
|
name: "{{ php_package_prefix }}opcache"
|
||||||
|
|
||||||
- name: Install opcache/apcu on FreeBSD
|
|
||||||
when: ansible_os_family == 'FreeBSD'
|
when: ansible_os_family == 'FreeBSD'
|
||||||
block:
|
|
||||||
|
|
||||||
- name: PKGNG | Install APCu
|
|
||||||
community.general.pkgng:
|
|
||||||
name: "php{{ php_version | replace('.', '') }}-pecl-APCu"
|
|
||||||
|
|
||||||
- name: PKGNG | Install Opcache
|
|
||||||
community.general.pkgng:
|
|
||||||
name: "{{ php_package_prefix }}opcache"
|
|
||||||
|
|
||||||
- name: TEMPLATE | Configure Opcache
|
- name: TEMPLATE | Configure Opcache
|
||||||
ansible.builtin.template:
|
template:
|
||||||
src: "etc/__php__/mods-available/opcache.ini.j2"
|
src: "etc/__php__/mods-available/opcache.ini.j2"
|
||||||
dest: "{{ php_mods_dir }}/opcache.ini"
|
dest: "{{ php_mods_dir }}/opcache.ini"
|
||||||
owner: root
|
notify: restart php-fpm
|
||||||
group: root
|
|
||||||
mode: 0644
|
|
||||||
notify: Restart php-fpm
|
|
||||||
|
|
||||||
- name: TEMPLATE | Configure APCu
|
- name: TEMPLATE | Configure APCu
|
||||||
ansible.builtin.template:
|
template:
|
||||||
src: "etc/__php__/mods-available/apcu.ini.j2"
|
src: "etc/__php__/mods-available/apcu.ini.j2"
|
||||||
dest: "{{ php_mods_dir }}/apcu.ini"
|
dest: "{{ php_mods_dir }}/apcu.ini"
|
||||||
owner: root
|
notify: restart php-fpm
|
||||||
group: root
|
|
||||||
mode: 0644
|
|
||||||
notify: Restart php-fpm
|
|
||||||
|
|
|
@ -1,44 +1,41 @@
|
||||||
---
|
---
|
||||||
|
|
||||||
- name: BLOCK | Uninstall xdebug
|
- block:
|
||||||
|
|
||||||
|
- name: APT | Install xdebug
|
||||||
|
apt:
|
||||||
|
pkg: "{{ php_xdebug_package }}"
|
||||||
|
state: present
|
||||||
|
update_cache: yes
|
||||||
|
cache_valid_time: 3600
|
||||||
|
when: ansible_os_family == 'Debian'
|
||||||
|
|
||||||
|
- name: PKGNG | Install xdebug
|
||||||
|
pkgng:
|
||||||
|
name: "{{ php_xdebug_package }}"
|
||||||
|
when: ansible_os_family == 'FreeBSD' and php_xdebug_package is defined
|
||||||
|
|
||||||
|
- name: TEMPLATE | Deploy module configurations
|
||||||
|
template:
|
||||||
|
src: "etc/__php__/mods-available/xdebug.ini.j2"
|
||||||
|
dest: "{{ php_mods_dir }}/xdebug.ini"
|
||||||
|
owner: root
|
||||||
|
mode: 0644
|
||||||
|
notify: restart php-fpm
|
||||||
|
|
||||||
when: php_install_xdebug
|
when: php_install_xdebug
|
||||||
block:
|
|
||||||
|
|
||||||
- name: APT | Install xdebug
|
- block:
|
||||||
ansible.builtin.apt:
|
|
||||||
pkg: "{{ php_xdebug_package }}"
|
|
||||||
state: present
|
|
||||||
update_cache: true
|
|
||||||
cache_valid_time: 3600
|
|
||||||
install_recommends: false
|
|
||||||
when: ansible_os_family == 'Debian'
|
|
||||||
|
|
||||||
- name: PKGNG | Install xdebug
|
- name: APT | Uninstall xdebug
|
||||||
community.general.pkgng:
|
apt:
|
||||||
name: "{{ php_xdebug_package }}"
|
pkg: "{{ php_xdebug_package }}"
|
||||||
when: ansible_os_family == 'FreeBSD' and php_xdebug_package is defined
|
state: absent
|
||||||
|
when: ansible_os_family == 'Debian'
|
||||||
|
|
||||||
- name: TEMPLATE | Deploy module configurations
|
- name: PKGNG | Install xdebug
|
||||||
ansible.builtin.template:
|
pkgng:
|
||||||
src: "etc/__php__/mods-available/xdebug.ini.j2"
|
name: "{{ php_xdebug_package }}"
|
||||||
dest: "{{ php_mods_dir }}/xdebug.ini"
|
when: ansible_os_family == 'FreeBSD' and php_xdebug_package is defined
|
||||||
owner: root
|
|
||||||
mode: 0644
|
|
||||||
notify: Restart php-fpm
|
|
||||||
|
|
||||||
|
|
||||||
- name: BLOCK | Uninstall xdebug
|
|
||||||
when: not php_install_xdebug
|
when: not php_install_xdebug
|
||||||
block:
|
|
||||||
|
|
||||||
- name: APT | Uninstall xdebug
|
|
||||||
ansible.builtin.apt:
|
|
||||||
pkg: "{{ php_xdebug_package }}"
|
|
||||||
state: absent
|
|
||||||
when: ansible_os_family == 'Debian'
|
|
||||||
|
|
||||||
- name: PKGNG | Uninstall xdebug
|
|
||||||
community.general.pkgng:
|
|
||||||
name: "{{ php_xdebug_package }}"
|
|
||||||
state: absent
|
|
||||||
when: ansible_os_family == 'FreeBSD'
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
; Start a new pool named '{{ item.name }}'.
|
; Start a new pool named '{{ item.pool_name }}'.
|
||||||
; the variable $pool can we used in any directive and will be replaced by the
|
; the variable $pool can we used in any directive and will be replaced by the
|
||||||
; pool name ('{{ item.name }}' here)
|
; pool name ('{{ item.pool_name }}' here)
|
||||||
[{{ item.name }}]
|
[{{ item.pool_name }}]
|
||||||
|
|
||||||
; Per pool prefix
|
; Per pool prefix
|
||||||
; It only applies on the following directives:
|
; It only applies on the following directives:
|
||||||
|
@ -20,8 +20,8 @@
|
||||||
; Unix user/group of processes
|
; Unix user/group of processes
|
||||||
; Note: The user is mandatory. If the group is not set, the default user's group
|
; Note: The user is mandatory. If the group is not set, the default user's group
|
||||||
; will be used.
|
; will be used.
|
||||||
user = {{ item.user }}
|
user = {{ item.user | default(php_default_user_group) }}
|
||||||
group = {{ item.group }}
|
group = {{ item.group | default(php_default_user_group) }}
|
||||||
|
|
||||||
; The address on which to accept FastCGI requests.
|
; The address on which to accept FastCGI requests.
|
||||||
; Valid syntaxes are:
|
; Valid syntaxes are:
|
||||||
|
@ -95,7 +95,7 @@ listen.group = {{ item.listen_owner | default(php_default_user_group) }}
|
||||||
; pm.process_idle_timeout - The number of seconds after which
|
; pm.process_idle_timeout - The number of seconds after which
|
||||||
; an idle process will be killed.
|
; an idle process will be killed.
|
||||||
; Note: This value is mandatory.
|
; Note: This value is mandatory.
|
||||||
pm = {{ item.pm | default('dynamic') }}
|
pm = {{ item.pm }}
|
||||||
|
|
||||||
; The number of child processes to be created when pm is set to 'static' and the
|
; The number of child processes to be created when pm is set to 'static' and the
|
||||||
; maximum number of child processes when pm is set to 'dynamic' or 'ondemand'.
|
; maximum number of child processes when pm is set to 'dynamic' or 'ondemand'.
|
||||||
|
@ -106,33 +106,33 @@ pm = {{ item.pm | default('dynamic') }}
|
||||||
; forget to tweak pm.* to fit your needs.
|
; forget to tweak pm.* to fit your needs.
|
||||||
; Note: Used when pm is set to 'static', 'dynamic' or 'ondemand'
|
; Note: Used when pm is set to 'static', 'dynamic' or 'ondemand'
|
||||||
; Note: This value is mandatory.
|
; Note: This value is mandatory.
|
||||||
pm.max_children = {{ item.pm_max_children | default('250') }}
|
pm.max_children = {{ item.pm_max_children }}
|
||||||
|
|
||||||
; The number of child processes created on startup.
|
; The number of child processes created on startup.
|
||||||
; Note: Used only when pm is set to 'dynamic'
|
; Note: Used only when pm is set to 'dynamic'
|
||||||
; Default Value: min_spare_servers + (max_spare_servers - min_spare_servers) / 2
|
; Default Value: min_spare_servers + (max_spare_servers - min_spare_servers) / 2
|
||||||
pm.start_servers = {{ item.pm_start_servers | default('10') }}
|
pm.start_servers = {{ item.pm_start_servers }}
|
||||||
|
|
||||||
; The desired minimum number of idle server processes.
|
; The desired minimum number of idle server processes.
|
||||||
; Note: Used only when pm is set to 'dynamic'
|
; Note: Used only when pm is set to 'dynamic'
|
||||||
; Note: Mandatory when pm is set to 'dynamic'
|
; Note: Mandatory when pm is set to 'dynamic'
|
||||||
pm.min_spare_servers = {{ item.pm_min_spare_servers | default('10') }}
|
pm.min_spare_servers = {{ item.pm_min_spare_servers }}
|
||||||
|
|
||||||
; The desired maximum number of idle server processes.
|
; The desired maximum number of idle server processes.
|
||||||
; Note: Used only when pm is set to 'dynamic'
|
; Note: Used only when pm is set to 'dynamic'
|
||||||
; Note: Mandatory when pm is set to 'dynamic'
|
; Note: Mandatory when pm is set to 'dynamic'
|
||||||
pm.max_spare_servers = {{ item.pm_max_spare_servers | default('20') }}
|
pm.max_spare_servers = {{ item.pm_max_spare_servers }}
|
||||||
|
|
||||||
; The number of seconds after which an idle process will be killed.
|
; The number of seconds after which an idle process will be killed.
|
||||||
; Note: Used only when pm is set to 'ondemand'
|
; Note: Used only when pm is set to 'ondemand'
|
||||||
; Default Value: 10s
|
; Default Value: 10s
|
||||||
pm.process_idle_timeout = {{ item.pm_process_idle_timeout | default('10s') }};
|
;pm.process_idle_timeout = 10s;
|
||||||
|
|
||||||
; The number of requests each child process should execute before respawning.
|
; The number of requests each child process should execute before respawning.
|
||||||
; This can be useful to work around memory leaks in 3rd party libraries. For
|
; This can be useful to work around memory leaks in 3rd party libraries. For
|
||||||
; endless request processing specify '0'. Equivalent to PHP_FCGI_MAX_REQUESTS.
|
; endless request processing specify '0'. Equivalent to PHP_FCGI_MAX_REQUESTS.
|
||||||
; Default Value: 0
|
; Default Value: 0
|
||||||
pm.max_requests = {{ item.pm_max_requests | default('0') }}
|
;pm.max_requests = 500
|
||||||
|
|
||||||
; The URI to view the FPM status page. If this value is not set, no URI will be
|
; The URI to view the FPM status page. If this value is not set, no URI will be
|
||||||
; recognized as a status page. It shows the following informations:
|
; recognized as a status page. It shows the following informations:
|
||||||
|
@ -369,7 +369,7 @@ chdir = /
|
||||||
; Note: on highloaded environement, this can cause some delay in the page
|
; Note: on highloaded environement, this can cause some delay in the page
|
||||||
; process time (several ms).
|
; process time (several ms).
|
||||||
; Default Value: no
|
; Default Value: no
|
||||||
catch_workers_output = {{ item.catch_workers_output | default('no') }}
|
;catch_workers_output = yes
|
||||||
|
|
||||||
; Clear environment in FPM workers
|
; Clear environment in FPM workers
|
||||||
; Prevents arbitrary environment variables from reaching FPM worker processes
|
; Prevents arbitrary environment variables from reaching FPM worker processes
|
||||||
|
@ -421,19 +421,5 @@ catch_workers_output = {{ item.catch_workers_output | default('no') }}
|
||||||
;php_admin_value[error_log] = /var/log/fpm-php.www.log
|
;php_admin_value[error_log] = /var/log/fpm-php.www.log
|
||||||
;php_admin_flag[log_errors] = on
|
;php_admin_flag[log_errors] = on
|
||||||
;php_admin_value[memory_limit] = 32M
|
;php_admin_value[memory_limit] = 32M
|
||||||
{% if item.php_env is defined %}
|
|
||||||
{% for k, v in item.php_env.items() | list %}
|
|
||||||
env[{{ k }}] = {{ v }}
|
|
||||||
{% endfor %}
|
|
||||||
{% endif %}
|
|
||||||
{% if item.php_value is defined %}
|
|
||||||
{% for k, v in item.php_value.items() | list %}
|
|
||||||
php_value[{{ k }}] = {{ v }}
|
|
||||||
{% endfor %}
|
|
||||||
{% endif %}
|
|
||||||
{% if item.php_admin_value is defined %}
|
|
||||||
{% for k, v in item.php_admin_value.items() | list %}
|
|
||||||
php_admin_value[{{ k }}] = {{ v }}
|
|
||||||
{% endfor %}
|
|
||||||
{% endif %}
|
|
||||||
; vim:filetype=dosini
|
; vim:filetype=dosini
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
---
|
---
|
||||||
|
|
||||||
- name: APT | Install Sury key
|
- name: APT | Install Sury key
|
||||||
ansible.builtin.apt_key:
|
apt_key:
|
||||||
url: 'https://packages.sury.org/php/apt.gpg'
|
url: 'https://packages.sury.org/php/apt.gpg'
|
||||||
|
|
||||||
- name: APT_REPOSITORY | Add Sury repository
|
- name: APT_REPOSITORY | Add Sury repository
|
||||||
ansible.builtin.apt_repository:
|
apt_repository:
|
||||||
repo: 'deb https://packages.sury.org/php/ {{ ansible_distribution_release }} main'
|
repo: 'deb https://packages.sury.org/php/ {{ ansible_distribution_release }} main'
|
||||||
|
|
|
@ -1,24 +1,24 @@
|
||||||
---
|
---
|
||||||
|
|
||||||
- name: SET_FACT | Prepare test vars
|
- name: SET_FACT | Prepare test vars
|
||||||
ansible.builtin.set_fact:
|
set_fact:
|
||||||
__nginx_conf: /etc/nginx/nginx.conf
|
__nginx_conf: /etc/nginx/nginx.conf
|
||||||
|
|
||||||
- name: APT | Install packages
|
- name: APT | Install packages
|
||||||
ansible.builtin.apt:
|
apt:
|
||||||
pkg: "{{ p }}"
|
pkg: "{{ p }}"
|
||||||
update_cache: true
|
update_cache: yes
|
||||||
cache_valid_time: 3600
|
cache_valid_time: 3600
|
||||||
vars:
|
vars:
|
||||||
p:
|
p:
|
||||||
- apt-transport-https
|
- apt-transport-https
|
||||||
- ca-certificates
|
- ca-certificates
|
||||||
- curl
|
- curl
|
||||||
- gpg
|
|
||||||
- lsb-release
|
- lsb-release
|
||||||
- nginx
|
- nginx
|
||||||
- vim
|
|
||||||
|
|
||||||
- name: INCLUDE_TASKS | Sury (only if a specific php_version is defined)
|
- name: INCLUDE_TASKS | Sury
|
||||||
ansible.builtin.include_tasks: Debian/sury.yml
|
include_tasks: Debian/sury.yml
|
||||||
when: php_version is defined
|
when:
|
||||||
|
(ansible_distribution_major_version is version('9', 'eq')) and
|
||||||
|
(php_version is version('7.1', 'ge'))
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
---
|
---
|
||||||
|
|
||||||
- name: SET_FACT | Prepare test vars
|
- name: SET_FACT | Prepare test vars
|
||||||
ansible.builtin.set_fact:
|
set_fact:
|
||||||
__nginx_conf: /usr/local/etc/nginx/nginx.conf
|
__nginx_conf: /usr/local/etc/nginx/nginx.conf
|
||||||
php_xdebug_package: 'php72-pecl-xdebug-2.6.1'
|
php_xdebug_package: 'php72-pecl-xdebug-2.6.1'
|
||||||
|
|
||||||
- name: PKGNG | Install packages
|
- name: PKGNG | Install packages
|
||||||
community.general.pkgng:
|
pkgng:
|
||||||
name: ['curl', 'nginx']
|
name: ['curl', 'nginx']
|
||||||
|
|
|
@ -2,7 +2,7 @@ events {
|
||||||
worker_connections 1024;
|
worker_connections 1024;
|
||||||
}
|
}
|
||||||
|
|
||||||
user root;
|
user {{ php_default_user_group }};
|
||||||
|
|
||||||
http {
|
http {
|
||||||
include mime.types;
|
include mime.types;
|
||||||
|
@ -15,27 +15,22 @@ http {
|
||||||
|
|
||||||
root /var/www;
|
root /var/www;
|
||||||
|
|
||||||
{% if ansible_local.hanxhx_php.fpm_pool.0.status_path is defined %}
|
{% if php_fpm_poold.0.status_path is defined %}
|
||||||
location = {{ ansible_local.hanxhx_php.fpm_pool.0.status_path }} {
|
location = {{ php_fpm_poold.0.status_path }} {
|
||||||
include fastcgi.conf;
|
include fastcgi.conf;
|
||||||
fastcgi_pass unix:{{ ansible_local.hanxhx_php.fpm_pool.0.listen }};
|
fastcgi_pass unix:{{ php_default_fpm_sock }};
|
||||||
}
|
}
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if ansible_local.hanxhx_php.fpm_pool.0.ping_path is defined %}
|
{% if php_fpm_poold.0.ping_path is defined %}
|
||||||
location = {{ ansible_local.hanxhx_php.fpm_pool.0.ping_path }} {
|
location = {{ php_fpm_poold.0.ping_path }} {
|
||||||
include fastcgi.conf;
|
include fastcgi.conf;
|
||||||
fastcgi_pass unix:{{ ansible_local.hanxhx_php.fpm_pool.0.listen }};
|
fastcgi_pass unix:{{ php_default_fpm_sock }};
|
||||||
}
|
}
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
location = /ini.php {
|
|
||||||
include fastcgi.conf;
|
|
||||||
fastcgi_pass unix:{{ ansible_local.hanxhx_php.fpm_pool.1.listen }};
|
|
||||||
}
|
|
||||||
|
|
||||||
location ~ \.php$ {
|
location ~ \.php$ {
|
||||||
include fastcgi.conf;
|
include fastcgi.conf;
|
||||||
fastcgi_pass unix:{{ ansible_local.hanxhx_php.fpm_pool.0.listen }};
|
fastcgi_pass unix:{{ php_default_fpm_sock }};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
138
tests/test.yml
138
tests/test.yml
|
@ -1,20 +1,18 @@
|
||||||
---
|
---
|
||||||
|
|
||||||
- hosts: all
|
- hosts: all
|
||||||
name: Test all
|
|
||||||
vars:
|
vars:
|
||||||
vhost: 'test.local'
|
vhost: 'test.local'
|
||||||
php_extra_packages:
|
php_extra_packages:
|
||||||
- '{{ php_package_prefix }}pgsql'
|
- '{{ php_package_prefix }}recode'
|
||||||
php_install_xdebug: true
|
php_install_xdebug: true
|
||||||
php_autoremove_default_pool: true
|
|
||||||
php_ini_fpm:
|
php_ini_fpm:
|
||||||
display_errors: 'Off'
|
display_errors: 'Off'
|
||||||
php_ini_cli:
|
php_ini_cli:
|
||||||
error_reporting: 'E_ALL'
|
error_reporting: 'E_ALL'
|
||||||
php_fpm_poold:
|
php_fpm_poold:
|
||||||
- pool_name: 'test_ansible'
|
- pool_name: 'test_ansible'
|
||||||
listen: '/run/php/php-ansible1.sock'
|
listen: '{{ php_default_fpm_sock }}'
|
||||||
pm: 'dynamic'
|
pm: 'dynamic'
|
||||||
pm_max_children: 250
|
pm_max_children: 250
|
||||||
pm_start_servers: 10
|
pm_start_servers: 10
|
||||||
|
@ -23,82 +21,70 @@
|
||||||
status_path: '/status'
|
status_path: '/status'
|
||||||
ping_path: '/ping'
|
ping_path: '/ping'
|
||||||
ping_response: 'ok'
|
ping_response: 'ok'
|
||||||
- name: 'test_ansible2'
|
|
||||||
user: 'foo'
|
|
||||||
php_env:
|
|
||||||
foo: bar
|
|
||||||
php_value:
|
|
||||||
display_errors: 'Off'
|
|
||||||
php_admin_value:
|
|
||||||
memory_limit: '98M'
|
|
||||||
|
|
||||||
pre_tasks:
|
pre_tasks:
|
||||||
|
|
||||||
- name: INCLUDE_TASKS | Pre tasks related to OS
|
- name: INCLUDE_TASKS | Pre tasks related to OS
|
||||||
ansible.builtin.include_tasks: "includes/pre_{{ ansible_os_family }}.yml"
|
include_tasks: "includes/pre_{{ ansible_os_family }}.yml"
|
||||||
|
|
||||||
- name: USER | Create PHP user
|
|
||||||
ansible.builtin.user:
|
|
||||||
name: 'foo'
|
|
||||||
system: true
|
|
||||||
create_home: false
|
|
||||||
shell: '/usr/sbin/nologin'
|
|
||||||
|
|
||||||
tasks:
|
tasks:
|
||||||
|
|
||||||
- name: TEMPLATE | Nginx site config
|
- name: TEMPLATE | Nginx site config
|
||||||
ansible.builtin.template:
|
template:
|
||||||
src: "templates/nginx.conf.j2"
|
src: "templates/nginx.conf.j2"
|
||||||
dest: "{{ __nginx_conf }}"
|
dest: "{{ __nginx_conf }}"
|
||||||
mode: 0644
|
notify: reload nginx
|
||||||
owner: root
|
|
||||||
group: root
|
|
||||||
notify: Reload nginx
|
|
||||||
|
|
||||||
- name: COMMAND | Fix nginx config
|
- name: COMMAND | Fix nginx config
|
||||||
ansible.builtin.command: "cp {{ __nginx_conf | dirname }}/fastcgi_params {{ __nginx_conf | dirname }}/fastcgi.conf"
|
command: "cp {{ __nginx_conf | dirname }}/fastcgi_params {{ __nginx_conf | dirname }}/fastcgi.conf"
|
||||||
args:
|
args:
|
||||||
creates: "{{ __nginx_conf | dirname }}/fastcgi.conf"
|
creates: "{{ __nginx_conf | dirname }}/fastcgi.conf"
|
||||||
notify: Reload nginx
|
notify: reload nginx
|
||||||
|
|
||||||
- name: LINEINFILE | Fix nginx config (second step)
|
- name: LINEINFILE | Fix nginx config (second step)
|
||||||
ansible.builtin.lineinfile:
|
lineinfile:
|
||||||
regexp: '^fastcgi_param\s+SCRIPT_FILENAME'
|
regexp: '^fastcgi_param\s+SCRIPT_FILENAME'
|
||||||
line: "fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;"
|
line: "fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;"
|
||||||
dest: "{{ __nginx_conf | dirname }}/fastcgi.conf"
|
dest: "{{ __nginx_conf | dirname }}/fastcgi.conf"
|
||||||
notify: Reload nginx
|
notify: reload nginx
|
||||||
|
|
||||||
- name: SERVICE | Ensure nginx is started
|
- name: SERVICE | Ensure nginx is started
|
||||||
ansible.builtin.service:
|
service:
|
||||||
name: nginx
|
name: nginx
|
||||||
state: started
|
state: started
|
||||||
when: ansible_virtualization_type != 'docker'
|
when: ansible_virtualization_type != 'docker'
|
||||||
|
|
||||||
- name: Start nginx if testing with Docker
|
- block:
|
||||||
|
|
||||||
|
- name: COMMAND | Docker nginx status
|
||||||
|
command: service nginx status
|
||||||
|
args:
|
||||||
|
warn: false
|
||||||
|
changed_when: false
|
||||||
|
failed_when: false
|
||||||
|
register: ngs
|
||||||
|
|
||||||
|
- name: COMMAND | Docker start nginx
|
||||||
|
command: service nginx start
|
||||||
|
args:
|
||||||
|
warn: false
|
||||||
|
when: ngs.stdout.find('nginx is not running') != -1
|
||||||
|
|
||||||
when: ansible_virtualization_type == 'docker'
|
when: ansible_virtualization_type == 'docker'
|
||||||
block:
|
|
||||||
|
|
||||||
- name: COMMAND | Docker nginx status # noqa: command-instead-of-module
|
|
||||||
ansible.builtin.command: service nginx status
|
|
||||||
changed_when: false
|
|
||||||
failed_when: false
|
|
||||||
register: ngs
|
|
||||||
|
|
||||||
- name: COMMAND | Docker start nginx # noqa: command-instead-of-module no-changed-when
|
|
||||||
ansible.builtin.command: service nginx start
|
|
||||||
when: ngs.stdout.find('nginx is not running') != -1
|
|
||||||
|
|
||||||
handlers:
|
handlers:
|
||||||
|
|
||||||
- name: Reload nginx
|
- name: reload nginx
|
||||||
ansible.builtin.service:
|
service:
|
||||||
name: nginx
|
name: nginx
|
||||||
state: reloaded
|
state: reloaded
|
||||||
notify: Docker reload nginx
|
notify: docker reload nginx
|
||||||
|
|
||||||
- name: Docker reload nginx # noqa: command-instead-of-module no-changed-when
|
- name: docker reload nginx
|
||||||
ansible.builtin.command: service nginx reload
|
command: service nginx reload
|
||||||
notify: Docker reload nginx
|
args:
|
||||||
|
warn: false
|
||||||
|
notify: docker reload nginx
|
||||||
when: ansible_virtualization_type == 'docker'
|
when: ansible_virtualization_type == 'docker'
|
||||||
|
|
||||||
roles:
|
roles:
|
||||||
|
@ -107,75 +93,35 @@
|
||||||
post_tasks:
|
post_tasks:
|
||||||
|
|
||||||
- name: SHELL | Test php-cli
|
- name: SHELL | Test php-cli
|
||||||
ansible.builtin.shell: set -o pipefail && php -i | grep '^PHP Version => {{ php_version }}' | head -n 1
|
shell: php -i | grep '^PHP Version => {{ php_version }}' | head -n 1
|
||||||
changed_when: false
|
changed_when: false
|
||||||
register: p
|
register: p
|
||||||
failed_when: p.stdout == ''
|
failed_when: p.stdout == ''
|
||||||
args:
|
|
||||||
executable: /bin/bash
|
|
||||||
|
|
||||||
- name: FILE | Create /var/www
|
- name: FILE | Create /var/www
|
||||||
ansible.builtin.file:
|
file:
|
||||||
dest: /var/www
|
dest: /var/www
|
||||||
state: directory
|
state: directory
|
||||||
owner: root
|
|
||||||
group: root
|
|
||||||
mode: 0755
|
|
||||||
|
|
||||||
- name: COPY | Add phpinfo
|
- name: COPY | Add phpinfo
|
||||||
ansible.builtin.copy:
|
copy:
|
||||||
dest: /var/www/phpinfo.php
|
dest: /var/www/phpinfo.php
|
||||||
content: '<?php phpinfo();'
|
content: '<?php phpinfo();'
|
||||||
owner: root
|
|
||||||
group: root
|
|
||||||
mode: 0644
|
|
||||||
|
|
||||||
- name: COPY | Add ini test file
|
|
||||||
ansible.builtin.copy:
|
|
||||||
dest: /var/www/ini.php
|
|
||||||
content: '<?php echo ini_get("memory_limit") . "\n";'
|
|
||||||
owner: root
|
|
||||||
group: root
|
|
||||||
mode: 0644
|
|
||||||
|
|
||||||
- name: SHELL | Check vhost
|
- name: SHELL | Check vhost
|
||||||
ansible.builtin.shell: "set -o pipefail && curl -v -H 'Host: {{ vhost }}' http://127.0.0.1/phpinfo.php 2> /dev/null | grep h1 | grep -o 'PHP Version {{ php_version }}' | sed -r 's/<//g'"
|
shell: "curl -v -H 'Host: {{ vhost }}' http://127.0.0.1/phpinfo.php 2> /dev/null | grep h1 | grep -o 'PHP Version {{ php_version }}' | sed -r 's/<//g'"
|
||||||
args:
|
args:
|
||||||
executable: /bin/bash
|
warn: false
|
||||||
changed_when: false
|
changed_when: false
|
||||||
register: c
|
register: c
|
||||||
failed_when: c.stdout == ''
|
failed_when: c.stdout == ''
|
||||||
|
|
||||||
- name: SHELL | Check custom php value # noqa: command-instead-of-module
|
|
||||||
ansible.builtin.shell: "curl -H 'Host: {{ vhost }}' http://127.0.0.1/ini.php 2> /dev/null"
|
|
||||||
changed_when: false
|
|
||||||
register: c
|
|
||||||
failed_when: 'php_fpm_poold.1.php_admin_value.memory_limit not in c.stdout'
|
|
||||||
|
|
||||||
- name: URI | Check ping
|
- name: URI | Check ping
|
||||||
ansible.builtin.uri:
|
uri:
|
||||||
url: "http://localhost{{ php_fpm_poold.0.ping_path }}"
|
url: "http://localhost{{ php_fpm_poold.0.ping_path }}"
|
||||||
when: php_fpm_poold.0.ping_path is defined
|
when: php_fpm_poold.0.ping_path is defined
|
||||||
|
|
||||||
- name: URI | Check status
|
- name: URI | Check status
|
||||||
ansible.builtin.uri:
|
uri:
|
||||||
url: "http://localhost{{ php_fpm_poold.0.status_path }}"
|
url: "http://localhost{{ php_fpm_poold.0.status_path }}"
|
||||||
when: php_fpm_poold.0.status_path is defined
|
when: php_fpm_poold.0.status_path is defined
|
||||||
|
|
||||||
- name: Debian extra checks
|
|
||||||
when: ansible_os_family == 'Debian'
|
|
||||||
block:
|
|
||||||
|
|
||||||
- name: SHELL | Check if we installed multiple PHP versions
|
|
||||||
ansible.builtin.shell: set -o pipefail && (dpkg -l | grep 'php[[:digit:]].*common' | wc -l)
|
|
||||||
args:
|
|
||||||
executable: /bin/bash
|
|
||||||
failed_when: false
|
|
||||||
changed_when: false
|
|
||||||
register: check_multiple_php
|
|
||||||
|
|
||||||
|
|
||||||
- name: FAIL | If we have multiple PHP version
|
|
||||||
ansible.builtin.fail:
|
|
||||||
msg: "Multiple PHP versions detected"
|
|
||||||
when: check_multiple_php.stdout != '1'
|
|
||||||
|
|
|
@ -1,3 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
php_default_version: '8.2'
|
|
|
@ -1,3 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
php_default_version: '7.4'
|
|
|
@ -1,3 +1 @@
|
||||||
---
|
|
||||||
|
|
||||||
php_default_version: '7.3'
|
php_default_version: '7.3'
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
php_default_version: '7.0'
|
|
@ -1,3 +1 @@
|
||||||
---
|
|
||||||
|
|
||||||
php_default_version: '7.2'
|
php_default_version: '7.2'
|
||||||
|
|
|
@ -1,3 +1 @@
|
||||||
---
|
|
||||||
|
|
||||||
php_default_version: '7.2'
|
php_default_version: '7.2'
|
||||||
|
|
|
@ -7,8 +7,7 @@ php_packages:
|
||||||
- '{{ php_package_prefix }}mysql'
|
- '{{ php_package_prefix }}mysql'
|
||||||
- '{{ php_package_prefix }}intl'
|
- '{{ php_package_prefix }}intl'
|
||||||
|
|
||||||
php_xdebug_package: '{% if multiple_php.rc == 0 %}{{ php_package_prefix }}{% else %}php-{% endif %}xdebug'
|
php_xdebug_package: 'php-xdebug'
|
||||||
php_apcu_package: '{% if multiple_php.rc == 0 %}{{ php_package_prefix }}{% else %}php-{% endif %}apcu'
|
|
||||||
|
|
||||||
php_package_prefix: 'php{{ php_version }}-'
|
php_package_prefix: 'php{{ php_version }}-'
|
||||||
|
|
||||||
|
|
|
@ -1,3 +1 @@
|
||||||
---
|
|
||||||
|
|
||||||
php_default_version: '7.2'
|
php_default_version: '7.2'
|
||||||
|
|
|
@ -1,3 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
php_default_version: '7.4'
|
|
|
@ -1,3 +0,0 @@
|
||||||
---
|
|
||||||
|
|
||||||
php_default_version: '8.1'
|
|
|
@ -1,3 +1 @@
|
||||||
---
|
|
||||||
|
|
||||||
php_default_version: '7.0'
|
php_default_version: '7.0'
|
||||||
|
|
Loading…
Reference in New Issue