1.帮助文档

以cmd函数为例子说下salt中的一些帮助信息

# 查看指定modules用法
salt '*' sys.doc cmd # 查看所有的modules列表
salt '*' sys.list_modules # 查看模块下的方法
salt '*' sys.list_functions cmd # 查看所有states列表
salt '*' sys.list_state_modules # 查看指定state的所有functions
salt '*' sys.list_state_functions # 查看指定states的用法
salt '*' sys.state_doc cmd # 查看指定states指定function用法
salt '*' sys.state_doc cmd.run

2.准备工作

一台master(192.168.111.128)

两台minion(192.168.111.129,192.168.111.133)

minion需要配置/etc/salt/minion中的id(为minion ID)和master(设置为master地址)

1.加入认证列表

[root@master salt]# salt-key -L
Accepted Keys:
Denied Keys:
Unaccepted Keys:
Centos
Ubuntu
Rejected Keys:
[root@master salt]# salt-key -A -y
The following keys are going to be accepted:
Unaccepted Keys:
Centos
Ubuntu
Key for minion Centos accepted.
Key for minion Ubuntu accepted.

2.测试是否可以远程操作

[root@master salt]# salt '*' test.ping # 测试服务器是否联通
Centos:
True
Ubuntu:
True

2.state.sls文件入门

salt默认的管理目录为/srv/salt,在这里我们改为了/base/salt(在master的/etc/salt/master中修改file_roots)

看下/base/salt中的文件结构

├── foo.conf  # 配置文件(需要下发到minion)
├── one
│   └── init.sls
├── three
│   └── init.sls
├── top.sls
└── tow
└── init.sls

在看下各个文件里的内容

[root@master salt]# cat top.sls
base: # base环境
'*':
- one # 执行one.sls或者one下的init.sls
'Centos':
- tow # 执行tow.;sls或者tow下的init.sls
'Ubuntu':
- three # 执行three.sls或者three下的init.sls
[root@master salt]# cat one/init.sls
/tmp/foo.conf: # 如果为指定name参数,这name的参数为这个
file.managed: # 上传文件
- source: salt://foo.conf # 源地址为/base/salt下(salt://表示在master配置文件中配置的地址)
- user: root
- group: root
- mode: 777
#- name: /tmp/foo.conf # 或在这里定义name并赋值
[root@master salt]# cat tow/init.sls
show_ip:
cmd.run: # 远程执行命令的函数
- name: ifconfig
[root@master salt]# cat three/init.sls
show_file:
cmd.run:
- name: cat /tmp/foo.conf
[root@master salt]#

3.关于sls文件的说明

一,普通的state文件说明:

  1.state文件的编写时YAML语法(后面会介绍YAML的具体规则)

  2.文件的执行使用state.sls

salt '*' state.sls one  # 默认找到/base/salt下的one.sls,如果没有找one/init.sls,如果在没有则报错

二,top.sls文件说明:

  1.top.sls文件不是必须的。

  2.top.sls入口文件可以同时对多台机器进行一个简单的配置管理。

  3.运行top.sls文件使用state.highstate。

salt '*' state.highstate

4.执行结果处理(redis)

Teturn是在Master端触发任务,然后Minion接受处理任务后直接与Return存储服务器建立连接

Return组件可以理解为salt的执行结果返回存储或者返回给其他程序,可以对salt的操作进行记录。

查看所有的Return列表

salt '*' sys.list_returners

下面我来演示下把执行结果返回到redis中

一,环境配置

  1.在所有的minion端安装pip,通过pip安装python的redis模块。

  2.所有的minion端配置文件中添加以下内容(Return 数据库信息)

redis.db: '0'
redis.host: '127.0.0.1' # 这里的主机为192.168.111.131
redis.port: 6379

二,安装redis并配置

  3.在192.168.111.129上用yum安装redis数据库,并配置redis地址

yum install redis
sed -i -e 's@^bind 127.0.0.1@bind 192.168.111.129@g' /etc/redis.conf

