Saltstack 部署Zabbix监控服务

1. 项目框架

[root@master ~]# tree  /srv/
/srv/
└── salt
    ├── base
    ├── dev
    ├── prod
    │   ├── modules
    │   │   ├── application
    │   │   │   └── php   
    │   │   │       ├── files
    │   │   │       │   ├── index.php
    │   │   │       │   ├── install.sh  
    │   │   │       │   ├── oniguruma-devel-6.8.2-2.el8.x86_64.rpm
    │   │   │       │   ├── php-7.4.25.tar.gz
    │   │   │       │   ├── php-fpm
    │   │   │       │   ├── php-fpm.conf
    │   │   │       │   ├── php-fpm.service
    │   │   │       │   └── www.conf
    │   │   │       └── install.sls
    │   │   ├── database
    │   │   │   └── mysql
    │   │   │       ├── files
    │   │   │       │   ├── install.sh
    │   │   │       │   ├── mysql-5.7.35-linux-glibc2.12-x86_64.tar.gz
    │   │   │       │   ├── mysqld.service
    │   │   │       │   └── mysql.server
    │   │   │       └── install.sls
    │   │   └── web
    │   │       └── httpd
    │   │           ├── files
    │   │           │   ├── apr-1.7.0.tar.gz
    │   │           │   ├── apr-util-1.6.1.tar.gz
    │   │           │   ├── httpd-2.4.51.tar.gz
    │   │           │   ├── httpd.conf
    │   │           │   ├── httpd.service
    │   │           │   └── install.sh
    │   │           └── install.sls
    │   └── zabbix
    │       ├── apache.sls
    │       ├── files
    │       │   ├── index.php
    │       │   ├── install.sh
    │       │   ├── my.cnf
    │       │   ├── mysql.conf
    │       │   ├── php.ini
    │       │   ├── vhosts.conf
    │       │   ├── zabbix-5.4.4.tar.gz
    │       │   └── zabbix_server.conf
    │       ├── install.sls
    │       ├── main.sls
    │       └── mysql.sls
    └── test

17 directories, 33 files

1.1 编写httpd状态文件

[root@master httpd]# cat install.sls 
"Development Tools":
  pkg.group_installed
httpd-packages:
  pkg.installed:
    - pkgs:
      - openssl-devel
      - pcre-devel
      - expat-devel
      - libtool
      - gcc
      - gcc-c++
      - make
create-user:
  user.present:
    - name: apache
    - createhome: false
    - shell: /sbin/nologin
    - system: true

apache-download:
  file.managed:
    - names:
      - /usr/src/apr-1.7.0.tar.gz:
        - source: salt://modules/web/apache/files/apr-1.7.0.tar.gz
      - /usr/src/apr-util-1.6.1.tar.gz:
        - source: salt://modules/web/apache/files/apr-util-1.6.1.tar.gz
      - /usr/src/httpd-2.4.51.tar.gz:
        - source: salt://modules/web/apache/files/httpd-2.4.51.tar.gz
      - /usr/lib/systemd/system/httpd.service:
        - source: salt://modules/web/apache/files/httpd.service
        - user: root
        - group: root
        - mode: '0644'

salt://modules/web/apache/files/install.sh:
  cmd.script 

/usr/local/apache/conf/httpd.conf:
  file.managed:
    - source: salt://modules/web/apache/files/httpd.conf
    - user: root
    - group: root
    - mode: '0644' 

安装脚本

#!/bin/bash
cd /usr/src
rm -rf apr-1.7.0 apr-util-1.6.1 httpd-2.4.51
tar xf apr-1.7.0.tar.gz
tar xf apr-util-1.6.1.tar.gz
tar xf httpd-2.4.51.tar.gz
cd apr-1.7.0
sed -i '/$RM "$cfgfile"/d' /usr/src/apr-1.7.0/configure
./configure --prefix=/usr/local/apr && \
        make && make install && \
cd ../apr-util-1.6.1
./configure --prefix=/usr/local/apr-util --with=/usr/local/apr && \
        make && make install && \
