Use Salt States to Configure a LAMP Stack on a Minion
Updated by Linode Written by Linode
This tutorial will configure a Minion’s LAMP stack with further use of Salt States. This tutorial is written for Debian 8 but can easily be adjusted for other Linux Distributions. You will need a working Salt master and minion configuration before starting this guide. If you need to set up that prerequisite, see our Salt installation guide to get started.
Create the LAMP Configuration States
The steps below configure all Salt Minions for a 2GB Linode, feel free to adjust as needed.
- Open the - /etc/salt/base/top.slsfile and add the additional line:- /etc/salt/base/top.sls
- 
1 2 3 4 5base: '*': - lamp - extras - lampconf
 
- Create and edit the - /etc/salt/base/lampconf.slsfile:- /etc/salt/base/lampconf.sls
- 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79#Apache Conguration for 2GB Linode /etc/apache2/apache2.conf-KA: file.replace: - name: /etc/apache2/apache2.conf - pattern: 'KeepAlive On' - repl: 'KeepAlive Off' - show_changes: True /etc/apache2/apache2.conf-IM: file.append: - name: /etc/apache2/apache2.conf - text: | <IfModule mpm_prefork_module> StartServers 4 MinSpareServers 20 MaxSpareServers 40 MaxClients 200 MaxRequestsPerChild 4500 </IfModule> # MySQL Configuration for 2GB Linode /etc/mysql/my.cnf-br: file.blockreplace: - name: /etc/mysql/my.cnf - marker_start: '# * Fine Tuning' - marker_end: '# * Query Cache Configuration' - content: | # key_buffer = 32M max_allowed_packet = 1M thread_stack = 128K thread_cache_size = 8 # This replaces the startup script and checks MyISAM tables if # needed the first time they are touched myisam-recover = BACKUP max_connections = 75 table_cache = 32 #thread_concurrency = 10 # - backup: '.bak' - show_changes: True # PHP Configuration for 2GB Linode /etc/php5/apache2/php.ini-er: file.replace: - name: /etc/php5/apache2/php.ini - pattern: 'error_reporting = E_ALL & ~E_DEPRECATED & ~E_STRICT' - repl: 'error_reporting = E_COMPILE_ERROR|E_RECOVERABLE_ERROR|E_ERROR|E_CORE_ERROR' - show_changes: True /etc/php5/apache2/php.ini-el: file.replace: - name: /etc/php5/apache2/php.ini - pattern: ';error_log = php_errors.log' - repl: 'error_log = /var/log/php/error.log' - show_changes: True /var/log/php/error.log: file.managed: - user: www-data - group: root - dir_mode: 755 - file_mode: 644 - makedirs: True # Restart apache2-run-at-boot-restart: service.running: - name: apache2 - enable: True - watch: - pkg: apache2 mysql-run-at-boot-restart: service.running: - name: mysql - enable: True - watch: - pkg: mysql-server
 - The above file uses the file and service Salt State modules. 
- Transfer the State settings to the Minions: - salt '*' state.highstate
Create Virtual Hosts Files
Salt State Modules are used for settings across groups of Minions. To adjust a configuration on a single Minion, try using Salt Execution Modules. Note, there are many ways to use Salt.
- Disable the default Apache virtual host on either a single Minion or all Minions: - For a specific Minion: - salt '<hostname or Minion ID>' cmd.run "a2dissite *default"- For all Minions: - salt '*' cmd.run "a2dissite *default"
- Create directories for the website’s files, logs, and backups. Replace - example.comwith the name of the website:- salt '<hostname or Minion ID>' file.makedirs /var/www/example.com/pubic_html/ salt '<hostname or Minion ID>' file.makedirs /var/www/example.com/log/ salt '<hostname or Minion ID>' file.makedirs /var/www/example.com/backups/
- Create a directory on the Master to hold all of the Minion virtual host files. This directory can act as an index for all of the Minion websites. - mkdir /etc/salt/base/minionsites
- Create the - /etc/salt/base/minionsites/example.com.confvhost file for the specified Minion. Replace- example.comthroughout and in the following commands.- /etc/salt/base/minionsites/example.com.conf
- 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17# domain: example.com # public: /var/www/example.com/public_html/ <VirtualHost *:80> # Admin email, Server Name (domain name), and any aliases ServerAdmin webmaster@example.com ServerName www.example.com ServerAlias example.com # Index file and Document Root (where the public files are located) DirectoryIndex index.html index.php DocumentRoot /var/www/example.com/public_html # Log file locations LogLevel warn ErrorLog /var/www/example.com/log/error.log CustomLog /var/www/example.com/log/access.log combined </VirtualHost>
 
- Copy the vhost file from the Master to the - /sites-availabledirectory of the Minion:- salt-cp '<hostname or Minion ID>' /etc/salt/base/minionsites/example.com.conf /etc/apache2/sites-available/example.com.conf
- Enable the new website and restart Apache: - salt '<hostname or Minion ID>' cmd.run "a2ensite example.com.conf" salt '<hostname or Minion ID>' cmd.run "service apache2 reload"
The above section used the cmdmod, file, and cp Salt Execution modules.
You should now have a configured LAMP stack across as many Minions as you wanted. Optionally, use grains for further customization and to apply specific variables to each host.
Join our Community
Find answers, ask questions, and help others.
This guide is published under a CC BY-ND 4.0 license.