作者:刘耀

QQ:22102107

一、目标(targeting Minions)

1.匹配Minions Id

匹配所有 (*)

[root@node1 salt]# salt '*' test.ping
node2.minion:
True

匹配后面是.minion的

[root@node1 salt]# salt '*.minion' test.ping
node2.minion:
True

匹配一个(?)

[root@node1 salt]# salt '*node?.minion' test.ping
node2.minion:
True

匹配多个[1-5]

[root@node1 salt]# salt 'node[1-5].minion' test.ping
node2.minion:
True

匹配某个主机和某个

[root@node1 salt]# salt 'node[2,3].minion' test.ping
node2.minion:
True

匹配a-z

[root@node1 salt]# salt 'node2.minio[n-z]' test.ping
node2.minion:
True

2.正则匹配:

-E

#匹配node2或者node3后面是.minion的主机
[root@node1 salt]# salt -E '(node2|node3).minion' test.ping
node2.minion:
True 可以在sls的配置文件里使用
修改
vim /etc/salt/states/top.sls
base:
#匹配node2或者node3后面是.minion的主机
'(node2|node3).minion':
#使用正则
- match: pcre
- init.pkg

-L

#匹配多个主机,逗号分隔
[root@node1 states]# salt -L 'node2.minion,node3,minion' test.ping
node2.minion:
True

-S ip地址匹配

salt -S '0.0.0.0/24' test.ping

二、模块

1.hosts模块

#获取IP地址
[root@node1 states]# salt '*' hosts.get_ip node2
node2.minion:
127.0.0.1

2.service模块

获取minion主机所有服务

[root@node1 states]# salt '*' service.get_all
node2.minion:
- abrt-ccpp
- abrt-oops
- abrtd
- acpid
- atd
- auditd
- blk-availability
- control-alt-delete
- crond
- cups
- elasticsearch
- exim
- halt
- htcacheclean
- httpd
- init-system-dbus
- ip6tables
- ipmi
- iptables
- irqbalance
- kexec-disable
- killall
- logstash
- lvm2-lvmetad
- lvm2-monitor
- messagebus
- netconsole
- netfs
- network
- ntpd
- ntpdate
- php-fpm
- plymouth-shutdown
- portreserve
- pptpd
- prefdm
- psacct
- quit-plymouth
- quota_nld
- rc
- rcS
- rcS-emergency
- rcS-sulogin
- rdisc
- readahead
- readahead-collector
- readahead-disable-services
- restorecond
- rsyslog
- salt-minion
- sandbox
- saslauthd
- serial
- shellinaboxd
- single
- smartd
- snmpd
- snmptrapd
- splash-manager
- sshd
- start-ttys
- svnserve
- sysstat
- tty
- ttyS0
- udev-post
- zabbix-agent
- zabbix-agentd
- zabbix_agentd
- zabbix_server 查看服务运行状态 [root@node1 states]# salt '*' service.status sshd
node2.minion:
True 重启某个服务 [root@node1 states]# salt '*' service.reload sshd
node2.minion:
True

3.salt-cp

root@node1 minions]# salt-cp '*' /etc/passwd /tmp/passwd
{'node2.minion': {'/tmp/passwd': True}}
[root@node1 minions]#

返回写入数据库

returners.mysql

默认情况下,发送给salt minion的命令执行结果将返回给salt master.

Saltstack Returner的接口允许将结果发送给任意系统

1.master端安装mysql

第一种:

源码包安装步骤省略

第二种:

yum install mysql-server -y

启动mysql服务

2.minion端部署MySQL-python

yum install MySQL-python

原理是minion把数据直接推到master的数据库中

3.在master端创建数据库

进入数据库

1.创建库名

