1. 程式人生 > >詳解Ansible(Roles)自動化部署配置LAMP架構

詳解Ansible(Roles)自動化部署配置LAMP架構

守護進程 ted rip images rabbitmq abc sha bdc efault

  • Roles簡介
    Ansible為了層次化、結構化地組織Playbook,使用了角色(roles)。Roles能夠根據層次型結構自動裝載變量文件、task以及handlers等。簡單來講,roles就是通過分別將變量、文件、任務、模塊及處理器放置於單獨的目錄中,並可以便捷地include它們,roles一般用於基於主機構建服務的場景中,但也可以用於構建守護進程等場景中。
    ?

  • 創建Roles
    創建roles時一般需要以下步驟:首先創建以roles命名的目錄。然後在roles目標下分別創建以個角色名稱命令的目錄,如websevers等,在每個角色命令的目錄中分別創建files、handlers、tasks、templates、meta、defaults和vars目錄,用不到的目錄可以創建為空目錄。最後在Playbook文件中調用各角色進行使用

  • roles內各目錄含義解釋
  • files:用來存放由copy模塊或script模塊調用的文件。
    templates:用來存放jinjia2模板,template模塊會自動在此目錄中尋找jinjia2模板文件。
    tasks:此目錄應當包含一個main.yml文件,用於定義此角色的任務列表,此文件可以使用include包含其它的位於此目錄的task文件。
    handlers:此目錄應當包含一個main.yml文件,用於定義此角色中觸發條件時執行的動作。
    vars:此目錄應當包含一個main.yml文件,用於定義此角色用到的變量。
    defaults:此目錄應當包含一個main.yml文件,用於為當前角色設定默認變量。

    meta:此目錄應當包含一個main.yml文件,用於定義此角色的特殊設定及其依賴關系。

    • 案例:使用roles安裝LAMP架構
    • 1:創建httpd、mysql、php角色名稱目錄,並在其目錄下創建files、handlers、tasks、templates、meta、defaults和vars目錄

      # mkdir /etc/ansible/roles/httpd/{files,templates,tasks,handlers,vars,defaults,meta} -p
      # mkdir /etc/ansible/roles/mysql/{files,templates,tasks,handlers,vars,defaults,meta} -p
      # mkdir /etc/ansible/roles/php/{files,templates,tasks,handlers,vars,defaults,meta} -p
      
      # touch /etc/ansible/roles/httpd/{defaults,vars,tasks,meta,handlers}/main.yml
      # touch /etc/ansible/roles/mysql/{defaults,vars,tasks,meta,handlers}/main.yml
      # touch /etc/ansible/roles/php/{defaults,vars,tasks,meta,handlers}/main.yml
    • 編寫httpd模塊
    • 安裝httpd服務
    • 修改httpd.conf配置文件

      # vim /etc/ansible/roles/httpd/tasks/main.yml
          - name: ensure apache is at the latest version 
            yum: pkg={{ servicenames}} state=latest
            template: src=/etc/ansible/templates/httpd.conf.j2 dest=/etc/httpd/conf/httpd.conf
          - name: restart httpd server
            service: name=httpd enabled=true state=restarted
    • 定義變量

      # vim /etc/ansible/roles/httpd/vars/main.yml
      # servicenames: httpd
    • 編寫mysql模塊
    • 並且定義變量

      # vi /etc/ansible/roles/mysql/tasks/main.yml
      - name: ensure mysql is at the latest version 
        yum: pkg={{ servicenames}} state=latest
      
      # vi /etc/ansible/roles/mysql/vars/main.yml
      servicenames: mariadb*
    • 編寫php模塊
    • 並且定義變量

      # vi /etc/ansible/roles/php/tasks/main.yml
      - name: ensure php is at the latest version
        yum: pkg={{ servicenames}} state=latest
      
      # vi /etc/ansible/roles/php/vars/main.yml
      servicenames: php
    • 修改httpd配置文件模板
    • 監聽IP 和域名 設為變量 方便其他主機使用這個模塊

    技術分享圖片技術分享圖片技術分享圖片技術分享圖片

    • 在/etc/ansible/hosts文件中設置變量
      技術分享圖片

    • 創建Playbook文件調用上面各角色安裝LAMP

      [root@rabbitmq01 ansible# vim /etc/ansible/site.yml
      ---
      - hosts: abc
          remote_user: root
          roles:
           - httpd
           - mysql
           - php
      
      [root@rabbitmq01 ansible]# ansible-playbook site.yml --syntax-check  //檢測語法
      
      playbook: site.yml
      [root@rabbitmq01 ansible]# ansible-playbook site.yml    //執行劇本

      技術分享圖片

    ?

    • 測試驗證
    • 去192.168.200.129主機上寫一個PHP測試頁面

      # echo "<?php phpinfo();?>" > /var/www/html/index.php
      # systemctl restart httpd
    • 打開瀏覽器輸入192.168.200.129/index.php

    技術分享圖片

    詳解Ansible(Roles)自動化部署配置LAMP架構