设为首页 收藏本站
查看: 1465|回复: 0

[经验分享] (二)slatstack远程执行

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-12-21 09:38:26 | 显示全部楼层 |阅读模式
salt执行模块
在远程主机上运行预定义的或任意命令,也称为远程执行,是saltstack的核心功能。
salt执行模块是由远程执行系统调用来执行各种各样的任务。这些模块提供的功能,如安装包,重启服务,远程命令运行,传输文件等。

远程执行命令:

命令格式
salt 目标 模块.方法 返回信息


salt '*' test.ping
salt '*' cmd.run "uptime"
salt 'salt-client.com' state.highstate -v test=True   #测试
salt 'salt-client.com' state.highstate        #主动推送
salt '*' sys.doc             #查看哪些函数可用
salt '*' pkg.install vim     #安装包 yum或apt
salt '*' network.interfaces  #查看网络


检查存活主机
salt "*" test.ping    #注意这里支持通配符哦,*表示所有,当然依旧也可以指定主机,在这里面test表示模块而ping则是方法。注意这里面的ping可不是Linux里面ICMP协议的ping是salt自己独有的东西

[iyunv@master ~]# salt "*" test.ping
salt-client.com:
    True



命令执行
#查看磁盘利用率
salt "*" cmd.run "df -h"   
#其中cmd为模块而run是方法df -h则是传入的参数.此时就能够返回各个主机的磁盘使用情况。cmd下的run方法后面可以接任何shell参数。因此这个模块非常之强大,当然也非常危险。

[iyunv@master ~]# salt "*" cmd.run "df -h"
salt-client.com:
    Filesystem      Size  Used Avail Use% Mounted on
    /dev/sda2       7.9G  1.6G  6.0G  21% /
    tmpfs           242M   12K  242M   1% /dev/shm
    /dev/sda1       194M   29M  155M  16% /boot



#查看内存剩余
salt "*" cmd.run "free -m"

[iyunv@master ~]# salt "*" cmd.run "df -h"
salt-client.com:
    Filesystem      Size  Used Avail Use% Mounted on
    /dev/sda2       7.9G  1.6G  6.0G  21% /
    tmpfs           242M   12K  242M   1% /dev/shm
    /dev/sda1       194M   29M  155M  16% /boot


#远程创建文件夹
[iyunv@master ~]# salt '*' cmd.run 'mkdir -p /tmp/salt'
salt-client.com:


远程拷贝文件
我们可以实现将本机的host文件直接复制到客户端的/tmp目录下,不必担心文件权限的问题
[iyunv@master ~]# salt-cp '*' /etc/hosts /tmp
{'salt-client.com': {'/tmp/hosts': True}}


这种方法是最简单的,不必担心远程复制时文件权限的问题,这种方法可比ssh远程复制要简单的太多啦


内置的执行模块
[iyunv@master salt]# salt '*' disk.usage   #查看远程主机磁盘使用情况
salt-client.com:
    ----------
    /:
        ----------
        1K-blocks:
            8256952


ervice模块
salt '*' service.status sshd          #查看服务状态
salt '*' service.restart sshd         #重启sshd服务
salt '*' service.get_all       #获取minion端已启动的服务

salt-cp模块
salt-cp '*' /root/salt.txt /root/


file模块
salt '*' file.file_exists /etc/passwd     #检测文件是否存在



远程代码执行
salt '*' cmd.exec_code python 'import sys; print sys.version'

查看执行过程
salt '*' cmd.exec_code python 'import sys; print sys.version' -l debug


saltstack远程执行几个典型模块来学习:
SALT.MODULES.NETWORK
 Module for gathering and managing network information

salt.modules.network.active_tcp()
 CLI Example:
salt '*' network.active_tcp

salt.modules.network.arp()
 Return the arp table from the minion
 CLI Example:
salt '*' network.arp

SALT.MODULES.SERVICE
 service is a virtual module that is fulfilled by one of the following modules:

salt.modules.service.available(name)
Returns True if the specified service is available, otherwise returns False.
 CLI Example:
salt '*' service.available sshd

salt.modules.service.get_all()
 Return a list of all available services
 CLI Example:
salt '*' service.get_all

salt.modules.service.reload(name)
 Refreshes config files by calling service reload. Does not perform a full restart.
 CLI Example:
salt '*' service.reload

salt.modules.service.restart(name)
 Restart the specified service
 CLI Example:
salt '*' service.restart

SALT.MODULES.CP
 Minion side functions for salt-cp
salt.modules.cp.cache_dir(path, saltenv='base', include_empty=False, include_pat=None, exclude_pat=None, env=None)
 Download and cache everything under a directory from the master
 CLI Example:
salt-cp '*’/etc/hots /opt/hehe

SALT.MODULES.STATE
 Control the state system on the minion.
 CLI Example:
salt '*' state.show_top
saltstack远程执行-返回程序

SALT.MODULES.MYSQL
 Module to provide MySQL compatibility to salt.
说明:返回数据是指minion直接返回给MYSQL

salt.modules.mysql.db_create(name, character_set=None, collate=None, **connection_args)
 Adds a databases to the MySQL server.

name
 The name of the database to manage
character_set
 The character set, if left empty the MySQL default will be used
collate
 The collation, if left empty the MySQL default will be used

 CLI Example:
salt '*' mysql.db_create 'dbname'
salt '*' mysql.db_create 'dbname' 'utf8' 'utf8_general_ci'

如何编写一个状态模块
1.放在哪里
/srv/salt/_modules
2.命令。文件名就是模块名;例如:my_disk.py

vim /_modules/my_disk.py
def list():
 cmd = 'df-h'
 ret = _salt_['cmd.run'](cmd)
 return ret
3.刷新
#刷新命令会把文件放在/etc/salt/minion/extmods里面
salt '*' saltutil.sync_modules


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-317213-1-1.html 上篇帖子: (一)slatstack简介与安装 下篇帖子: (三)slatstack配置管理
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表