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. 配置完后检查语法是否错误 ...
随机推荐
- 【Android】安卓闪电复习
Intent An intent is an abstract description of an operation to be performed 一个Intent就是一次对将要执行的操作的抽象描 ...
- Docker 入门(Mac环境)-part 1 入门基本操作
part-1 入门基本操作 Docker 安装 去官网下载对应的版本,然后点击安装就可以了: 如果环境是Linux,可以参照之前写的get started教程 查看docker版本 docker -- ...
- Windows下搭建Android NDK开发环境及命令行编译
首先说明本文内的相关安装操作参考<Pro Android C++ with the NDK>一书. 安装 Windows搭建Android NDK开发环境需要安装如下部分(同时需要配置对应 ...
- js获取系统的根路径实现介绍
js如何获取系统的根路径,在本文给出了详细的方法 function getBasePath(){ var obj=window.location; var contextPath=obj.pathna ...
- uboot之第一阶段
U-boot的启动一般分为两个阶段,现在我们先将第一阶段. 在此之前,我们先了解一下uboot的目录结构,各个文件夹是什么作用. 如果连各个文件夹是干什么的都不清楚就开始移植剪裁,势必会和我刚拿到开发 ...
- c#中日期格式化
c#的日期格式化比较简单,在ToString中设置日期格式即可 DateTime.Now.ToLocalTime().ToString("yyyy_MM_dd_hh_mm_ss") ...
- 7. 集成学习(Ensemble Learning)Stacking
1. 集成学习(Ensemble Learning)原理 2. 集成学习(Ensemble Learning)Bagging 3. 集成学习(Ensemble Learning)随机森林(Random ...
- 基于HTML5手机登录注册表单代码
分享一款基于HTML5手机登录注册表单代码.这是一款鼠标点击注册登录按钮弹出表单,适合移动端使用.效果图如下: 在线预览 源码下载 实现的代码. html代码: <div class=&qu ...
- Spring框架中InitializingBean执行顺序
本文转自:https://www.cnblogs.com/yql1986/p/4084888.html package org.test.InitializingBean; 2 3 import or ...
- kafka demo
public static void main(String[] args) { Properties props = new Properties(); props.put("bootst ...