热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

salt之grains组件

grains是saltstack最重要的组件之一,作用是收集被控主机的基本信息,这些信息通常都是一些静态类的数据,包括CPU、内核、操作系

grains是saltstack最重要的组件之一,作用是收集被控主机的基本信息,这些信息通常都是一些静态类的数据,包括CPU、内核、操作系统、虚拟化等,在服务器端可以根据这些信息进行灵活定制,管理员可以利用这些信息对不同业务进行个性化配置。----其实类似于Ansible的Facts

grains常用操作命令:

salt '*' grains.ls   #获取主机的grains项信息(列出grains相关模块信息)

salt '*' grains.items   #获取主机的所有grains信息

salt '*' grains.item os  #获取主机单项grains数据

 

定义grains数据

方法有两种,其中一种为在被控主机定制配置文件,另一种是通过主控端扩展模块API实现,区别是模块更灵活,可以通过Python编程动态定义,而配置文件只适合相对固定的键与值。

1、被控端主机定制grains数据

ssh登录一台被控机,配置文件定制的路径为/etc/salt/minion,参数为default_include:minion.d/*.conf,具体操作如下:

vim /etc/salt/minion.d/hostinfo.conf

grains:

  roles:

    - webserver

    - memcache

  deployment: datacenter3

  cabinet: 13

重启被控主机salt-minion服务,使之生效。验证结果在主控端主机运行:salt 'myhost' grains.item roles deployment cabinet 查看结果应该如上。

2、主控端扩展模块定制grains数据

首先在主控端编写Python代码,然后将Python文件同步到被控主机即可生效。在主控端base目录/srv/salt下生成_grains目录,执行 install -d /srv/salt/_grains 开始编写代码,实现获取被控主机允许最大打开文件数的grains数据。

#vim /srv/salt/_grains/grains_openfile.py

import os,sys,commands
def grains_openfile():grains = {}_open_file=65533try:getulimit=commands.getstatusoutput('source /etc/profile;ulimit -n')except Exception,e:passif getulimit[0]==0:_open_file=int(getulimit[1])grains['max_open_file'] = _open_filereturn grains

  • grains_openfile()定义一个获取最大打开文件数的函数,函数名称没有要求,符合Python函数命名规则即可。
  • grains={} 初始化一个grains字典,变量名一定要用grains,以便saltstack识别
  • grains['max_open_file']=_open_file 将获取的Linux ulimit -n的结果值赋予grains['max_open_file'],其中"max_open_file"就是grains的项,_open_file就是grains的值。

在主控端同步模块:salt 'myhost' saltutil.sync_grains 或 salt 'myhost' saltutil.sync_all,此时文件已经同步到被控端主机以下目录中,如下:

/var/cache/salt/minion/extmods/grains/grains_openfile.py和grains_openfile.pyc

/var/cache/salt/minion/files/base/_grains/grains_openfile.py

/var/cache/salt/minion/extmods/grains/    为扩展模块文件最终存放位置,刷新模块后将在同路径下生成字节码pyc ;

/var/cache/salt/minion/files/base/_grains/ 为临时存放位置

在主控端进行校验,执行salt 'myhost' grains.item max_open_file

 ------------------------------------------------------------------

1、执行命令时,查找minion目标(targeting)常用有三种方式:

 salt ‘bash’ command         #根据bash形式匹配主机(如host1、host2)

 例:# salt 'host*' test.ping       

 salt –E ‘RE’ command          #--pcre,使用正则表达式匹配主机  

 例:# salt -E '(web|mysql)' test.ping  

 salt –N group command           #--nodegroup,使用分组匹配,前提已经做好分组

 例:# salt -N web test.ping

 salt –L ‘host1,host2’ command     #--list,根据主机名

 例:# salt -L 'host1,host2' test.ping

 salt -G 'os:CentOS' command        #--grains,根据grains获取的信息来查

 

 

参考文档:http://lizhenliang.blog.51cto.com/7876557/1638581

 

转:https://www.cnblogs.com/wjoyxt/p/5088032.html



推荐阅读
  • Django + Ansible 主机管理(有源码)
    本文给大家介绍如何利用DjangoAnsible进行Web项目管理。Django介绍一个可以使Web开发工作愉快并且高效的Web开发框架,能够以最小的代价构建和维护高 ... [详细]
  • Python脚本编写创建输出数据库并添加模型和场数据的方法
    本文介绍了使用Python脚本编写创建输出数据库并添加模型数据和场数据的方法。首先导入相应模块,然后创建输出数据库并添加材料属性、截面、部件实例、分析步和帧、节点和单元等对象。接着向输出数据库中添加场数据和历程数据,本例中只添加了节点位移。最后保存数据库文件并关闭文件。文章还提供了部分代码和Abaqus操作步骤。另外,作者还建立了关于Abaqus的学习交流群,欢迎加入并提问。 ... [详细]
  • python3.7 安装pip3_python3的pip3安装
    ---恢复内容开始---pip3的安装需要对应一整套python的编译工具库,所以安装好的pip3是这个样子:inearAi:~$pip3-Vpi ... [详细]
  • Python实现变声器功能(萝莉音御姐音)的方法及步骤
    本文介绍了使用Python实现变声器功能(萝莉音御姐音)的方法及步骤。首先登录百度AL开发平台,选择语音合成,创建应用并填写应用信息,获取Appid、API Key和Secret Key。然后安装pythonsdk,可以通过pip install baidu-aip或python setup.py install进行安装。最后,书写代码实现变声器功能,使用AipSpeech库进行语音合成,可以设置音量等参数。 ... [详细]
  • 展开全部下面的代码是创建一个立方体Thisexamplescreatesanddisplaysasimplebox.#Thefirstlineloadstheinit_disp ... [详细]
  • 如何在服务器主机上实现文件共享的方法和工具
    本文介绍了在服务器主机上实现文件共享的方法和工具,包括Linux主机和Windows主机的文件传输方式,Web运维和FTP/SFTP客户端运维两种方式,以及使用WinSCP工具将文件上传至Linux云服务器的操作方法。此外,还介绍了在迁移过程中需要安装迁移Agent并输入目的端服务器所在华为云的AK/SK,以及主机迁移服务会收集的源端服务器信息。 ... [详细]
  • Linux一键安装web环境全攻略
    摘自阿里云服务器官网,此处一键安装包下载:点此下载安装须知1、此安装包可在阿里云所有Linux系统上部署安装,此安装包包含的软件及版本为& ... [详细]
  • 一、Struts2是一个基于MVC设计模式的Web应用框架在MVC设计模式中,Struts2作为控制器(Controller)来建立模型与视图的数据交互。Struts2优点1、实现 ... [详细]
  • 对于一般的扩展包,我们一般直接pipinstallxxx即可安装,但是unrar直接安装后,发现并不能通过Python程序实现解压的功能& ... [详细]
  • 都说Python处理速度慢,为何月活7亿的 Instagram依然在使用Python?
    点击“Python编程与实战”,选择“置顶公众号”第一时间获取Python技术干货!来自|简书作者|我爱学python链接|https:www.jian ... [详细]
  • C++字符字符串处理及字符集编码方案
    本文介绍了C++中字符字符串处理的问题,并详细解释了字符集编码方案,包括UNICODE、Windows apps采用的UTF-16编码、ASCII、SBCS和DBCS编码方案。同时说明了ANSI C标准和Windows中的字符/字符串数据类型实现。文章还提到了在编译时需要定义UNICODE宏以支持unicode编码,否则将使用windows code page编译。最后,给出了相关的头文件和数据类型定义。 ... [详细]
  • iOS Swift中如何实现自动登录?
    本文介绍了在iOS Swift中如何实现自动登录的方法,包括使用故事板、SWRevealViewController等技术,以及解决用户注销后重新登录自动跳转到主页的问题。 ... [详细]
  • SpringBoot整合SpringSecurity+JWT实现单点登录
    SpringBoot整合SpringSecurity+JWT实现单点登录,Go语言社区,Golang程序员人脉社 ... [详细]
  • LVS实现负载均衡的原理LVS负载均衡负载均衡集群是LoadBalance集群。是一种将网络上的访问流量分布于各个节点,以降低服务器压力,更好的向客户端 ... [详细]
  • 0x00端口渗透端口扫描端口的指纹信息(版本信息)端口所对应运行的服务常见的默认端口号.尝试弱口令端口爆破hydra端口弱口令NTScanHs ... [详细]
author-avatar
lovely叫我龙哥
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有