Salt-ssh批量自动安装被控端salt-mini
Salt-ssh是Saltstack的另外一种管理方式,无需安装minion端,可以运行salt的一切功能,管理和使用方法基本和salt一样。但是,salt-ssh并没有继承原来的ZeroMQ通讯架构。所以,她的执行速度比较慢,作为salt的补充在初次批量安装minion或某些不能安装minion的特殊场景下还是非常好用的。
环境配置说明:
| Hostname | IP地址 | 节点 | 服务 |
| salt-master | 10.10.100.127 | master | salt-ssh |
| salt-client01 | 10.10.100.8 | minion | salt-minion |
| salt-client02 | 10.10.100.148 | minion | salt-minion |
客户端在/etc/hosts文件中写入主机名和ip的映射关系:
echo "10.10.100.8 salt-client01" >> /etc/hosts
echo "10.10.100.148 salt-client02" >> /etc/hosts
1.安装salt-ssh(在salt-master端安装)
yum -y install salt-ssh
2.配置/etc/salt/roster,所有需要安装被控端的主机信息,都在这里配置和定义。
[root@salt-master ~]# vim /etc/salt/roster # Sample salt-ssh config file
#
10.10.100.8:
host: 10.10.100.8
user: root
passwd: 1q2w3e4r5t--==
port: 22
timeout: 10
10.10.100.148:
host: 10.10.100.148
user: guest
passwd: 1q2w3e4r5t--==
sudo: True
port: 22
timeout: 10
3.编写state.sls文件
1>.创建目录
mkdir /etc/salt/states/minions/conf #存放统一管理minion端的配置文件信息
mkdir /etc/salt/states/minions/yum.repos.d #yum源的配置信息 路径:/etc/salt/states/minion
目录树结构如下: [root@Testa-www minions]# tree
.
├── conf
│?? └── minion
├── install.sls
└── yum.repos.d
├── CentOS6-Base-163.repo
└── epel.repo 2 directories, 4 files
2>.编写vim /etc/salt/states/minions/install.sls文件
#salt_minion_install
minion_yum: #配置yum源信息
file.recurse:
- name: /etc/yum.repos.d
- source: salt://minions/yum.repos.d
- user: root
- group: root
- file_mode: 644
- dir_mode: 755
- include_empty: True
minion_install: #安装salt-minion
pkg.installed:
- pkgs:
- salt-minion
- require:
- file: minion_yum
- unless: rpm -qa | grep salt-minion
minion_conf: #minion配置文件信息
file.managed:
- name: /etc/salt/minion
- source: salt://minions/conf/minion
- user: root
- group: root
- mode: 640
- template: jinja
- defaults:
minion_id: {{ grains['fqdn_ip4'][0] }} #要求客户端/etc/hosts中绑定其IP及主机名,不绑定主机名在127.0.0.1下
- require:
- pkg: minion_install
minion_service: #服务状态
service.running:
- name: salt-minion
- enable: True
- require:
- file: minion_conf
3.>修改/etc/salt/states/minions/conf/minion文件如下两行:
master: 10.10.100.127 #master端IP
id: {{ minion_id }} #jinja格式
4.>定义vim /etc/salt/states/top.sls文件。
base:
'*': #主机信息
- minions.instal #执行minions目录下的install.sls文件
最终目录结构如下:
路径:/etc/salt/states
[root@salt-master states]# tree
.
├── minions
│?? ├── conf
│?? │?? └── minion
│?? ├── install.sls
│?? └── yum.repos.d
│?? ├── CentOS6-Base-163.repo
│?? └── epel.repo
└── top.sls 3 directories, 5 files
4.部署salt-minion
salt-ssh端执行如下命令:
salt-ssh -i '*' test.ping #测试主机连通性,如果没问题执行下面的命令
salt-ssh -i '*' state.sls minions.install
5.验证结果:
[root@salt-master ~]# salt-ssh -ir '*' 'ps aux | grep salt' |grep salt |grep -v grep |wc -l
2
参考文档:https://www.sudops.com/you-must-have-a-tty-to-run-sudo.html
http://www.cnblogs.com/jim-hwg/p/4952418.html
http://blog.csdn.net/hnhuangyiyang/article/details/50421422#
Salt-ssh批量自动安装被控端salt-mini的更多相关文章
- 自动化运维之-PXE实现系统批量自动安装
转自:https://www.linuxidc.com/Linux/2017-10/147379.htm 本节索引 需求分析 PXE简介 整体方案 服务选择 功能实现 安装调试 错误分析 总结 1 需 ...
- s32 kickstart 批量自动安装系统
1. 自动安装操作系统 http://blog.oldboyedu.com/autoinstall-kickstart/ 自动安装操作系统的解决方案:kickstart.cobbler(披着web ...
- 自动安装Redis服务端与PHP扩展Redis
该脚本基于阿里云服务器安装脚本,并只能运用于centos / aliyun os,该脚本使用时,需要与阿里云安装脚本的install.sh放在同一目录下.有缘人切忌乱用: #! /bin/bash # ...
- 自动安装memcached服务端与PHP扩展Memcached
该脚本基于阿里云服务器安装脚本,并只能运用于centos / aliyun os,该脚本使用时,需要与阿里云安装脚本的install.sh放在同一目录下.有缘人切忌乱用: #! /bin/bash # ...
- 电脑用bat脚本给手机批量自动安装apk文件 autoInstall.bat
------创建这个文件autoInstall.bat 内容如下: @ECHO off @REM 将adb.exe添加到PATH中ECHO 初始化…@SET PATH=%PATH%;%CD%\Adb@ ...
- Linux部署之批量自动安装系统之测试篇
1. 客户端从网络启动如下 2. 复制vesamenu.c32文件可解决上面的问题 3. 客户端再次启动 4. 选择第一个进 ...
- Linux部署之批量自动安装系统之Kickstart篇
1. 安装 2. 在桌面环境下啊配置 3. Kickstart之基本配置 4. Kickstart之安装方法 5. ...
- Linux部署之批量自动安装系统之TFTP篇
1. 安装:yum install tftp-server –y 2. 配置tftp文件开启tftp功能 3. 开启依赖服务xinetd 4 ...
- Linux部署之批量自动安装系统之DHCP篇
1. 安装:yum install dhcp 2. Ip配置信息 3. Dhcp配置文件如下 4. 配置完后检查语法是否错误 ...
随机推荐
- 【Ubuntu】VirtualBox 您没有查看“sf_VirtualDisk”的内容所需的权限。
转自:https://www.cnblogs.com/laishenghao/p/5346651.html 最终解决办法: sudo adduser lqr vboxsf 这里lqr是我的用户名 然后 ...
- LeetCode: Linked List Cycle II 解题报告
Linked List Cycle II Given a linked list, return the node where the cycle begins. If there is no cyc ...
- (精品)微信支付android端
PayingActivity.java public void WxPay(){ // new Thread(new Runnable() { // @Override // public void ...
- Kafka vs RocketMQ——单机系统可靠性
引言 前几期的评测中,我们对比了Kafka和RocketMQ的吞吐量和稳定性,本期我们要引入一个新的评测标准——软件可靠性. 何为“可靠性”? 先看下面这种情况:有A,B两辆越野汽车,在城市的周边地区 ...
- Pandas.plot 做图 demo(scatter,bar,pie)
#coding:utf-8import numpy as npimport matplotlib.pyplot as pltplt.rcParams['font.sans-serif']=['SimH ...
- Oracle 物理视图刷新报错ORA-00942
原因:物化视图调用的主表没有主键,物化视图创建默认以主键创建(with primarykey),改为用with rowid创建即可.
- vi/vim 中如何在每行行首或行尾插入指定字符串
行首 :%s/^/your_word/ 行尾 :%s/$/your_word/ 按键操作: 注释:ctrl+v 进入列编辑模式,向下或向上移动光标,把需要注释的行的开头标记起来,然后按大写的I,再插入 ...
- [uart]设置linux 串口的block方式
1. 如果设置为非block模式: open(device, O_RDWR | O_NDELAY | O_NONBLOCK); 2. 如果设置为block模式,且读固定字节数返回则termios.c_ ...
- redis关闭/重启服务器
通过docker实现: 一.创建redis服务器与客户端 docker run -p : -d --name redis-server docker.io/redis: redis-server -- ...
- valgrind--CPP程序内存泄露检查工具
内存泄漏是c++程序常见的问题了,特别是服务类程序,当系统模块过多或者逻辑复杂后,很难通过代码看出内存泄漏. valgrind是一个开源的,检测c++程序内存泄漏有效工具,编译时加上-g选项可以定位到 ...