- 
      
- 
        Save seriald/a4a78e6afe0cd6b44b0dfa78bf58fefe to your computer and use it in GitHub Desktop. 
    Intro to ansible tutorial playbook
  
        
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | --- | |
| - hosts: webservers | |
| tasks: | |
| - name: Install Apache | |
| apt: pkg=apache2 update_cache=true state=installed | |
| - name: Install bunch of php packages | |
| apt: pkg={{ item }} update_cache=true state=installed | |
| with_items: | |
| - php5 | |
| - php5-cli | |
| - php5-curl | |
| - php5-mcrypt | |
| - php5-mysql | |
| - php5-gd | |
| - name: Install MySQL Client | |
| apt: pkg=mysql-client update_cache=true state=installed | |
| - name: Checking if file already exists | |
| stat: path=/home/vagrant/wordpress-latest.zip | |
| register: wordpress_file | |
| - name: Download wordpress latest zip | |
| get_url: dest=/home/vagrant/wordpress-latest.zip url=https://wordpress.org/latest.zip | |
| when: wordpress_file.stat.exists != true | |
| - name: Install Unzip package | |
| apt: pkg=unzip update_cache=true state=installed | |
| - name: Deploying wordpress | |
| unarchive: | |
| src="/home/vagrant/wordpress-latest.zip" | |
| dest={{ wordpress_dest_path }} | |
| copy=no | |
| creates={{ wordpress_dest_path_checker }} | |
| owner=www-data | |
| group=www-data | |
| mode=755 | |
| sudo: true | |
| - hosts: dbservers | |
| tasks: | |
| - name: Install MySQL Components | |
| apt: pkg={{ item }} update_cache=true state=installed | |
| with_items: | |
| - mysql-client | |
| - mysql-server | |
| - python-mysqldb | |
| - name: delete anonymous mysql user | |
| mysql_user: name="" state=absent | |
| register: command_result | |
| ignore_errors: true | |
| - name: install Mysql Root user | |
| mysql_user: name=root host={{ item }} password={{ mysql_root_password }} login_user=root login_password= | |
| when: command_result|success | |
| with_items: | |
| - 127.0.0.1 | |
| - ::1 | |
| - localhost | |
| - name: install Mysql wordpress database | |
| mysql_db: name=wp_db state=present login_user=root login_password={{ mysql_root_password }} | |
| - name: install Mysql wordpress user | |
| mysql_user: name=wp_user priv=wp_db.*:ALL host={{ item }} password={{ mysql_wp_password }} login_user=root login_password={{ mysql_root_password }} | |
| with_items: | |
| - localhost | |
| - 172.24.14.100 | |
| - name: Openning our Mysql to the world | |
| replace: | |
| dest=/etc/mysql/my.cnf | |
| regexp="^bind-address.*" | |
| replace="#bind-address= 127.0.0.1" | |
| backup=yes | |
| notify: | |
| - Restart_Mysql | |
| vars_prompt: | |
| - name: "mysql_root_password" | |
| prompt: "Please enter the root password" | |
| private: yes | |
| handlers: | |
| - name: Restart_Mysql | |
| service: name=mysql state=restarted | |
| sudo: true | 
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment