Saltstack 常用的模块及API

Saltstack提供了非常丰富的功能模块,设计操作系统的基础功能,常用工具支持等,

官网模块介绍

http://docs.saltstack.com/ref/modules/all/index.html

一 列出当前版本支持的模块

[[email protected]020 ~]# salt ‘*‘ sys.list_modules
hzbj-tomcat-021:
    - acl
    - aliases
    - alternatives
    - apache
    - archive
    - artifactory
    - blockdev
    - btrfs
    - buildout
    - cloud
    - cmd
    - composer
    - config
    - container_resource
    - cp
    - cron
    - data
    - defaults
    - devmap
    - disk
    - django
    - dnsmasq
    - dnsutil
    - drbd
    - elasticsearch
    - environ
    - etcd
    - event
    - extfs
    - file
    - gem
    - genesis
    - git
    - grains
    - group
    - grub
    - hashutil
    - hg
    - hipchat
    - hosts
    - http
    - img
    - incron
    - ini
    - introspect
    - ip
    - iptables
    - jboss7
    - jboss7_cli
    - key
    - kmod
    - locale
    - locate
    - logrotate
    - lowpkg
    - lvm
    - match
    - mine
    - modjk
    - mount
    - network
    - openstack_config
    - pagerduty
    - pillar
    - pip
    - pkg
    - pkg_resource
    - postfix
    - publish
    - pyenv
    - raid
    - random
    - random_org
    - rbenv
    - ret
    - rsync
    - runit
    - rvm
    - s3
    - saltutil
    - schedule
    - scsi
    - sdb
    - seed
    - serverdensity_device
    - service
    - shadow
    - slack
    - smtp
    - sqlite3
    - ssh
    - state
    - status
    - supervisord
    - sys
    - sysctl
    - syslog_ng
    - system
    - test
    - timezone
    - user
    - vbox_guest
    - virtualenv
    - webutil
    - xfs

所有主机saltstack支持的模块清单(打印部分)

二 模块及api

import salt.client
client = salt.client.LocalClient()
ret = client.cmd(‘*‘,‘test.ping‘)
print ret

(1) Archive模块

1)功能:实现系统层面的压压缩包调用,支持gunzip,gzip,rar,tar,unrar,unzip等。

2)示例:

(2)cmd模块

1)功能:实现远程的命令行调用执行(默认具备root操作权限,使用时需要评估风险)

2)示例:

#获取所有被控主机的内存使用情况
[[email protected]-salt-020 ~]# salt ‘*‘ cmd.run "free -m"
hzbj-tomcat-022:
                 total       used       free     shared    buffers     cached
    Mem:           980        715        264          0         55        476
    -/+ buffers/cache:        184        796
    Swap:         1983          0       1983
hzbj-tomcat-021:
                 total       used       free     shared    buffers     cached
    Mem:           980        884         95          0         25        206
    -/+ buffers/cache:        652        327
    Swap:         1983         11       1972

#在hzbj-tomcat-022主机运行test.sh脚本,其中scripts/test.sh存放在file_roots指定的目录,
#改命令会做两个动作:首选同步test.sh到minion的cache目录(如同步到/var/cache/salt/ #minion/files/base/script/test.sh):其次运行改脚本
[[email protected]-salt-020 ~]# salt ‘hzbj-tomcat-01‘ cmd.script salt://script/test.sh

3)API调用

client.cmd(‘hzbj-tomcat-021‘,‘cmd.run‘,[‘free -m‘])

(3)cp模块

1)功能:实现远程文件,目录的复制,以及下载URL文件等操作

2)示例:

 将注服务器file_roots指定位置下的目录复制到被控主机
 salt ‘*‘ cp.get_dir salt://path/to/dir /minion/dest

 将主服务器file_roots指定文职下的文件复制到被控主机
 salt ‘*‘ cp.get_file salt://path/to/file /minion/dest

下载URL内容到被控主机指定位置
salt ‘*‘ cp.get_url http://www.salshdot.org /tmp/index.html

3)API调用

client.cmd(‘hzbj-tomcat-021‘,‘cp.get_file‘,[‘salt://path/to/file‘,‘/minion/dest‘])

(4)cron模块

1)功能:实现被控主机的crontab操作

2)示例

 查看指定被控主机,root用户的crontab清单
 [[email protected]-salt-020 salt]# salt ‘hzbj-tomcat-021‘ cron.raw_cron root
hzbj-tomcat-021:
    */2 * * * * ntpdate pool.ntp.org &>/dev/null
    */1 * * * * cd /usr/local/gse/; ./cron_gse.sh 1>/dev/null 2>&1

#指定的被控主机,root用户添加/usr/local/weekly任务作业
[[email protected]-salt-020 salt]# salt ‘hzbj-tomcat-021‘ cron.raw_cron root
hzbj-tomcat-021:
    */2 * * * * ntpdate pool.ntp.org &>/dev/null
    */1 * * * * cd /usr/local/gse/; ./cron_gse.sh 1>/dev/null 2>&1
    # Lines below here are managed by Salt, do not edit
    * * * * 1 /usr/local/weekly

#删除指定的被控主机,root用户添加/usr/local/weekly任务作业
[[email protected]-salt-020 salt]# salt ‘hzbj-tomcat-021‘ cron.rm_job root /usr/local/weekly
hzbj-tomcat-021:
    removed

注解: 如果需要写入sls文件里面

/usr/sbin/ntpdate pool.ntp.org >>/dev/null 2>&1:
  cron.present:
    - user: root
    - minute: 10
minute      #分钟
hour        #小时
daymonth    #日
month       #月
dayweek     #0~6是周一到周六,周日是7

默认执行用户“root”,时间不填写默认是“*”,周期执行“*/2”,随机执行“random”,identifier    是任务标识符,类似于任务ID,更改任务时指定“标识符”可方便修改

3)API调用

client.cmd(‘hzbj-tomcat-021‘,‘cron.set_job‘,[‘root‘,‘*‘,‘*‘,‘*‘,‘*‘,‘*‘,‘/usr/echo‘])

(5)dnsutil模块

1)功能:实现被控主机通用DNS相关操作。

2)示例:

[[email protected]020 ~]# salt ‘*‘ dnsutil.hosts_append /etc/hosts 127.0.0.1 ad1.yuk.com

删除指定被控主机hosts的主机批准
[[email protected]-salt-020 ~]# salt ‘*‘ dnsutil.hosts_remove /etc/hosts ad1.yuk.com

3)API调用

client.cmd(‘hzbj-tomcat-021‘,‘dnsutil.hosts_append‘,[‘/etc/hosts‘,‘127.0.01‘,‘ad1.yuk.co‘])

(6)file模块

1)功能:被控主机文件操作,包括文件读写,权限,查找,校验等。

(9)pkg包管理模块

1)功能:被控主机程序包管理,如yum,apt-get

2)示例:

#为所有被控主机安装PHP环境,根据不同系统发现版调用不同安装工具进行部署,如redhat
平台的yum,等价于yum -y install php
salt ‘*‘ pkg.install php
#卸载所有被控主机的PHP
salt ‘*‘ pkg.remove php
#升级所有被控主机的软件包
salt ‘*‘ pkg.upgrade

3)API调用

client.cmd(‘hzbj-tomcat-021‘,‘pkg.remove‘,[‘php‘])

(10)Service服务模块

1)功能:被控主机程序包服务管理

2)示例:

#开启(enable),禁用(disable)nginx开机自启动服务

salt ‘*‘ service.enable nginx
salt ‘*‘ service.disable nginx

#针对nginx服务的reload,restart,start,stop,ss操作
salt ‘*‘ service.reload nginx
salt ‘*‘ service.restart nginx
salt ‘*‘ service.start nginx
salt ‘*‘ service.stop nginx
salt ‘*‘ service.status nginx

3)API调用

client.cmd(‘hzbj-tomcat-021‘,‘service.stop‘,[‘nginx‘])
时间: 2024-12-13 10:12:11

Saltstack 常用的模块及API的相关文章

SaltStack常用的模块

目录 1. SaltStack模块介绍 2. SaltStack常用模块 2.1 SaltStack常用模块之network 2.1.1 network.active_tcp 2.1.2 network.calc_net 2.1.3 network.connect 2.1.4 network.default_route 2.1.5 network.get_fqdn 2.1.6 network.get_hostname 2.1.7 network.get_route 2.1.8 network.h

saltstack常用模块及组件备忘

Saltstack分为主控端和被控端.主控端的salt服务启动:systemctl start salt-master,被控端的服务启动:systemctl start salt-minion1.Saltstack的防火墙配置主控端防火墙允许TCP4505和4506端口,被控端不需要配置.原理是被控端直接与主控端的zeromq建立长链接,接受广播到的任务信息并执行. iptables -I INPUT -m state --state new -m tcp -p tcp --dport 4506

saltstack使用指南----常用执行模块

saltstack常用执行模块: cron模块 archive模块 cmd模块 cp模块 dnsutil模块 file模块 group模块 network模块 service模块 pkg模块 user模块 一.cron模块: 功能:实现被控主机的crontab操作 [[email protected] ~]# salt '*' sys.list_functions cron izwz9f8xrvty50quc2gq50z: - cron.list_tab - cron.ls - cron.raw

Saltstack常用模块及API(4)

Saltstack提供了非常丰富的功能模块(用python所写),涉及操作系统的基础功能.常用工具支持等,当然也可以通过sys模块列出当前版本支持的模块 #salt '*' sys.list_modules 接下来抽取常见的模块进行介绍,同时也会列举模块的API使用方法.API的原理是通过调用master client模块,实例化一个LocalClient对象,再调用cmda()方法来实现的.以下是API实现test.ping的示例: import salt.client client = sa

几种常用的医院地图API接口地址—百度地图

几种常用的医院地图API接口地址,医疗网站上经常使用的来院路线地图,调用第三方平台提供的地图接口,下面是医疗模板库为大家收集整理的几种常用的地图API接口. 1.百度地图: 网址:http://api.map.baidu.com/lbsapi/creatmap/index.html 2.搜狗地图: 网址:http://map.sogou.com/mark/?app=card 3.图吧: 网址:http://union.mapbar.com/onlineTagging.jsp 4.腾讯地图: 网址

Linux驱动学习之常用的模块操作命令

1.常用的模块操作命令 (1)lsmod(list module,将模块列表显示),功能是打印出当前内核中已经安装的模块列表 (2)insmod(install module,安装模块),功能是向当前内核中去安装一个模块,用法是insmod xxx.ko (3)modinfo(module information,模块信息),功能是打印出一个内核模块的自带信息.,用法是modinfo xxx.ko,注意要加.ko,也就是说是一个静态的文件形式. (4)rmmod(remove module,卸载

常用的模块 一 --sys --os ---haslib摘要算法

模块的加载顺序 ===>> python 解释器 ====>>> 第三方模块 =====>>> 自定义模块 常用的模块  1 import sys print(sys.modules) # sys.modules中找到当前已经加载的模块,sys.modules是一个字典 ============   sys 模块============ sys与python解释其交互相关的接口 import sys # sys与python解释其交互相关的接口 print(

详解Ansible服务常用命令模块

ansible可以使用命令行方式进行自动化管理,基本语法如下: ansible 主机名 -m 模块名称 -a 模块特有参数 ansible的命令行管理工具都是由一系列模块.参数所支持的,可以在命令后面加上-h或--help获取帮助.如使用ansible-doc -h或者ansible-doc --help查看其帮助信息ansible-doc是用来查看模块帮助信息的工具,最主要的选项 -l用来列出可使用的模块, -s用来列出某个模块的描述信息和使用示例. 以下是我列出yum模块的描述信息和操作动作

Python学习手册之__main__,常用第三方模块和打包发布

在上一篇文章中,我们介绍了 Python 的 元组拆包.三元运算符和对 Python 的 else 语句进行了深入讲解,现在我们介绍 Python 的 __main__ 模块.常用第三方模块和打包发布.查看上一篇文章请点击:https://www.cnblogs.com/dustman/p/10057482.html __main__大多数 Python 代码要么是导入的模块,要么是执行某些任务的脚本.但是,有时需要使一个文件既可以作为模块导入,也可以作为脚本运行. def sayHello()