三,信息的查看

  4.在redis上查看信息

redis-cli -h 192.168.111.129 monitor  # 动态查看数据库信息
redis-cli -h 192.168.111.129 # 连接数据库查询

四,执行命令

[root@master jobs]# salt '*' test.ping
Centos:
True
Ubuntu:
True
# 此时去redis服务器就可以查看job的信息了。

4.Job管理

在salt里执行任何一个操作都会在master上产生一个jid号,minion端在/var/cache/salt/minion/proc目录下创建一个以jid号码为名称的文件,文件内是此次操作的记录,操作处理完成后改文件会自动删除。而master端会记录每次操作的详细信息,这个记录保存到/var/cache/salt/master/jobs目录下两位16进制数组成的目录名下。

一,salt-run jobs管理

下面列除salt-run中jobs的用法:

[root@master jobs]# salt-run -d | grep jobs
'jobs.active:' # 查看正在运行的jobs
Return a report on all actively running jobs from a job id centric
salt-run jobs.active
'jobs.list_job:' # 指定jid查看jobs详细信息
salt-run jobs.list_job 20130916125524463507
'jobs.list_jobs:' # 查看所有jobs信息
List all detectable jobs and associated functions
salt-run jobs.list_jobs
'jobs.lookup_jid:' # 指定jid查询jobs结果
salt-run jobs.lookup_jid 20130916125524463507
salt-run jobs.lookup_jid 20130916125524463507 outputter=highstate
'jobs.print_job:' # 指定jid查询jobs详细信息
salt-run jobs.print_job 20130916125524463507

二,通过saltutil模块管理job

salt-run不支持kill某个job,所有使用saltutil模块管理job

先来看看saltutil模块的使用:

[root@master jobs]# salt \* sys.doc saltutil | grep job
'saltutil.find_cached_job:' # 查询job cache信息
Return the data for a specific cached job id
salt '*' saltutil.find_cached_job <job id>
'saltutil.find_job:' # 指定jid查看job信息
Return the data for a specific job id
salt '*' saltutil.find_job <job id>
'saltutil.kill_job:' # 杀掉job(发送SIGTERM 9信号方式)
Sends a kill signal (SIGKILL 9) to the named salt job's process
salt '*' saltutil.kill_job <job id>
salt '*' saltutil.runner jobs.list_jobs
'saltutil.signal_job:' # 发送指定信号
Sends a signal to the named salt job's process
salt '*' saltutil.signal_job <job id> 15
'saltutil.term_job:' # 删掉job(发送SIGTERM 15信号方式)
Sends a termination signal (SIGTERM 15) to the named salt job's process
salt '*' saltutil.term_job <job id>

salt基本使用之一(1)的更多相关文章

  1. C# salt+hash 加密

    一.先明确几个基本概念 1.伪随机数:pseudo-random number generators ,简称为:PRNGs,是计算机利用一定的算法来产生的.伪随机数并不是假随机 数,这里的" ...

  2. 密码学应用(DES,AES, MD5, SHA1, RSA, Salt, Pkcs8)

    目录 一.数据加密标准 - Data Encryption Standard(DES) 二.高级加密标准 - Advanced Encryption Standard(AES) 三.消息摘要算法第五版 ...

  3. salt源码安装软件和yum安装软件

    上面简单列出了源码安装的sls文件书写思路. 涉及到一些固定的思路:如, 1,拷贝 解压安装时候需要依赖tar.gz存在 如果已安装则无需再次安装. 2,启动脚本 加入chk时候需要文件存在,如果已添 ...

  4. Salt安装(yum不可用时)

        salt-master安装   [salt-master]# yum install salt-master   或者 curl -L http://bootstrap.saltstack.o ...

  5. Salt 安装方式(CentOS)

    安装前必备环境:2.6.6<Pythin<3.x 本文内容是参考 中国SaltStack用户组 里面 Salt中文手册 中的安装内容实践之后总结的. 初学者可用Ubuntu系统学习安装,因 ...

  6. 翻译-Salt与Ansible全方位比较

    原文链接:http://jensrantil.github.io/salt-vs-ansible.html 作者: Jens Rantil 之前某些时候我需要评估配置管理系统.结合从他人得到的意见,我 ...

  7. salt基本原理

            转载自: 来自:http://tech.mainwise.cn/?p=438     说明:salt是一个异构平台基础设置管理工具(虽然我们通常只用在Linux上),使用轻量级的通讯器 ...

  8. ecshop 重置后台密码 MD5+salt

    ecshop密码加密方式: MD5 32位+salt,简单来说就是明文密码用MD5加密一次,然后在得到的MD5字符后边加上salt字段值(salt值为系统随机生成,生成以后不再改变)再进行一次MD5加 ...

  9. salt stack 工具之一——远程命令

    salt stack 远程命令 salt stack是一种自动化的运维工具,可以同时对N台服务器进行配置管理.远程命令执行等操作. salt stack分为两个部分: salt-master,部署在控 ...

  10. saltstack/salt的state.sls的使用

    SLS(代表SaLt State文件)是Salt State系统的核心.SLS描述了系统的目标状态,由格式简单的数据构成.这经常被称作配置管理 首先,在master上面定义salt的主目录,默认是在/ ...

