前面己经说过如何安装saltstack,在平时己经体验了它的强大,下面来说一下平时常用的cp模块及cron与sls文件的书写
一、salt.modules.cp
1、复制文件[我使用最多的]
格式:
salt.modules.cp.get_file(path, dest, saltenv='base', makedirs=False, template=None, gzip=None, env=None,**kwargs)
常用参数说明:
path:表示salt-master的file_roots的路径下的源文件
dest:表示salt-minion的路径下文件(可以指定文件名,也可以不指定,但不指定【有时】会报错)
saltenv:salt-master部署到的环境,可以/etc/salt/master文件的file_roots自行指定,默认为base
makedirs:类型为布尔型,True表示目录不存在创建,False表示不创建
template: 指定模板,常用的有jinja。。。
gzip:压缩级别
例子:
salt '192.168.2.36-CentOS.backup.test.backend' cp.get_file salt://crontab/bak_sys.py /root/bak_sys.py makedirs=True gzip=9
2、复制目录
格式:
salt.modules.cp.get_dir(path, dest, saltenv='base', template=None, gzip=None, env=None, **kwargs)
注:path在此处表示目录,如果你不想将path复制到dest之下,那么指定到dest的上一级就好
例子:
#salt 'test-201' cp.get_dir salt://crontab /root makedirs=True test-201: - /root/crontab/Insert_Outgoing_Mail_Total.py - /root/crontab/Redis_config.py .....
3、查看文件内容
格式:
salt.modules.cp.get_file_str(path, saltenv='base', env=None)
例子:
[root@report copy_crontab_file]# salt 'test-201' cp.get_file_str salt://crontab/delete_mysql_rsyslog.sh test-201: #!/bin/bash # Database maintance script which can be used for rsyslog # and phplogcon default database schema. # Michael Mansour suggested it to be included - thx! # This program was original part of of PHPloghost # Copyright (C) 2004 Tuatha de Dana # some modifications for rsyslog by mmeckelein at 2007-08-08 # 2007-08-13 mmeckelein: added dbhost and some other improvements # suggested by Michael Mansour - thx a lot! .....
二、salt.modules.cron
1、添加计划任务
格式:
salt.modules.cron.set_job(user, minute, hour, daymonth, month, dayweek, cmd, comment=None,identifier=None)
参数说明:
user:用户;剩下的表示分、时、日、月、周、命令、任务描述信息
例子:
salt \* cron.set_job root '0' '03' '*' '*' '*' '/bin/bash /root/crontab/rsync_mysql_backup.sh' 'remote backup mysql data to xxxxxxx/backup/local_mysql_backup/ by king.gp'
说明:每一个参数项都要用引号括起来。
2、删除计划任务
格式:
salt.modules.cron.rm_job(user, cmd, minute=None, hour=None, daymonth=None, month=None,dayweek=None, identifier=None)
例子:
salt '*' -b 3 cron.rm_job root '/root/crontab/rsync_mysql_backup.sh'
三、添加计划任务states文件版本。
注:
-
要在salt-master端设置file_roots (略)
在file_roots指定的目录下创建top.sls文件
定义init.sls文件
1、我们第二步开始,file_roots设置top文件
[root@report /]# egrep -v "^$|^#" /etc/salt/master file_roots: base: - /home/sysadmin/yunwei - /home/sysadmin/yunwei/workspace
2、创建top.sls文件
[root@report workspace]# pwd /home/sysadmin/yunwei/workspace [root@report workspace]# cat top.sls base: "test-201": - install_python_ext - add_crontab_file
注:如果file_roots指向多个路径,salt则取它们的合集
3、定义init.sls文件
注:也是可以直接在top.sls的同级目录写sls文件的,但这样到后期要维护太多的文件,而且看上会会很乱,如果定义多级目录,就可在同名目录中写【init.sls】文件了
[root@report workspace]# cd add_crontab_file/ [root@report add_crontab_file]# pwd /home/sysadmin/yunwei/workspace/add_crontab_file [root@report add_crontab_file]# cat init.sls /root/crontab: file.directory: - user: root - group: root - mode: 755 - makedirs: True /root/crontab/clean_mail_local_mysql_history_data.sh: cron.present: - user: root - minute: 30 - hour: 23 - daymonth: 28 - comment: 'clean local mysql data info by king.gp' /root/crontab/Insert_Outgoing_Mail_Total.py: cron.present: - user: root - minute: 0 - hour: 23 - comment: 'mail outgoing total by king.gp' /root/crontab/rsync_mysql_backup.sh: cron.present: - user: root - minute: 0 - hour: 3 - comment: 'remote backup mysql data to 192.168.3.34/backup/local_mysql_backup/ by king.gp' /root/crontab/rsync_redis_backup.sh: cron.present: - user: root - minute: 0 - hour: '*/2' - comment: 'remote backup redis data to 192.168.3.37/archive/redis_backup/ by king.gp' /root/crontab/delete_mysql_rsyslog.sh: cron.present: - user: root - minute: 0 - hour: 1 - comment: 'del local mysql syslog data'
注:由于有一个脚本用python写的,还要安装一些python的扩展包
[root@report copy_crontab_file]# cd .. [root@report workspace]# cd install_python_ext/ [root@report install_python_ext]# pwd /home/sysadmin/yunwei/workspace/install_python_ext [root@report install_python_ext]# cat init.sls python_ext: pkg.installed: - pkgs: - python-setuptools - python-pip - MySQL-python
4、定义runner文件
[root@report workspace]# pwd /home/sysadmin/yunwei/workspace [root@report workspace]# cat cron_runner.sls python_ext: salt.state: - tgt: 'test-201' - highstate: True corn_exec: salt.state: - tgt: 'test-201' - highstate: True - require: - salt: python_ext
5、测试runner文件
[root@report workspace]# salt-run state.orchestrate cron_runner test=Ture report.chinadns.net_master: ---------- ID: python_ext Function: salt.state Result: True Comment: States ran successfully. No changes made to test-201. Started: 18:00:13.372399 Duration: 8079.834 ms Changes: ---------- ID: corn_exec Function: salt.state Result: True Comment: States ran successfully. No changes made to test-201. Started: 18:00:21.452916 Duration: 8101.168 ms Changes: Summary ------------ Succeeded: 2 Failed: 0 ------------ Total states run: 2
注:此处我是先将计划任务的目录拷贝到test-201上
salt 'test-201' cp.get_file salt://crontab /root makedirs=True
6、执行定义好的runner文件
[root@report workspace]# salt-run state.orchestrate cron_runner report.chinadns.net_master: ---------- ID: python_ext Function: salt.state Result: True Comment: States ran successfully. No changes made to test-201. Started: 18:03:39.272417 Duration: 8305.688 ms Changes: ---------- ID: corn_exec Function: salt.state Result: True Comment: States ran successfully. No changes made to test-201. Started: 18:03:47.578834 Duration: 8102.33 ms Changes: Summary ------------ Succeeded: 2 Failed: 0 ------------ Total states run: 2
7、查看结果
[root@report workspace]# salt 'test-201' cron.ls root test-201: ---------- crons: |_ ---------- cmd: /root/crontab/clean_mail_local_mysql_history_data.sh comment: clean local mysql data info by king.gp daymonth: 28 dayweek: * hour: 23 identifier: /root/crontab/clean_mail_local_mysql_history_data.sh minute: 30 month: * |_ ---------- cmd: /root/crontab/Insert_Outgoing_Mail_Total.py comment: mail outgoing total by king.gp daymonth: * dayweek: * hour: 23 identifier: /root/crontab/Insert_Outgoing_Mail_Total.py minute: 0 month: * |_ ---------- cmd: /root/crontab/rsync_mysql_backup.sh comment: remote backup mysql data to 192.168.3.37/backup/local_mysql_backup/ by king.gp daymonth: * dayweek: * hour: 3 identifier: /root/crontab/rsync_mysql_backup.sh minute: 0 month: * |_ ---------- cmd: /root/crontab/rsync_redis_backup.sh comment: remote backup redis data to 192.168.3.34/archive/redis_backup/ by king.gp daymonth: * dayweek: * hour: */2 identifier: /root/crontab/rsync_redis_backup.sh minute: 0 month: * |_ ---------- cmd: /root/crontab/delete_mysql_rsyslog.sh comment: del local mysql syslog data daymonth: * dayweek: * hour: 1 identifier: /root/crontab/delete_mysql_rsyslog.sh minute: 0 month: * env: pre: special:
注:最通用的还是写piller,但现在我还是用不明白,就不丢人了!
四、总结
1、多看文档,多总结;【E文没过级,but我有×××】
2、如果别人发现你用方法很蠢,请接受;
3、多动手。【能打就不要吵】