salt '*' sys.list_modules
salt '*' sys.list_functions
salt '*' sys.list_functions test
salt '*' sys.doc test.ping
常用模块
salt 'minion01' cp.push /root/test.log
把minion01的文件发到了master /var/cache/salt/master/minions/minion01/files/root/test.log 下面
# salt 'minion01' file.copy /root/test.py /root/test.py.bak # 将minion端的一个文件copy成另一个文件
#salt '*' file.chown /etc/passwd root root 修 改文件属组
远程执行命令 cmd
#salt -v --out=json "*" cmd.run "ps aux |wc -l"
安装包 pkg
#salt "*" pkg.install "httpd" 安装
pkg.version
pkg.remove
管理服务模块 service
salt "*" service.status "httpd"
service.start|stop|restart
用户管理模块 user
salt '*' user.add 'test' shell=/sbin/nologin
user.delete
user.info
# salt '*' sys.list_state_modules //查看state所有模块
# salt '*' sys.list_state_functions pkg // 查看state指定模块的所有方法
# salt '*' sys.state_doc pkg // 查看模块方法的详细用法
# salt '*' sys.state_doc pkg.upgrade // 查看某个方法的详细用法
- 缩进 两个空格,不能tab键。表示层级关系
- 冒号 冒号后面一个空格,除了以冒号结尾和路径中的冒号
- 短横线 后面跟一个空格。表示列表项。
state.sls的写法:
# cat test.sls
lftp: # name
pkg.installed #状态模块 installed-ssh: # ID 必须唯一。一个id声明下,状态模块不能重复使用。
pkg.installed:
- names: # names复数,多个值,一行一个,列表项
- openssh-server
- openssh-clients
执行: salt '*' state.sls test
jinja模板语法:变量用{{...}}, 表达式用{%...%}
1. 设置jinja变量
{% set var='hello world!' %}
test_var:
cmd.run:
- name: echo "var is {{var}}"
设置:
字符串: {% set var='hello world!' %}
引用: {{var}}
列表: {% set list = ['one','two','three'] %}
{{ list[1] }}
字典: {% set dic = {'a':'11','b':'22'} %}
{{ dic['a'] }}
2,流程控制语句
For循环
{% for user in users %}
{{user}}
{% endfor %}
#字典
{% for key,value in my_dict.iteritems() %}
{{ key }}
{{ value }}
{% endfor %}
举例:
举例:
dir-tomcat:
file.directory:
{% for Dir in ['bin','conf','lib','logs','temp','webapps','work'] %}
- names:
- /usr/local/tomcat/{{Dir}}
{% endfor %}
- makedirs: True
- user: root
- group: root
- dir_mode: 755
- file_mode: 644
例2:
# salt "minion-2" grains.items
# salt "*" grains.ls
检索某一grains数据用如下命令:
#salt 'minion-2' grains.item os
了解操作系统信息后 ,可以使用grains定位主机,用-G或者--grains对只是centos的机器定位
#salt -G "os:CentOS" test.ping
#salt -G "hwaddr_interfaces:eth0:00:16:3e:06:39:af" test.ping
#配置pillar_roots
# vim /etc/salt/master
pillar_roots:
base:
- /srv/pillar
# salt '*' saltutil.refresh_pillar pillar刷新
{% set confdir="/etc/zabbix" %}
zabbix-conf:
file.managed:
- name: {{confdir}}/zabbix_agentd.conf
- source: salt://file/zabbix_agentd.conf
- user: root
- group: root
- mode: 755
- require:
- pkg: zabbix-pkg
- template: jinja
- defaults:
SERVER: {{ pillar['zabbix-agent'] }} #SERVER变量 # 定义pillar值
# cat /srv/pillar/zabbix-agent.sls
zabbix-agent: 192.168.1.10
# cat /srv/pillar/top.sls
base:
'*':
- zabbix-agent
# vim file/zabbix_agentd.conf #文件里面使用变量
Server={{ SERVER }}
Hostname={{ grains['fqdn'] }}
zabbix-yum: # ID号
pkgrepo.managed: # 方法名
- name: zabbix #参数 zabbix是文件名 发到客户端为/etc/yum.repos.d/zabbix.repo 文件
- humanname: Zabbix Official Repository - $basearch
- baseurl: http://repo.zabbix.com/zabbix/3.4/rhel/7/$basearch/
- enabled: 1
- gpgcheck: 0
- gpgkey: file:///etc/pki/rpm-gpg/RPM-GPG-KEY-ZABBIX-A14FE591