随机推荐

  1. 关于java中的数组

    前言:最近刚刚看完了<Java编程思想>中关于数组的一章,所有关于Java数组的知识,应该算是了解的差不多了.在此再梳理一遍,以便以后遇到模糊的知识,方便查阅. Java中持有对象的方式, ...

  2. openlayers调用瓦片地图分析

    网上有诸多资料介绍openlayers如何调用百度地图或者是天地图等常见互联网地图,本文作者使用的是不是常见的互联网瓦片,现将调用过程进行整理与大家分享. 首先,openlayers就不赘述了(官网: ...

  3. python实现维吉尼亚解密

    # -*-coding:UTF-8-*- from sys import stdout miwen = "KCCPKBGUFDPHQTYAVINRRTMVGRKDNBVFDETDGILTXR ...

  4. SQL SERVER 字符串按数字排序

    需求是这样的: 数据库表里面有一个字段类型是nvachar,存的值是数字和字符混合的,要实现先按数字排序,再按字母倒序. 思路: 考虑这个字段的值是否是有规律可循的,把要按数字排序的部分转换为数字,再 ...

  5. Hadoop完全分布式安装教程

    一.软件版本 Hadoop版本号:hadoop-2.6.0.tar: VMWare版本号:VMware-workstation-full-11.0.0-2305329 Ubuntu版本号:ubuntu ...

  6. Andrew Ng机器学习第一章——初识机器学习

    机器学习的定义 计算机程序从经验E中学习,解决某一任务T.进行某一性能度量P,通过P测定在T上的表现因E而提高. 简而言之:程序通过多次执行之后获得学习经验,利用这些经验可以使得程序的输出结果更为理想 ...

  7. OAuth2.0学习(1-8) 授权方式五之Access_Token令牌过期更新

    OAuth2.0的Access_Token令牌过期更新 如果用户访问的时候,客户端的"访问令牌"已经过期,则需要使用"更新令牌"申请一个新的访问令牌. 客户端发 ...

  8. IDE-Android Studio -FAQ-使用习惯(不断更新 欢迎留言)

    摘要: 从ecplise工具切换到android studio后遇到了很多问题,起初亦非常痛苦,城墙内外阅博无数才得以解决.所以把当时遇到的问题记录下来,方便后来人学习. 另如果有遇到未纪录的问题欢迎 ...

  9. python/零起点(一、字典)

    python/零起点(一.字典) dict( )字典 dict()强型转换成字典类型的数据类型: 字典的键(Key)必须是唯一不可变的 字典是无序,字典可变数据类型,且是可迭代的对象 字典清空操作案例 ...

  10. django Form组件

    django Form组件 Django的Form主要具有一下几大功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显示内容 小试牛刀 1.创建 ...