SaltStact自动化运维工具03
存储位置 类型 采集方式 场景
Grains minion 静态 minion启动时,可以刷新 1、获取信息 2、匹配
pillar master 动态 指定,实时生效 1、匹配 2、敏感数据配置
LAMP (软件安装salt.states.pki 配置文件salt.states.file 服务salt.states.service)
[root@linux-node1 prod]# mkdir -p /srv/salt/prod/{apache,mysql,php}
[root@linux-node1 prod]# tree
.
├── apache
├── mysql
└── php
#################################
[root@linux-node1 prod]# cd apache/
[root@linux-node1 apache]# vim init.sls
apache-install:
pkg.installed:
- name: httpd
apache-config:
file.managed:
- name: /etc/httpd/conf/httpd.conf
- source: salt://apache/files/httpd.conf
- user: root
- group: root
- mode: 644
apache-services:
service.running:
- name: httpd
- enable: True
[root@linux-node1 apache]# mkdir files
[root@linux-node1 apache]# cd files/
[root@linux-node1 files]# cp /etc/httpd/conf/httpd.conf .
[root@linux-node1 files]# salt 'linux-node1*' state.sls apache.init saltenv='prod'
linux-node1.localdomain: ----------ID: apache-installFunction: pkg.installedName: httpdResult: TrueComment: All specified packages are already installedStarted: 11:22:05.394917Duration: 1124.351 msChanges: ----------ID: apache-configFunction: file.managedName: /etc/httpd/conf/httpd.confResult: TrueComment: File /etc/httpd/conf/httpd.conf is in the correct stateStarted: 11:22:06.550853Duration: 32.42 msChanges: ----------ID: apache-servicesFunction: service.runningName: httpdResult: TrueComment: The service httpd is already runningStarted: 11:22:06.637945Duration: 115.643 msChanges: Summary for linux-node1.localdomain ------------ Succeeded: 3 Failed: 0 ------------ Total states run: 3 Total run time: 1.272 s
View Code
[root@linux-node1 prod]# cd php/
[root@linux-node1 php]# mkdir files
[root@linux-node1 php]# vim init.sls
php-install:
pkg.installed:
- pkgs:
- php
- php-pdo
- php-mysql
php-config:
file.managed:
- name: /etc/php.ini
- source: salt://php/files/php.ini
- user: root
- group: root
- mode: 644
[root@linux-node1 php]# yum -y install php
[root@linux-node1 php]# cp /etc/php.ini files/
#################################
[root@linux-node1 prod]# cd mysql/
[root@linux-node1 mysql]# mkdir files
[root@linux-node1 mysql]# vim init.sls
mysql-install:
pkg.installed:
- pkgs:
- mariadb
- mariadb-server
mysql-config:
file.managed:
- name: /etc/my.cnf
- source: salt://mysql/files/my.cnf
- user: root
- group: root
- mode: 644
mysql-service:
service.running:
- name: mariadb
- enable: True
[root@linux-node1 prod]# yum -y install mariadb-server
[root@linux-node1 prod]# cp /etc/my.cnf mysql/files/
#################################
[root@linux-node1 prod]# tree
.
├── apache
│ ├── files
│ │ └── httpd.conf
│ └── init.sls
├── mysql
│ ├── files
│ │ └── my.cnf
│ └── init.sls
└── php
├── files
│ └── php.ini
└── init.sls
[root@linux-node1 files]# salt 'linux-node1*' state.sls apache.init saltenv='prod'
salt -S '192.168.0.2' state.sls php.init saltenv=prod
salt -S '192.168.0.2' state.sls mysql.init saltenv=prod
等价于以下方式:
[root@linux-node1 prod]# vim ../base/top.sls
prod:
'linux-node1.localdomain':
- apache.init
- php.init
- mysql.init
[root@linux-node1 prod]# salt -S '192.168.0.2' state.highstate
linux-node1.localdomain: ----------ID: apache-installFunction: pkg.installedName: httpdResult: TrueComment: All specified packages are already installedStarted: 12:04:03.354119Duration: 987.978 msChanges: ----------ID: apache-configFunction: file.managedName: /etc/httpd/conf/httpd.confResult: TrueComment: File /etc/httpd/conf/httpd.conf is in the correct stateStarted: 12:04:04.345800Duration: 24.349 msChanges: ----------ID: apache-servicesFunction: service.runningName: httpdResult: TrueComment: The service httpd is already runningStarted: 12:04:04.371095Duration: 59.907 msChanges: ----------ID: php-installFunction: pkg.installedResult: TrueComment: All specified packages are already installedStarted: 12:04:04.431364Duration: 26.57 msChanges: ----------ID: php-configFunction: file.managedName: /etc/php.iniResult: TrueComment: File /etc/php.ini is in the correct stateStarted: 12:04:04.458181Duration: 13.008 msChanges: ----------ID: mysql-installFunction: pkg.installedResult: TrueComment: All specified packages are already installedStarted: 12:04:04.471433Duration: 24.754 msChanges: ----------ID: mysql-configFunction: file.managedName: /etc/my.cnfResult: TrueComment: File /etc/my.cnf is in the correct stateStarted: 12:04:04.496454Duration: 11.538 msChanges: ----------ID: mysql-serviceFunction: service.runningName: mariadbResult: TrueComment: The service mariadb is already runningStarted: 12:04:04.508203Duration: 45.043 msChanges: Summary for linux-node1.localdomain ------------ Succeeded: 8 Failed: 0 ------------ Total states run: 8 Total run time: 1.193 s
View Code
incloude 和 extend 使用
[root@linux-node1 prod]# vim lamp.sls
include:
- php.init
- apache.init
- mysql.init
[root@linux-node1 prod]# vim ../base/top.sls
prod:
'linux-node1.localdomain':
- lamp
[root@linux-node1 prod]# salt -S '192.168.0.2' state.highstate
扩展
[root@linux-node1 prod]# vim lamp.sls
include: #相当于把三个文件夹里的init.sls的内容复制粘贴过来一样
- php.init
- apache.init
- mysql.init
extend: #相当于在php/init.sls里面的pkg.installed加了一个安装项目
php-install:
pkg.installed:
- name: php-mbstring
[root@linux-node1 prod]# salt -S '192.168.0.2' state.highstate
#################################
require(我依赖谁) 和 require_in(我被谁依赖) 使用
[root@linux-node1 prod]# vim apache/init.sls
apache-install: #没有ID下面的模块(例如pkg、file、service)不能重复
pkg.installed:
- name: httpd
apache-config:
file.managed:
- name: /etc/httpd/conf/httpd.conf
- source: salt://apache/files/httpdi.conf 故意改错http.conf httpdi.conf
- user: root
- group: root
- mode: 644
apache-services:
service.running:
- name: httpd
- enable: True
- require: #先会判断 apache-install 和 apache-config是否执行成功 不成功就不执行apache-services
- pkg: apache-install #格式: - 模块名: 自己定义的ID
- file: apache-config
[root@linux-node1 prod]# salt -S '192.168.0.2' state.highstate 先找到 base的top.sls ---> 再执行top.sls里面的lamp.sls --->最后执行lamp.sls里面的 mysql/init.sls php/init.sls apache/init.sls
linux-node1.localdomain: ----------ID: php-installFunction: pkg.installedName: php-mbstringResult: TrueComment: All specified packages are already installedStarted: 15:31:45.534122Duration: 992.179 msChanges: ----------ID: php-configFunction: file.managedName: /etc/php.iniResult: TrueComment: File /etc/php.ini is in the correct stateStarted: 15:31:46.529682Duration: 24.317 msChanges: ----------ID: apache-installFunction: pkg.installedName: httpdResult: TrueComment: All specified packages are already installedStarted: 15:31:46.554230Duration: 25.533 msChanges: ----------报错的地方ID: apache-configFunction: file.managedName: /etc/httpd/conf/httpd.confResult: FalseComment: Source file salt://apache/files/httpdi.conf not found in saltenv 'prod'Started: 15:31:46.580005Duration: 5.781 msChanges: ----------报错的地方ID: apache-servicesFunction: service.runningName: httpdResult: FalseComment: One or more requisite failed: apache.init.apache-configStarted: 15:31:46.587421Duration: 0.02 msChanges: ----------ID: mysql-installFunction: pkg.installedResult: TrueComment: All specified packages are already installedStarted: 15:31:46.587521Duration: 24.84 msChanges: ----------ID: mysql-configFunction: file.managedName: /etc/my.cnfResult: TrueComment: File /etc/my.cnf is in the correct stateStarted: 15:31:46.612602Duration: 11.833 msChanges: ----------ID: mysql-serviceFunction: service.runningName: mariadbResult: TrueComment: The service mariadb is already runningStarted: 15:31:46.624651Duration: 59.244 msChanges: Summary for linux-node1.localdomain ------------ Succeeded: 6 Failed: 2 ------------ Total states run: 8 Total run time: 1.144 s
View Code
require_in(我被谁依赖) 演示
[root@linux-node1 prod]# vim apache/init.sls
跟require效果差不多
watch 和 watch_in 的使用(不是什么模块都可以使用 service有)
[root@linux-node1 prod]# vim apache/init.sls
看着(watch) 修改http.conf 文件的内容 就执行重启
[root@linux-node1 prod]# vim apache/init.sls
加了一行 reload: True
看着(watch) 修改http.conf 文件的内容 就执行重新加载
[root@linux-node1 prod]# vim apache/init.sls
看着(watch in) 修改http.conf 文件的内容 就执行重新加载
unless用法
[root@linux-node1 ~]# cd /var/www/html/
[root@linux-node1 html]# mkdir admin
[root@linux-node1 admin]# vim index.html
[root@linux-node1 salt]# cd /srv/salt/prod/apache/files/
[root@linux-node1 files]# vim httpd.conf
<Directory /var/www/html/admin>
AllowOverride All
Order allow,deny
Allow from all
AuthType Basic
AuthName "welcome"
AuthUserFile /etc/httpd/conf/htpasswd_file
Require user admin
</Directory>
[root@linux-node1 files]# whereis htpasswd
htpasswd: /usr/bin/htpasswd /usr/share/man/man1/htpasswd.1.gz
[root@linux-node1 files]# rpm -qf /usr/bin/htpasswd
httpd-tools-2.4.6-88.el7.centos.x86_64
[root@linux-node1 files]# cd ..
[root@linux-node1 apache]# vim init.sls 增加一个
apache-auth:
pkg.installed:
- name: httpd-tools
cmd.run:
- name: htpasswd -bc /etc/httpd/conf/htpasswd_file admin admin
- unless: test -f /etc/httpd/conf/htpasswd_file # 如果条件为假 才执行 htpasswd -bc /etc/httpd/conf/htpasswd_file admin admin
[root@linux-node1 ~]# salt -S '192.168.0.2' state.highstate
http://192.168.0.2/admin
jinja模板用法
[root@linux-node1 ~]# vim /srv/salt/prod/apache/init.sls #加上jinja模板
apache-config:
file.managed:
- name: /etc/httpd/conf/httpd.conf
- source: salt://apache/files/httpd.conf
- user: root
- group: root
- mode: 644
- template: jinja
PORT: 80
IPADDR: {{ grains['fqdn_ip4'][0] }} #输出的是一个列表
[root@linux-node1 ~]# vim /srv/salt/prod/apache/files/httpd.conf
#Listen 12.34.56.78:80
Listen {{ IPADDR }}:{{ PORT }}
#
[root@linux-node1 ~]# vim /srv/salt/base/top.sls
#base:
# 'os:ubuntu':
# - match: grain
# - web.apache
prod:
'linux-node*.localdomain':
- lamp
~
[root@linux-node1 ~]# salt '*' state.highstate
转载于:https://www.cnblogs.com/linux985/p/10542730.html
SaltStact自动化运维工具03相关推荐
- mysql 自动化运维工具_部署MySQL自动化运维工具inception+archer
*************************************************************************** 部署MySQL自动化运维工具inception+ ...
- 自动化运维工具Ansible实战(一)简介和部署
一.Ansible的介绍 Ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet.cfengine.chef.func.fabric)的优点.实现了批量系统配置 ...
- Centos7部署轻量级自动化运维工具pssh (亲测)
下载pssh安装包 [root@localhost ~]# wget https://files.pythonhosted.org/packages/60/9a/8035af3a7d3d1617ae2 ...
- 自动化运维工具——【ansible】——从菜鸟到菜鸟
一.ansible详解 1.1.什么是ansible ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet.cfengine.chef.func.fabric ...
- 自动化运维工具-Ansible的Playbook的使用
Playbook的使用 前言 一.Playbook是什么? 二.playbook使用场景 三.Playbook格式说明 四.Play book变量的使用 1 在主机列表定义变量 2 在playbook ...
- 自动化运维工具-Ansible实战指南
Ansible实战 前言 一.Ansible简介 1.ansible是什么? 2.ansible特点 3.ansible架构 主要模块 工作流程 命令执行过程 二.Ansible 配置 1 安装ans ...
- 自动化运维工具Ansible
ansible简介: ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet.cfengine.chef.func.fabric)的优点,实现了批量系统配置.批 ...
- 自动化运维工具----ansible
自动化运维工具----ansible ansible是新出现的运维工具是基于Python研发的糅合了众多老牌运维工具的优点实现了批量操作系统配置.批量程序的部署.批量运行命令等功能. 主要模块以及功能 ...
- 简单介绍自动化运维工具clip
Clip是一款自动化运维工具,适用于海量服务器的管理场景,可以降低系统误操作风险,提高工作效率等.Clip将传统的IP管理纬度替换为String管理纬度,管理方式的改变使海量运维时更加的便捷.可靠与高 ...
- 轻量级自动化运维工具Fabric的安装与实践
一.背景环境 在运维工作中,经常会遇到重复性的劳动,这个时候为了效率就必须要使用自动化运维工具. 这里我给大家介绍轻量级自动化运维工具Fabric,Fabric是基于Python语言开发的,是开发同事 ...
最新文章
- 苹果四大供应商向高通索赔90亿;金立否认裁定破产清算
- 开源mindmap_Java开发人员访谈的MindMap
- 哲学家就餐(避免死锁)(多进程版)
- 天池 在线编程 输入流
- Kibana 的安装(Windows版本)新手入门
- Rational 中 DataPool 的介绍与实际应用
- mysql 5.6.17 备份还原_mysql 备份和恢复
- mysql count or null_为什么在对带有条件的行进行计数时,为什么在MySQL中需要“ OR NULL”...
- mysql数据字典的通俗理解_MySQL关于数据字典的一个疑问
- 关于spring+springMVC+myBatis的一些基础配置以及整合
- python枚举函数_python dict函数枚举对象
- mybatis 之 parameterType=list
- mvn help:system下载包失败错误解决!
- cleanmymac x激活码免费下载激活及使用教程
- 网易云课堂 oracle,网易云课堂DBA学习笔记 (一) 数据库基础
- 信息储存服务器有没有辐射,服务器存储主机存在辐射吗
- HeadPose Estimation头部姿态估计头部朝向(Android)
- 基于JAVA校内图书馆智能管理系统计算机毕业设计源码+数据库+lw文档+系统+部署
- Open vSwitch系列实验(三):Open vSwitch的VxLAN隧道网络实验
- pycharm安装与配置Pyqt5
热门文章
- 哀悼日网站全站变灰代码,最简单的还是ng这种方式...
- Java序列化 3 连问,这太难了吧!
- 电商购物核心架构演进:谁说架构思路会过时?
- 华为、阿里、京东停止社招转外包:头部公司们的谋局
- 一篇文章帮你梳理清楚API设计时需要考虑的几个关键点
- 是什么浪费了运维的工作时间?
- IT 行业加班到底有没有价值?
- 代码很烂,所以离职?
- python函数可以改变哪种数据类型的实参_表达式1+2*3.140的结果类型是():_学小易找答案...
- 为什么python除法结果会有小数点0_22. 为什么 Python 中的整除是向下取整?