cd ../httpd-2.4.51
./configure --prefix=/usr/local/apache \
                --sysconfdir=/etc/httpd24 \
                --enable-so \
                --enable-ssl \
                --enable-cgi \
                --enable-rewrite \
                --with-zlib \
                --with-pcre \
                --with-apr=/usr/local/apr \
                --with-apr-util=/usr/local/apr-util/ \
                --enable-modules=most \
                --enable-mpms-shared=all \
                --with-mpm=prefork && \
                make && make install
sed -i '/#ServerName/s/#//g' /usr/local/apache/conf/httpd.conf

配置文件修改

# probably should define those extensions to indicate media types:
#
  AddType application/x-compress .Z
  AddType application/x-gzip .gz .tgz
  AddType application/x-httpd-php .php  #添加这行
  AddType application/x-httpd-php-source .phps 添加这行

# AddHandler allows you to map certain file extensions to "handlers":

#取消下列两行的注释
LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so


#搜索index.html这一行添加index.php
<IfModule dir_module>
    DirectoryIndex index.php   index.html
</IfModule>


#取消下列一行的注释,并修改自定义路径
# Virtual hosts
Include conf/extra/vhosts.conf

service启动文件

[root@master ~]# cat /srv/salt/prod/modules/web/apache/files/httpd.service 
[Unit]
Description=Apache server daemon
After=network.target

[Service]
Type=forking
ExecStart=/usr/local/apache/bin/apachectl start
ExecStop=/usr/local/apache/bin/apachectl stop

[Install]
WantedBy=multi-user.target

1.2 Mysql服务安装状态文件

[root@master ~]# cat /srv/salt/prod/modules/database/mysql/install.sls 
mysql-dep-package:
  pkg.installed:
    - name: ncurses-compat-libs


create-mysql-user:
  user.present:
    - name: mysql
    - system: true
    - createhome: false
    - shell: /sbin/nologin

create-datadir:
  file.directory:
    - name: {
    
    {
    
     pillar['data_dir'] }}
    - user: mysql
    - group: mysql
    - mode: '0755'
    - makedirs: true


/usr/src/mysql-5.7.35-linux-glibc2.12-x86_64.tar.gz:
  file.managed:
    - source: salt://modules/database/mysql/files/mysql-5.7.35-linux-glibc2.12-x86_64.tar.gz
    - user: root
    - group: root
    - mode: '0644'

mysql-install:
  cmd.script:
    - name: salt://modules/database/mysql/files/install.sh    
    - unless:  test -d {
    
    {
    
     pillar['base_dir'] }}

trasfer-files:
  file.managed:
  - names: 
    - {
    
    {
    
     pillar['base_dir'] }}/support-files/mysql.server:
      - source: salt://modules/database/mysql/files/mysql.server
    - /usr/lib/systemd/system/mysqld.service:
      - source: salt://modules/database/mysql/files/mysqld.service.j2
      - template: jinja 
  - require: 
    - cmd: mysql-install

mysql安装脚本

#!/bin/bash
cd /usr/src
tar -xf  mysql-5.7.35-linux-glibc2.12-x86_64.tar.gz -C  /usr/local
ln -s /usr/local/mysql-5.7.35-linux-glibc2.12-x86_64 /usr/local/mysql
chown -R mysql.mysql  /usr/local/mysql*
/usr/local/mysql/bin/mysqld --initialize-insecure --user mysql --datadir=/opt/data
echo "export PATH=/usr/local/mysql/bin:\$PATH" > /etc/profile.d/mysqld.sh

service启动文件

[Unit]
Description=Mysqld server daemon
After=network.target

[Service]
Type=forking
ExecStart=/usr/local/mysql/support-files/mysql.server start
ExecStop=/usr/local/mysql/support-files/mysql.server stop

[Install]
WantedBy=multi-user.target


1.3 php服务的状态文件

[root@master ~]# cat /srv/salt/prod/modules/application/php/install.sls 
/usr/src/oniguruma-devel-6.8.2-2.el8.x86_64.rpm:
  file.managed:
    - source: salt://modules/application/php/files/oniguruma-devel-6.8.2-2.el8.x86_64.rpm
    - user: root
    - group: root
    - mode: '0644'
  cmd.run:
    - names:
      - yum -y install /usr/src/oniguruma-devel-6.8.2-2.el8.x86_64.rpm 
    - unless: rpm -q oniguruma-devel  

