菜鸟玩云计算之二十:saltstack入门初步
菜鸟玩云计算之二十
SaltStack 入门初步
0. saltstack 是什么
参考下面的文章:
http://docs.saltstack.com/en/latest/topics/tutorials/walkthrough.html
Salt Stack 初探 之 另外一种用 Python 写的配置管理系统
http://www.mamicode.com/info-detail-461069.html
saltstack这货居然是用python2.6写的,费了好大的劲,才弄出来用python调用它.首先安装好salt-master(或者salt-minion),然后输入下面的命令:
# python2.6
>>> import salt.config
没有错误. 那么接下来就可以用python调用salt的api干活了.
0.1 salt-key 管理
master上执行:
# 列出所有key
# salt-key -L
# 接受所有key
# salt-key -A
# 验证并接受指定minion的key
# salt-key -f '202'
202: fd:c3:43:22:df:14:7e:b9:1e:cd:be:9a:fc:62:17:7c
在minion id: 202上执行:
# salt-call key.finger --local
local:
fd:c3:43:22:df:14:7e:b9:1e:cd:be:9a:fc:62:17:7c
在master上接受202的key:
# salt-key -a '202'
0.2 发送命令
## 测试命令
# salt '*' test.ping
## 打印磁盘使用
# salt '*' disk.usage
## 打印帮助文档
# salt '*' sys.doc
## 执行ls命令
# salt '*' cmd.run 'ls -l /etc'
## 显示minion的网络信息:
# salt '*' network.interfaces
0.3 安装软件包
salt 会调用合适的包管理工具执行软件包的安装(如yum和apt):
# salt '*' pkg.install ${pkgname}
如(节点必须配置好yum源):
# salt '*' pkg.install hadoop-lzo
1. 同步文件
slatsatck用于同步master上的配置文件到minion节点,首先在master上增加设置:
# mkdir -p /srv/salt/dev/services /srv/salt/dev/states /srv/salt/prod/services /srv/salt/prod/services # mkdir /etc/salt/master.d/ # vi fileserver.conf # service salt-master restart
fileserver.conf内容如下:
#### fileserver.conf
# Salt runs a lightweight file server written in zeromq to deliver files to
# minions. This file server is built into the master daemon and does not
# require a dedicated port.
file_roots:
base:
- /srv/salt/
dev:
- /srv/salt/dev/services
- /srv/salt/dev/states
prod:
- /srv/salt/prod/services
- /srv/salt/prod/states
假设在master: /srv/salt/下创建了文件: first.xml, 使用下面的命令可以实现文件first.xml下发到所有minions的/tmp下面:
# salt ‘*‘ cp.get_file salt://first.xml /tmp/first.xml 或 gzip=1-9,数字越大,压缩越高; makedirs=True 自动创建目录 # salt ‘*‘ cp.get_file salt://first.xml /tmp/salt/first.xml gzip=9 makedirs=True
这样我们就可以用脚本灵活控制服务器端(master)的配置文件的分发。
2. 目录同步
cp.get_dir,get_dir与get_file的用法十分相似,用来将整个目录分发到minions. 本例在master的/srv/salt下创建目录和文件:
/srv/salt/hadoop_conf_dir/hadoop.config, 同步到所有minion节点的/tmp/hacl_conf下面, 如果目录不存在则创建,使用压缩
# salt ‘*‘ cp.get_dir salt://hadoop_conf_dir /tmp/hacl_conf gzip=9 makedirs=True
这样,minion上为:
/tmp/hacl_conf/hadoop_conf_dir/hadoop.config
3. grains
1) grains的作用是在minion端的服务启动时,调用这个接口,收集minion端的信息,这些信息数据可以在salt的其他模块中直接使用,需要注意的是,这个接口只在minion端的minion服务启动时被调用一次,所以收集的数据是静态的,不会改变的,除非你重启了minion端的服务. 在master上执行下面的命令(202是minion节点id)收集minion端的信息:
# salt '202' grains.ls
显示:
- SSDs
- biosreleasedate
- biosversion
- cpu_flags
- cpu_model
- cpuarch
- domain
- fqdn
- fqdn_ip4
...
2) 使用grains.items模块列出所有可用grains的具体数据:
# salt '202' grains.items
3) 查看所有节点的IP地址:
# salt ‘*‘ grains.item ipv4 # NOT grains.items
4) 查看202的os版本:
# salt ‘202‘ grains.item os
4. 自定义grains_module
所有操作都是在master上运行!
4.1 写模块/srv/salt/_grains/${module_name}.py
自定义的grains_module存放在/srv/salt/_grains目录,下面定义一个获取max_open_file的grains:
# vi /srv/salt/_grains/max_open_file.py # chmod a+x /srv/salt/_grains/max_open_file.py
max_open_file.py内容如下:
#!/usr/bin/python2.6
#-*- coding: UTF-8 -*-
# cheungmine
import os,sys,commands
def Grains():
grains = {}
max_open_file=65536
try:
getulimit=commands.getstatusoutput('source /etc/profile;ulimit -n')
except Exception,e:
pass
if getulimit[0]==0:
max_open_file=int(getulimit[1])
grains['max_open_file'] = max_open_file
return grains
4.2 同步grains模块
## 到所有节点 # salt '*' saltutil.sync_all ## 到指定minion id的节点 ## salt '202' saltutil.sync_all
得到显示:
203:
----------
grains:
- grains.max_open_file
modules:
outputters:
renderers:
returners:
states:
utils:
202:
----------
grains:
- grains.max_open_file
modules:
outputters:
renderers:
returners:
states:
utils:
4.3 刷新模块(让minion编译模块)
# salt '*' sys.reload_modules 或 #### salt '202' sys.reload_modules
203:
True
202:
True
4.4 验证max_open_file
$ salt '*' grains.item max_open_file
203:
----------
max_open_file:
1024
202:
----------
max_open_file:
1024
5. 自定义module
存放在/srv/salt/_modules下面. 写一个测试的module: /srv/salt/_modules/nodejs.py, 内容如下:
#!/usr/bin/python2.6
#-*- coding: UTF-8 -*-
#
def status(cmd):
ret = {}
ret['Cmd'] = cmd
ret['Msg'] = "Good-Bye"
ret['Result'] = True
return ret
提交到所有minions(虚拟机上时间比较长):
# chmod a+x ./nodejs.py # salt '*' saltutil.sync_all # salt '*' sys.reload_modules
203:
----------
grains:
modules:
- modules.nodejs
outputters:
renderers:
returners:
states:
utils:
202:
----------
grains:
modules:
- modules.nodejs
outputters:
renderers:
returners:
states:
utils:
执行:
# salt '*' nodejs.status "hello"
203:
----------
Cmd:
hello
Msg:
Good-Bye
Result:
True
202:
----------
Cmd:
hello
Msg:
Good-Bye
Result:
True
菜鸟玩云计算之二十:saltstack入门初步的更多相关文章
- 菜鸟玩云计算之十二:KVM虚拟机更改大小
菜鸟玩云计算之十二:KVM虚拟机更改大小 参考: http://www.missionfamilybank.org/expanding-resizing-your-qcow2-virtual-mach ...
- 菜鸟玩云计算之十六:Ubuntu14.04上创建的虚拟机迁移到RHEL6.4
菜鸟玩云计算之十六:Ubuntu14.04上创建的RHEL6.4虚拟机迁移到RHEL6.4主机上 RHEL6.4 Server作为虚拟机的HOST,执行以下的命令检查配置和安装相关软件: # egre ...
- 菜鸟玩云计算之十四:克隆虚拟机及ssh登录的问题
菜鸟玩云计算之十四:克隆虚拟机及ssh登录的问题 今天早上,我的Ubuntu12.04.3LTS Desktop提示升级,升级. 从vm-ubuntu12.04克隆出虚拟机vm-thrift: $ s ...
- 菜鸟玩云计算之廿二: saltstack 配置
菜鸟玩云计算之廿二: saltstack 配置 要求环境: RHEL6.4+ >=Python2.6.6, < Python 3.0 关闭salt-master/minion服务: # ...
- 菜鸟玩云计算之廿一: saltstack之pillar
菜鸟玩云计算之廿一: saltstack之pillar 参考: 点击打开链接 查看pillar数据: # salt '*' pillar.items pillar的默认根目录在:/srv/pillar ...
- 菜鸟玩云计算之十五:在Ubuntu上创建和管理Redhat虚拟机
菜鸟玩云计算之十五:在Ubuntu上创建和管理Redhat虚拟机 chedou@hgdb.net 虚拟机给工作带来巨大的便利,不仅仅体现在资源的按需使用,而且配置的迁移特别方便.本文将使用Ubuntu ...
- 菜鸟玩云计算之十九:Hadoop 2.5.0 HA 集群安装第2章
菜鸟玩云计算之十九:Hadoop 2.5.0 HA 集群安装第2章 cheungmine, 2014-10-26 在上一章中,我们准备好了计算机和软件.本章开始部署hadoop 高可用集群. 2 部署 ...
- 菜鸟玩云计算之十八:Hadoop 2.5.0 HA 集群安装第1章
菜鸟玩云计算之十八:Hadoop 2.5.0 HA 集群安装第1章 cheungmine, 2014-10-25 0 引言 在生产环境上安装Hadoop高可用集群一直是一个需要极度耐心和体力的细致工作 ...
- 菜鸟玩云计算之十七:RHEL克隆虚拟机后改变网卡地址
菜鸟玩云计算之十七:RHEL克隆虚拟机后改变网卡地址 (一)更改hostname # vi /etc/sysconfig/network NETWORKING=yes HOSTNAME=your-vm ...
随机推荐
- Bootstrap3 概述
注意:HTML5 文档类型 Bootstrap 使用到的某些 HTML 元素和 CSS 属性需要将页面设置为 HTML5 文档类型.在你项目中的每个页面都要参照下面的格式进行设置. <!DOCT ...
- Playground中格式注释语法
类似于Ruby的ruby document,Xcode的Playground自身也提供一些嵌入文档中的格式注释的语法. 我们先定义一个简单的类: class A{ } 按住opt点击class A,你 ...
- 无需密码通过scp命令+key的方式实现文件传输
如果觉得scp每次都要输入密码很麻烦, 那么这是解决方案.假设你平时在windows上开发,用户名是xiang, 你有一台Ubuntu服务器wdksw.com, 用户名是root.现在你准备上传一些文 ...
- springmvc文件上传和拦截器
文件上传 用到这两个包 配置视图解析器:springmvc配置文件配置 <!-- id必须要是"multipartResolver" --> <bean id=& ...
- java操作xml文件--修改节点
上一篇文章我介绍了SAX方法解析XML文件的过程,这篇文章讲解的内容是利用DOM方法修改XML文件的节点内容. 下面依然是首先贴出XML文件: <?xml version ...
- Linux2.6 --系统调用处理程序
用户空间的程序无法直接执行内核代码.它们不能直接调用内核空间中的函数,因为内核驻留在受保护的地址空间上.如果进程可以直接在内核的地址空间上读写的话,系统的安全性和稳定性将不复存在. ...
- 最简单的基于librtmp的示例:接收(RTMP保存为FLV)
===================================================== 最简单的基于libRTMP的示例系列文章列表: 最简单的基于librtmp的示例:接收(RT ...
- (NO.00004)iOS实现打砖块游戏(十四):3球道具的实现
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;) 反弹棒变化道具实现前面已经介绍过了,我们下面可以在小球上做些文章 ...
- Android Studio科普篇——2.误区
1.删除一行是ctrl+x? 这是一个被谣传得很广泛的快捷键,但其实删除一行的快捷键不是ctrl+x,而是ctrl+y.ctrl+x在不选中内容的情况下,是剪切当前行,而ctrl+y才是删除当前行,它 ...
- Linux下使用gcc编程初体验
近期刚刚放弃了Windows,投入了Ubuntu 的怀抱.今天就拿一个小小的案例来做一下C语言的编译和运行流程.额,顺便说一句.本文适合那些Linux新手,不适合老鸟哈. 看完本文可以学到什么? 程序 ...