11、ssh自动化脚本编写
11.1、如何一键自动化安装50台规模集群网站搭建:
1、自动化思路:
kickstart无人值守安装linux系统(自动创建用户、密码、优化);
分发机上创建秘钥对、批量发走公钥(expect);
写部署及优化脚本、批量发到各个服务器上,远程执行安装;
2、高级架构师:
cobbler无人值守安装linux系统(自动创建用户、密码、优化,saltstack客户端)
服务端satl上创建认证,写配置来批量安装管理各个节点服务器应用
kvm虚拟化、根据不同的业务提前做好镜像,linux基础优化,saltstack客户端
通过云计算工具openstack管理镜像,批量生成虚拟机
3、自动化运维:
需求分析 cdn;
机房设备上下架;
虚拟机:弹性、扩展性、充分利用资源;
系统初始化;
应用环境初始化;
应用的部署 调试 配置;
代码发布;
服务监控 应用 (系统cpu、硬盘、内存);
数据备份;
4、自动化发展的阶段:
环境的统一;
标准化:比如软件/usr/local/xxx/opt;
文档化;
工具化;
web化;
平台化;
11.2、ssh key + expect:
1、前期准备:
各个服务器的ssh配置文件已经优化,禁用root用户ssh登录,更改服务器监听的端口号和监听的端口;
[root@m01 ~]# useradd lc(所有的服务器都要建立相同的用户,lc)
[root@m01 ~]# echo '123456' | passwd --stdin lc(所有的服务器lc用户都要建立相同的密码)
[root@m01 ~]# echo ‘lc ALL=(ALL) NOPASSWD:ALL(所有的服务器都lc用户都要sudo权限)
[lc@m01 .ssh]$ ssh-keygen -t dsa -P ' ' -f ~/.ssh/id_dsa >/dev/null 2>&1
[root@m01 ~]# yum install expect -y
[lc@m01 ~]$ mkdir -p /server/scripts
2、创建秘钥对、批量发送公钥(expect),批量发到各个服务器上,远程执行安装服务(一次):
(1)[root@m01 ~]$ vim /server/scripts/fenfa_sshkey.exp
#!/usr/bin/expect
if { $argc != 2 } {
send_user "usage: expect fenfa_sshkey.exp file host dir\n"
exit 1
}
set file [ lindex $argv 0 ]
set host [ lindex $argv 1 ]
#set dir [ lindex $argv 2 ]
set password "123456"
spawn ssh-copy-id -i $file "-p 52113 lc@$host"
expect {
"yes/no" {send "yes\n";exp_continue}
"*password" {send "$password\n"}
}
expect eof
exit -onexit {
send_user "success!\n"
}
#expect fenfa_sshkey.exp ~/.ssh/id_das.pub 172.168.1.31
(2)[root@m01 ~]$ vim /server/scripts/fenfa_sshkey.sh
#!/bin/sh
. /etc/init.d/functions
export PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin
#1 create dsa key
ssh-keygen -t dsa -P ' ' -f ~/.ssh/id_dsa >/dev/null 2>&1
if [ $? -eq 0 ];then
action "create dsa 172.16.1.61" /bin/true
else
action "create dsa 172.16.1.61" /bin/false
exit 1
fi
#2 sed id_dsa.pub
for n in 8 31 41;do
expect fenfa_sshkey.exp ~/.ssh/id_dsa.pub 172.16.1.$n >/dev/null 2>&1
if [ $? -eq 0 ];then
action "sed id_dsa.pub 172.16.1.$n" /bin/true
else
action "sed id_dsa.pub 172.16.1.$n" /bin/false
fi
done
#3 install service
for n in 8 31 41;do
ssh -t -p 52113 lc@172.16.1.$n sudo yum install httpd -y >/dev/null 2>&1
if [ $? -eq 0 ];then
action "install httpd 172.16.1.$n" /bin/true
else
action "install httpd 172.16.1.$n" /bin/false
fi
done
[lc@m01 ~]$ sh /server/scripts/fenfa_sshkey.sh
11、ssh自动化脚本编写的更多相关文章
- java+selenium自动化脚本编写
实训项目:创盟后台管理,页面自动化脚本编写 使用工具:java+selenium 1)java+selenium环境搭建文档 2)创盟项目后台管理系统链接 java+selenium环境搭建 一.Se ...
- 自动化脚本编写环境部署_win7(RF)
第一步 安装Python并设置环境变量 1.安装python: python下载地址https://www.python.org/,建议用2.7.x版本 2.设置环境变量: 方法如下所示 第二步 安 ...
- Selenium2学习-018-WebUI自动化实战实例-016-自动化脚本编写过程中的登录验证码问题
日常的 Web 网站开发的过程中,为提升登录安全或防止用户通过脚本进行黄牛操作(宇宙最贵铁皮天朝魔都的机动车牌照竞拍中),很多网站在登录的时候,添加了验证码验证,而且验证码的实现越来越复杂,对其进行脚 ...
- 《手把手教你》系列基础篇(五)-java+ selenium自动化测试- 创建首个自动化脚本(详细教程)
1.简介 前面几篇宏哥介绍了两种(java和maven)环境搭建和三大浏览器的启动方法,这篇文章宏哥将要介绍第一个自动化测试脚本.前边环境都搭建成功了,浏览器也驱动成功了,那么我们不着急学习其他内容, ...
- RobotFramework自动化测试之脚本编写(一)
接触了上一篇的RF环境搭建及安装,相比大家都会觉得,哇塞,为什么要做这么多,那么复杂?装那么多干什么有什么用?写脚本会不会也很复杂? 其实首次安装的话 会觉得有点蒙,也不知道安装那么多是拿来干什么的, ...
- 20181225-Linux Shell Bash环境下自动化创建ssh互信脚本
20181225-Linux Shell Bash环境下自动化创建ssh互信脚本 1. 我的Blog 博客园 https://www.cnblogs.com/piggybaba/ 个人网站 http: ...
- Python+Appium自动化测试(3)-编写自动化脚本
之前一篇博客已经讲述怎样手动使用appium-desktop启动测试机上的app,但我们实际跑自动化脚本的过程中,是需要用脚本调用appium启动app的,接下来就尝试写Python脚本启动app并登 ...
- shell脚本编写笔记
包含转载内容,转载自http://wenku.baidu.com/link?url=jtCHxEYzgGve6P64U3JRQRgU6nhpGvqFLLpWu9I2Htq6hi9TGLudRFkk7r ...
- 批量配置SSH互信脚本
在大规模自动化部署时我们常常需要配置好服务器的SSH互信,以便自动化脚本可以免密登录远程服务器,常规的手动配置SSH互信步骤如下: 使用ssh-keygen生成本地ssh key(mha01),生成的 ...
随机推荐
- mysqldMY-010457] [Server] --initialize specified but the data directory has files in it. Aborting. 2020-12
删除mysql的/var/lib/mysql目录下的所有文件 https://blog.csdn.net/tr1912/article/details/81271851 # mysqld --init ...
- vim使用基础
vi/vim编辑器使用 前言 There is an old joke about a visitor to New York City asking a passerby for direction ...
- centOS 7 安装 CUPS 打印服务器,安装映美 FP-730K打印机共享
centOS 7 安装 CUPS 打印服务器,安装映美 FP-730K打印机共享 2017-09-13 16:27:02 mostone 阅读数 3698 版权声明:本文为博主原创文章,遵循CC ...
- 七牛云-上传、删除文件,工具类(Day49)
要求: 1. java1.8以上 2. Maven: 这里的version指定了一个版本范围,每次更新pom.xml的时候会尝试去下载7.5.x版本中的最新版本,你可以手动指定一个固定的版本. < ...
- UEFI和Legacy兼容启动U盘制作
应用场景 自己有一个可启动移动硬盘,是属于老式的BIOS启动方式,最近换了新电脑,因为电脑只支持uefi的启动方式,所以决心为移动硬盘增加uefi启动支持,如何将一个只支持BIOS启动(或者 Lega ...
- FreeBSD 13.0 正式版发布,已经可以下载
请访问原文链接:https://sysin.org/article/freebsd-13/,查看最新版.原创作品,转载请保留出处. 根据 FreeBSD 13.0 官方发布计划,4 月 9 日 13. ...
- pika详解(三)SelectConnection及其他Connection
pika详解(三)SelectConnection及其他Connection 本文链接:https://blog.csdn.net/comprel/article/details/94661147 ...
- Nginx 配置实例-配置虚拟主机
Nginx 配置实例-配置虚拟主机 配置基于域名的虚拟主机 1. 配置域名为 aaa.domain.com 的虚拟主机 1.1 nginx 中虚拟主机的配置 1.2 相关目录及文件的创建 1.3 验证 ...
- 北汽极狐ARCFOX与华为合作
北汽极狐ARCFOX与华为合作 全球首款激光雷达量产车 2021年,是激光雷达"上车"的元年. 曾经价格高不可攀,只能用于Robotaxi.无人车测试的激光雷达,终于彻底具备商业化 ...
- VAE变分自编码器实现
变分自编码器(VAE)组合了神经网络和贝叶斯推理这两种最好的方法,是最酷的神经网络,已经成为无监督学习的流行方法之一. 变分自编码器是一个扭曲的自编码器.同自编码器的传统编码器和解码器网络一起,具有附 ...