saltsack自动化配置day02:之配置管理-LAMP自动化部署

一、基础知识

1、声明id

之前提到过saltstack的脚本是使用YAML格式来渲染的,YAML是python中指代字典类型数据结构的结构序列化格式,基本上的结构就是键值对的形式,需要注意的是SLS文件中每个小节的key称为ID,这个ID必须全局唯一不然会出现错误。

在一个总的id下面,一个模块只能用一次

2、声明name

当你没有设置name声明的时候,id就是name

3、有name和没有那么的区别

1、有name

apache-config:
  file.managed:
    - name: /etc/httpd/conf/httpd.conf
    - source: salt://apache/files/httpd.conf
    - user: root
    - group: root
    - mode: 644
	
php-config:
  file.managed:
    - name: /etc/httpd/conf/php.ini:
    - source: salt://web/files/php.ini
    - user: root
    - group: root
    - mode: 644

2、没有name

/etc/httpd/conf/httpd.conf:
  file.managed: 
    - source: salt://web/files/httpd.conf
    - user: root
    - group: root
    - mode: 644

/etc/httpd/conf/php.ini:
  file.managed: 
    - source: salt://web/files/php.ini
    - user: root
    - group: root
    - mode: 644

4、多个文件的2种写法

1、第一种写法

/etc/httpd/conf/httpd.conf:
  file.managed: 
    - source: salt://web/files/httpd.conf
    - user: root
    - group: root
    - mode: 644

/etc/httpd/conf/php.ini:
  file.managed: 
    - source: salt://web/files/php.ini
    - user: root
    - group: root
    - mode: 644

2、第二种写法(对于文件推荐写法)

apache-config:
  file.managed:
    - name: /etc/httpd/conf/httpd.conf
    - source: salt://apache/files/httpd.conf
    - user: root
    - group: root
    - mode: 644
	
php-config:
  file.managed:
    - name: /etc/httpd/conf/php.ini:
    - source: salt://web/files/php.ini
    - user: root
    - group: root
    - mode: 644
	

5、各自的优缺点

第二种写法:

依赖的时候id名很短,好记忆

第一种写法:

很清晰,看到文件就知道是那个文件

二. 部署思路

1. 将lamp分成3部分:软件包、配置文件、服务; 
2. 确认安装的软件包名、配置文件路径、服务名等; 
3. 按以上信息编写yaml文件;

三. 编写lamp.sls

[root@salt-master salt]# pwd
/srv/salt
[root@salt-master salt]# ls
dev  init  prod  test  top.sls
[root@salt-master salt]# cat dev/lamp.sls 
lamp-pkg-install:
  pkg.installed:
    - names:
      - httpd
      - php
      - php-fpm
      - mysql
      - mysql-server
      - php-mysql
      - php-pdo

apache-service:
  file.managed:
    - name: /etc/httpd/conf/httpd.conf
    - source:
      - salt://dev/files/httpd.conf
    - user: root
    - group: root
    - mode: 644
  service.running:
    - name: httpd
    - enable: True

mysql-service:
  file.managed:
    - name: /etc/my.cnf
    - source:
      - salt://dev/files/my.cnf
    - user: root
    - group: root
    - mode: 644
  service.running:
    - name: mysqld
    - enable: True

php-fpm-service:
  service.running:
    - name: php-fpm
    - enable: True
[root@salt-master salt]# cat top.sls 
base:
  '*':
    - init.dns

dev:
  'node*.test.com':
  - lamp
[root@salt-master salt]# ls dev/
files  lamp.sls
[root@salt-master salt]# ls dev/files/
httpd.conf  my.cnf
[root@salt-master salt]# 

执行salt '*' state.highstate查看结果:

 [root@salt-master salt]# salt-key -L
Accepted Keys:
master.test.com
node1.test.com
node2.test.com
Denied Keys:
Unaccepted Keys:
Rejected Keys:
[root@salt-master salt]# salt '*' state.highstate
master.test.com:
----------
          ID: /etc/resolv.conf
    Function: file.managed
      Result: True
     Comment: File /etc/resolv.conf is in the correct state
     Started: 23:20:50.495770
    Duration: 23.706 ms
     Changes:   