dep-package-install:
  pkg.installed:
    - pkgs: 
      - libxml2
      - libxml2-devel
      - openssl 
      - openssl-devel 
      - bzip2 
      - bzip2-devel 
      - libcurl 
      - libcurl-devel 
      - libicu-devel 
      - libjpeg-turbo
      - libjpeg-turbo-devel 
      - libpng 
      - libpng-devel 
      - openldap-devel  
      - pcre-devel 
      - freetype 
      - freetype-devel 
      - gmp   
      - gmp-devel 
      - libmcrypt 
      - libmcrypt-devel 
      - readline 
      - readline-devel 
      - libxslt      
      - libxslt-devel 
      - mhash 
      - mhash-devel 
      - php-mysqlnd 
      - libzip-devel 
      - libsqlite3x 
      - libsqlite3x-devel 
      - oniguruma   
      - libzip-devel    

/usr/src/php-8.0.10.tar.gz:
  file.managed:
    - source: salt://modules/application/php/files/php-8.0.10.tar.gz
    - user: root
    - group: root
    - mode: '0644'

php-install:
  cmd.script:
    - name: salt://modules/application/php/files/install.sh
    - unless:  test -d /usr/local/php8

php-copy-package:
  file.managed:
    - names:
      - /etc/init.d/php-fpm:
        - source: salt://modules/application/php/files/php-fpm
        - user: root
        - group: root
        - mode: '0755'  
      - /usr/local/php8/etc/php-fpm.conf:
        - source: salt://modules/application/php/files/php-fpm.conf
      - /usr/local/php8/etc/php-fpm.d/www.conf:
        - source: salt://modules/application/php/files/www.conf
      - /usr/lib/systemd/system/php-fpm.service:
        - source: salt://modules/application/php/files/php-fpm.service
    - require: 
      - cmd: php-install
php-fpm.service:
  service.running:
    - enable: true  
    - reload: true
    - require:
      - cmd: php-install
      - file: php-copy-package
    - watch: 
      - file: php-copy-package

安装脚本

[root@master ~]# cat /srv/salt/prod/modules/application/php/files/install.sh 
#!/bin/bash

cd /usr/src
rm -rf php-7.4.25
tar -xf php-7.4.25.tar.gz
cd  php-7.4.25
./configure --prefix=/usr/local/php8  \
        --with-config-file-path=/etc \
        --enable-fpm \
        --disable-debug \
        --disable-rpath \
        --enable-shared \
        --enable-soap \
        --with-openssl \
        --enable-bcmath \
        --with-iconv \
        --with-bz2 \
        --enable-calendar \
        --with-curl \
        --enable-exif  \
        --enable-ftp \
        --enable-gd \
        --with-jpeg \
        --with-zlib-dir \
        --with-freetype \
        --with-gettext \
        --enable-mbstring \
        --enable-pdo \
        --with-mysqli=mysqlnd \
        --with-pdo-mysql=mysqlnd \
        --with-readline \
        --enable-shmop \
        --enable-simplexml \
        --enable-sockets \
        --with-zip \
        --enable-mysqlnd-compression-support \
        --with-pear \
        --enable-pcntl \
        --enable-posix  && \
make && make install

service文件

[root@master ~]# cat /srv/salt/prod/modules/application/php/files/php-fpm.service 
[Unit]
Description=Php-fpm server daemon
After=network.target

[Service]
Type=forking
ExecStart=service php-fpm start
ExecStop=service php-fpm stop

[Install]
WantedBy=multi-user.target

2. 编写项目配置

2.1apache配置的状态文件

[root@master ~]# cat /srv/salt/prod/zabbix/apache.sls 
"Development Tools":
  pkg.group_installed

include:
  - modules.web.apache.install


/usr/include/httpd:
  file.symlink:
    - target: /usr/local/apache/include
    - require: 
      - cmd: apache-install

/usr/local/apache/htdocs/zabbix:
  file.directory:
    - user: root
    - group: root
    - mode: '0755'
    - makedirs: true
    - require:
      - cmd: apache-install

/usr/local/apache/htdocs/zabbix/index.php:
  file.managed:
    - source: salt://zabbix/files/index.php
    - user: root
    - group: root
    - mode: '0755'
    - makedirs: true
    - require:
      - cmd: apache-install