CREATE DATABASE  `salt`
DEFAULT CHARACTER SET utf8
DEFAULT COLLATE utf8_general_ci; 2.创建jid表 USE `salt`; DROP TABLE IF EXISTS `jids`;
CREATE TABLE `jids` (
`jid` varchar(255) NOT NULL,
`load` mediumtext NOT NULL,
UNIQUE KEY `jid` (`jid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8; 3.创建return表 存放返回的数据 DROP TABLE IF EXISTS `salt_returns`;
CREATE TABLE `salt_returns` (
`fun` varchar(50) NOT NULL,
`jid` varchar(255) NOT NULL,
`return` mediumtext NOT NULL,
`id` varchar(255) NOT NULL,
`success` varchar(10) NOT NULL,
`full_ret` mediumtext NOT NULL,
`alter_time` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
KEY `id` (`id`),
KEY `jid` (`jid`),
KEY `fun` (`fun`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8; 4.创建事件表 DROP TABLE IF EXISTS `salt_events`;
CREATE TABLE `salt_events` (
`id` BIGINT NOT NULL AUTO_INCREMENT,
`tag` varchar(255) NOT NULL,
`data` mediumtext NOT NULL,
`alter_time` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
`master_id` varchar(255) NOT NULL,
PRIMARY KEY (`id`),
KEY `tag` (`tag`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8; 5.授权访问 grant all on salt.* to salt@'%' identified by 'salt'; 注:%不包括localhosts

4.在master里修改配置文件

# vi /etc/salt/master
在配置文件后面追加以下内容 mysql.host: '115.29.51.8'
mysql.user: 'salt'
mysql.pass: 'salt'
mysql.db: 'salt'
mysql.port: 3306

5.在minion里修改配置文件

# vi /etc/salt/minion
在配置文件后面追加以下内容 mysql.host: '115.29.51.8'
mysql.user: 'salt'
mysql.pass: 'salt'
mysql.db: 'salt'
mysql.port: 3306

6.master和minion端都重启服务

master端:

# service salt-master restart

minion端:

# /etc/init.d/salt-minion restart

7.测试

#salt '*' test.ping --return mysql
node2.minion:
True # salt '*' cmd.run 'df -TH' --return=mysql
node2.minion:
Filesystem Type Size Used Avail Use% Mounted on
/dev/vda1 ext3 8.5G 4.3G 3.8G 54% /

在数据库里查看

方法2:

如果每次执行不加--return=mysql
由master端将返回的数据写入数据库

1.修改master配置文件

# vi /etc/salt/master
在配置文件后面追加以下内容 master_job_cache: mysql

2.重启master

# service salt-master restart

3.测试

过程略

2.saltstack笔记之目标,模块,返回写入数据库的更多相关文章

  1. saltstack:使用教程之一安装及客户端返回写入MySQL

    saltstack使用教程: 1.安装: 需要epel的yum源,没有的话把下面的复制并新建个文件 /etc/yum.repos.d/epel.repo 粘贴即可: [epel] name=Extra ...

  2. 13.python笔记之pyyaml模块

    Date:2016-03-25 Title:13.Python笔记之Pyymal模块使用 Tags:Python Category:Python 博客地址:www.liuyao.me 作者:刘耀 YA ...

  3. Python标准库笔记(10) — itertools模块

    itertools 用于更高效地创建迭代器的函数工具. itertools 提供的功能受Clojure,Haskell,APL和SML等函数式编程语言的类似功能的启发.它们的目的是快速有效地使用内存, ...

  4. Python标准库笔记(8) — pprint模块

    struct模块提供了用于在字节字符串和Python原生数据类型之间转换函数,比如数字和字符串. Python版本: 2.x & 3.x 该模块作用是完成Python数值和C语言结构体的Pyt ...

  5. Python3学习笔记(urllib模块的使用)转http://www.cnblogs.com/Lands-ljk/p/5447127.html

    Python3学习笔记(urllib模块的使用)   1.基本方法 urllib.request.urlopen(url, data=None, [timeout, ]*, cafile=None,  ...

  6. python笔记之常用模块用法分析

    python笔记之常用模块用法分析 内置模块(不用import就可以直接使用) 常用内置函数 help(obj) 在线帮助, obj可是任何类型 callable(obj) 查看一个obj是不是可以像 ...

  7. python笔记之bisect模块

    python笔记之bisect模块 当你决定使用二分搜索时,这个模块会给你带来很大的帮助. 例子 import bisect L = [1,3,3,6,8,12,15] x = 3 #在L中查找x,x ...

  8. python笔记之itertools模块

    python笔记之itertools模块 itertools模块包含创建有效迭代器的函数,可以用各种方式对数据进行循环操作,此模块中的所有函数返回的迭代器都可以与for循环语句以及其他包含迭代器(如生 ...

  9. python笔记之ZipFile模块

    python笔记之ZipFile模块 zipfile模块用来做zip格式编码的压缩和解压缩的,zipfile里有两个非常重要的class, 分别是ZipFile和ZipInfo, 在绝大多数的情况下, ...

随机推荐

  1. 【CodeForces 602B】G - 一般水的题2-Approximating a Constant Range

    Description When Xellos was doing a practice course in university, he once had to measure the intens ...

  2. iOS之单例

    今天在看多线程同步时,突然想到了单例的同步问题.自从dispatch_once出现后,我们创建单例非常简单且安全: static dispatch_once_t pred; static Single ...

  3. BIEE 创建一个简单的分析(2)

    步骤: 1.如果BIEE安装在本机,直接登录http://localhost:9704/analytics/ 点击右上方导航菜单中的“新建->分析” 2.选择上节创建的RPD文件中的SCOTT主 ...

  4. 15.Android中LinearLayout布局一些小记录

    在App中,我们经常看到布局中会有分割线,直接上代码: <?xml version="1.0" encoding="utf-8"?> <Lin ...

  5. Linux Cache Mechanism Summary(undone)

    目录 . 缓存机制简介 . 内核缓存机制 . 内存缓存机制 . 文件缓存机制 . 数据库缓存机制 1. 缓存机制简介 0x1: 什么是缓存cache 在计算机整个领域中,缓存(cache)这个词是一个 ...

  6. C语言学习-01第一个C语言程序

    一 C语言的历史 C语言是一门通用计算机编程语言,应用广泛.C语言的设计目标是提供一种能以简易的方式编译.处理低级存储器.产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言. 尽管C语言提供 ...

  7. 修改host

    需修改手机/etc/hosts文件.将” 118.194.60.190 域名” 添加 手机的/etc/hosts文件.手机需有root权限,操作如下:1. C:\Documents and Setti ...

  8. 实现SVN与WEB同步解决方案(转)

    实现SVN与WEB同步解决方案 1)设置WEB服务器根目录为/www/default 2)checkout一份SVN svn co svn://localhost/oplinux /www/defau ...

  9. javascript常量

    javascript中没有常量的概念,虽然许多现代的变成环境可能为您提供了用以创建常量的const语句.对于的自己的变量,可以采用相同的命名约定,并且将他们以静态属性的方式添加到构造函数中. //构造 ...

  10. 一步一步教你将普通的wifi路由器变为智能广告路由器

    一步一步教你将普通的wifi路由器变为智能广告路由器 相信大家对WiFi智能广告路由器已经不再陌生了,现在很多公共WiFi上网,都需要登录并且验证,这也就是WiFi广告路由器的最重要的功能.大致就是下 ...