Summary for master.test.com
------------
Succeeded: 1
Failed:    0
------------
Total states run:     1
Total run time:  23.706 ms
node1.test.com:
----------
          ID: /etc/resolv.conf
    Function: file.managed
      Result: True
     Comment: File /etc/resolv.conf is in the correct state
     Started: 15:23:33.990342
    Duration: 32.918 ms
     Changes:   
----------
          ID: lamp-pkg-install
    Function: pkg.installed
        Name: httpd
      Result: True
     Comment: Package httpd is already installed
     Started: 15:23:34.603609
    Duration: 649.913 ms
     Changes:   
----------
          ID: lamp-pkg-install
    Function: pkg.installed
        Name: php-pdo
      Result: True
     Comment: Package php-pdo is already installed
     Started: 15:23:35.253716
    Duration: 0.539 ms
     Changes:   
----------
          ID: lamp-pkg-install
    Function: pkg.installed
        Name: php-fpm
      Result: True
     Comment: Package php-fpm is already installed
     Started: 15:23:35.254347
    Duration: 0.359 ms
     Changes:   
----------
          ID: lamp-pkg-install
    Function: pkg.installed
        Name: mysql-server
      Result: True
     Comment: Package mysql-server is already installed
     Started: 15:23:35.254807
    Duration: 0.346 ms
     Changes:   
----------
          ID: lamp-pkg-install
    Function: pkg.installed
        Name: php-mysql
      Result: True
     Comment: Package php-mysql is already installed
     Started: 15:23:35.255233
    Duration: 0.367 ms
     Changes:   
----------
          ID: lamp-pkg-install
    Function: pkg.installed
        Name: mysql
      Result: True
     Comment: Package mysql is already installed
     Started: 15:23:35.255688
    Duration: 0.355 ms
     Changes:   
----------
          ID: lamp-pkg-install
    Function: pkg.installed
        Name: php
      Result: True
     Comment: Package php is already installed
     Started: 15:23:35.256129
    Duration: 0.348 ms
     Changes:   
----------
          ID: apache-service
    Function: file.managed
        Name: /etc/httpd/conf/httpd.conf
      Result: False
     Comment: Unable to manage file: none of the specified sources were found
     Started: 15:23:35.256569
    Duration: 6.275 ms
     Changes:   
----------
          ID: apache-service
    Function: service.running
        Name: httpd
      Result: False
     Comment: Service httpd has been enabled, and is dead
     Started: 15:23:35.275736
    Duration: 230.013 ms
     Changes:   
              ----------
              httpd:
                  True
----------
          ID: mysql-service
    Function: file.managed
        Name: /etc/my.cnf
      Result: False
     Comment: Unable to manage file: none of the specified sources were found
     Started: 15:23:35.505956
    Duration: 6.35 ms
     Changes:   
----------
          ID: mysql-service
    Function: service.running
        Name: httpd
      Result: False
     Comment: Service httpd is already enabled, and is dead
     Started: 15:23:35.512412
    Duration: 134.002 ms
     Changes:   
----------
          ID: php-fpm-service
    Function: service.running
        Name: php-fpm
      Result: True
     Comment: Service php-fpm is already enabled, and is running
     Started: 15:23:35.646635
    Duration: 196.639 ms
     Changes:   
              ----------
              php-fpm:
                  True

Summary for node1.test.com
------------
Succeeded: 9 (changed=2)
Failed:    4
------------
Total states run:    13
Total run time:   1.258 s

node2.test.com:
----------
          ID: /etc/resolv.conf
    Function: file.managed
      Result: True
     Comment: File /etc/resolv.conf is in the correct state
     Started: 15:23:34.682679
    Duration: 103.617 ms
     Changes:   
----------
          ID: lamp-pkg-install
    Function: pkg.installed
        Name: httpd
      Result: True
     Comment: The following packages were installed/updated: httpd
     Started: 15:23:38.021487
    Duration: 46521.648 ms
     Changes:   
              ----------
              apr:
                  ----------
                  new:
                      1.3.9-5.el6_2
                  old:
              apr-util:
                  ----------
                  new:
                      1.3.9-3.el6_0.1
                  old:
              apr-util-ldap:
                  ----------
                  new:
                      1.3.9-3.el6_0.1
                  old:
              httpd:
                  ----------
                  new:
                      2.2.15-59.el6.centos
                  old:
              httpd-tools:
                  ----------
                  new:
                      2.2.15-59.el6.centos
                  old:
              mailcap:
                  ----------
                  new:
                      2.1.31-2.el6
                  old:
----------
          ID: lamp-pkg-install
    Function: pkg.installed
        Name: php-pdo
      Result: True
     Comment: The following packages were installed/updated: php-pdo
     Started: 15:24:24.562565
    Duration: 8749.133 ms
     Changes:   
              ----------
              php-common:
                  ----------
                  new:
                      5.3.3-49.el6
                  old:
              php-pdo:
                  ----------
                  new:
                      5.3.3-49.el6
                  old:
----------
          ID: lamp-pkg-install
    Function: pkg.installed
        Name: php-fpm
      Result: True
     Comment: The following packages were installed/updated: php-fpm
     Started: 15:24:33.336866
    Duration: 8477.529 ms
     Changes:   
              ----------
              php-fpm:
                  ----------
                  new:
                      5.3.3-49.el6
                  old:
----------
          ID: lamp-pkg-install
    Function: pkg.installed
        Name: mysql-server
      Result: True
     Comment: The following packages were installed/updated: mysql-server
     Started: 15:24:41.843441
    Duration: 28414.553 ms
     Changes:   
              ----------
              mysql:
                  ----------
                  new:
                      5.1.73-8.el6_8
                  old:
              mysql-libs:
                  ----------
                  new:
                      5.1.73-8.el6_8
                  old:
              mysql-server:
                  ----------
                  new:
                      5.1.73-8.el6_8
                  old:
              perl-DBD-MySQL:
                  ----------
                  new:
                      4.013-3.el6
                  old:
              perl-DBI:
                  ----------
                  new:
                      1.609-4.el6
                  old:
----------
          ID: lamp-pkg-install
    Function: pkg.installed
        Name: php-mysql
      Result: True
     Comment: The following packages were installed/updated: php-mysql
     Started: 15:25:10.289755
    Duration: 8122.46 ms
     Changes:   
              ----------
              php-mysql:
                  ----------
                  new:
                      5.3.3-49.el6
                  old:
----------
          ID: lamp-pkg-install
    Function: pkg.installed
        Name: mysql
      Result: True
     Comment: Package mysql is already installed
     Started: 15:25:18.458202
    Duration: 1.519 ms
     Changes:   
----------
          ID: lamp-pkg-install
    Function: pkg.installed
        Name: php
      Result: True
     Comment: The following packages were installed/updated: php
     Started: 15:25:18.459996
    Duration: 14374.708 ms
     Changes:   
              ----------
              php:
                  ----------
                  new:
                      5.3.3-49.el6
                  old:
              php-cli:
                  ----------
                  new:
                      5.3.3-49.el6
                  old:
----------
          ID: apache-service
    Function: file.managed
        Name: /etc/httpd/conf/httpd.conf
      Result: False
     Comment: Unable to manage file: none of the specified sources were found
     Started: 15:25:32.846614
    Duration: 38.9 ms
     Changes:   
----------
          ID: apache-service
    Function: service.running
        Name: httpd
      Result: False
     Comment: Service httpd has been enabled, and is dead
     Started: 15:25:32.916084
    Duration: 674.943 ms
     Changes:   
              ----------
              httpd:
                  True
----------
          ID: mysql-service
    Function: file.managed
        Name: /etc/my.cnf
      Result: False
     Comment: Unable to manage file: none of the specified sources were found
     Started: 15:25:33.591498
    Duration: 23.162 ms
     Changes:   
----------
          ID: mysql-service
    Function: service.running
        Name: httpd
      Result: False
     Comment: Service httpd is already enabled, and is dead
     Started: 15:25:33.614954
    Duration: 357.977 ms
     Changes:   
----------
          ID: php-fpm-service
    Function: service.running
        Name: php-fpm
      Result: True
     Comment: Service php-fpm is already enabled, and is running
     Started: 15:25:33.973402
    Duration: 512.95 ms
     Changes:   
              ----------
              php-fpm:
                  True

Summary for node2.test.com
------------
Succeeded: 9 (changed=8)
Failed:    4
------------
Total states run:    13
Total run time: 116.373 s
ERROR: Minions returned with non-zero exit code
[root@salt-master salt]# 

  

posted @ 2018-09-05 15:07  活的潇洒80  阅读(160)  评论(0编辑  收藏  举报