/usr/local/apache/conf/extra/vhosts.conf:
  file.managed: 
    - source: salt://zabbix/files/vhosts.conf
    - require:
      - cmd: apache-install


apache-service-start:
  service.running:
    - name: httpd
    - enable: true
    - reload: true
    - require:
      - file: /usr/local/apache/conf/extra/vhosts.conf
    - watch: 
      - file: /usr/local/apache/conf/extra/vhosts.conf

2.2 mysql的状态文件

mysql-dep-packages:
  pkg.installed:
    - pkgs:
      - ncurses-devel
      - openssl-devel
      - openssl
      - cmake
      - mariadb-devel

include:
  - modules.database.mysql.install

provides-mysql-file:
  file.managed:
    - source: salt://zabbix/files/my.cnf
    - user: root
    - group: root
    - mode: '0644' 
    - names:
      - /etc/my.cnf:
        - source: salt://zabbix/files/my.cnf
      - /etc/ld.so.conf.d/mysql.conf:
        - source: salt://zabbix/files/mysql.conf
 
   
/usr/local/include/mysql:
  file.symlink:
    - target: /usr/local/mysql/include


mysqld.service:
  service.running:
    - enable: true
    - require:
      - cmd: mysql-install
      - file: trasfer-files
    - watch:
      - file: provides-mysql-file   

mysql-set-password:
  cmd.run:
    - name: /usr/local/mysql/bin/mysql -e "set password=password('123');"
    - require: 
      - service: mysqld.service
    - unless:  /usr/local/mysql/bin/mysql -uroot -p123 -e  "exit"

2.3 zabbix安装的状态文件

[root@master ~]# cat  /srv/salt/prod/zabbix/install.sls 
zabbix-dep-packages:
  pkg.installed:
    - pkgs: 
      - net-snmp-devel
      - libevent-devel
      - gcc 
      - gcc-c++ 
      - make

zabbix:
  user.present:
    - shell: /sbin/nologin
    - createhome: false
    - system: true

/usr/src/zabbix-5.4.4.tar.gz:
  file.managed:
    - source: salt://zabbix/files/zabbix-5.4.4.tar.gz

salt://zabbix/files/install.sh:
  cmd.script

/usr/local/etc/zabbix_server.conf:
  file.managed:
    - source: salt://zabbix/files/zabbix_server.conf

create-dir:
  file.directory:
    - name: /var/lib/mysql
    - user: root
    - group: root 
    - mode: '0644'

link:
  cmd.run:
    - name: ln -s /tmp/mysql.sock /var/lib/mysql/

/etc/php.ini:
  file.managed:
    - source: salt://zabbix/files/php.ini

copy-ui:
  cmd.run:
    - name: cp -a /usr/src/zabbix-5.4.4/ui/* /usr/local/apache/htdocs/zabbix/
 
start-service:
  cmd.run:
    - names:
      - zabbix_server
      - zabbix_agentd

2.4 zabbix主状态文件

include:
  - zabbix.apache
  - zabbix.mysql
  - modules.application.php.install
  - zabbix.install

2.5 zabbix安装脚本

[root@master ~]# cat  /srv/salt/prod/zabbix/files/install.sh 
#!/bin/bash

cd /usr/src/
tar xf zabbix-5.4.4.tar.gz
/usr/local/mysql/bin/mysql -uroot -p123 -e "create database zabbix character set utf8 collate utf8_bin;"
/usr/local/mysql/bin/mysql -uroot -p123 -e "grant all privileges on zabbix.* to 'zabbix'@'localhost' identified by 'zabbix123';"
/usr/local/mysql/bin/mysql -uroot -p123 -e "flush  privileges;"

cd  /usr/src/zabbix-5.4.4/database/mysql
/usr/local/mysql/bin/mysql -uroot -p123 zabbix   < schema.sql
/usr/local/mysql/bin/mysql -uroot -p123 zabbix   < images.sql
/usr/local/mysql/bin/mysql -uroot -p123 zabbix   < data.sql
cd  /usr/src/zabbix-5.4.4/
./configure --enable-server --enable-agent --with-mysql --with-net-snmp --with-libcurl --with-libxml2  &&  make install

执行main文件

猜你喜欢

转载自blog.csdn.net/weixin_46115601/article/details/121263472