expect脚本与shell脚本相结合

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

Expect脚本和shell脚本相结合—断电后可实现执行一个脚本启动所有应用

expect脚本我们这里只使用了expect 和 send,expect意味着出现的提示信息,send就可以书写正常的linux命令,具体看例子。具体书写还是要靠大家自己调试,基本框架都是我这个例子里面。

这个例子是bash脚本和expect脚本相结合

#!/bin/bash                             --bash脚本的标志

/usr/bin/expect <<EOF                    --这里意味着bash脚本中嵌套着expect脚本

set timeout -1                           --设置超时时间,-1意思是永远也不超时

spawn ssh root@192.168.20.115           --意味着远程登录到我这个应用的数据库服务器

expect {                              --第一次远程登录别的服务器的时候会出现一些

                                       提示,你可以在你自己的应用上ssh +IP尝试一下,我这里                                        会出现(yes/no),接着会让我输入密码。第二次登录就是                                        直接提示输入密码。所以这里是‘或’关系中嵌套                                                着‘与’关系。根据{}的组合来进行理解

"*(yes/no)*" {

  send "yes\n"

  expect "asswd:"

  send "Pandora!74\n"}


"*password:" {send "Pandora!74\n"}

}

expect "*#"                       --expect是出现的提示信息,不同的系统不一样,你的可能是 “*$”,这里是正则表达式的匹配用法

send "ps -ef | grep oracle\n"          -- send是输入的命令

expect "*oracle*oraclehrdb"

send "exit\n"                        --退出远程的数据库服务器,回到本地应用服务器

expect "*#"

spawn ssh root@192.168.20.217        --远程登录到另一台应用服务器,启动这个应用服务器上面的启动脚本

expect {

"*(yes/no)*" {

  send "yes\n"

  expect "asswd:"

  send "Pandora!74\n"}

"*password:" {send "Pandora!74\n"}

}

expect "*#"

send "cd /opt/jboss-eap-6.2\n"

expect "*#"

send "sh zidong.sh\n"

expect "*#"

send "exit\n"


expect eof

EOF                          --退出expect脚本

#最终启动自己的Jboss

ps -ef | grep jboss | grep -v grep | cut -c 9-15 | xargs kill -s 9

rm -rf /opt/jboss6/jboss-eap-6.2/standalone/tmp/*

nohup /opt/jboss6/jboss-eap-6.2/bin/standalone.sh  -Djboss.bind.address=0.0.0.0 -Dorg.jboss.as.logging.per-deployment=false  & >> /opt/jboss6/nohup.out


这样最终你就可以实现只在一个服务器上写一个启动脚本,远程登录到其他的应用服务器,启动那个应用上的脚本。我这里只是远程登录了两个,你可以按照例子远程多个。


注意事项:1、这个脚本一定要放到和Jboss的启动脚本一个路径,否则就会出现不能够执行的状况,因为获取不到JBOSS的变量。

2、我们的应用的启动脚本都会有一句tail –f nohup.out ,把启动日志放到前台,我们这里不需要放到前台,因为放到前台会有很多的日志信息,看起来很乱,因此不需要加这个语句,只需要让JBOSS自己在后台运行就可以。因此你可以自己再另写一个启动JBOSS的脚本。

3、我这里只是我系统的例子,因为我已经吧所有的oracle设置为开机启动了,因此这里只需要查看一下oracle的状态就可以,也可以不查看,加入开机启动即可。

4、最好把自己系统上的一些其余的软件都设置为开机启动,或者写到我们这脚本里面也可以

另一个数据库是mysql数据库,因为我的MySQL没有实现开机自启,我就把启动MySQL放到了脚本里面。

#!/bin/bash

/usr/bin/expect <<EOF

set timeout -1

spawn ssh root@192.168.20.208   --MySQL数据库服务器

expect {

"*(yes/no)*" {

  send "yes\n"

  expect "asswd:"

  send "Pandora!74\n"}

"*password:" {send "Pandora!74\n"}

}

expect "*#"                     --查看MySQL运行状态,没有运行就启动,正在运行就退出

send "service mysql status\n"

expect {

"*ERROR! MySQL is not running*"  {

                                  send "service mysql start\r";

                                  expect "*#"

                                  send "exit\n"

                                  }

"*SUCCESS! MySQL running*" {send "exit\n"}


}

expect eof

EOF

ps -ef | grep jboss | grep -v grep | cut -c 9-15 | xargs kill -s 9           --杀进程

rm -rf /opt/jboss-eap-6.2/standalone/dppm-deploy/dppm-web.war

cp-r/opt/Jenkins/test_NewPackage/dppm-web.war /opt/jboss-eap-6.2/standalone/dppm-deploy/

nohup bin/standalone.sh  -c=dppm.xml -Derrors.port.offset=0 -Dfile.encoding=utf-8 -Djboss.bind.address=0.0.0.0  -Dorg.jboss.as.logging.per-deployment=false > ./nohup.out 2>&1 &  


本文转自aaa超超aaa 51CTO博客,原文链接:http://blog.51cto.com/10983441/1739193

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
打赏
0
0
0
0
344
分享
相关文章
MySQL 备份 Shell 脚本:支持远程同步与阿里云 OSS 备份
一款自动化 MySQL 备份 Shell 脚本,支持本地存储、远程服务器同步(SSH+rsync)、阿里云 OSS 备份,并自动清理过期备份。适用于数据库管理员和开发者,帮助确保数据安全。
定期备份数据库:基于 Shell 脚本的自动化方案
本篇文章分享一个简单的 Shell 脚本,用于定期备份 MySQL 数据库,并自动将备份传输到远程服务器,帮助防止数据丢失。
|
2月前
|
【linux】Shell脚本中basename和dirname的详细用法教程
本文详细介绍了Linux Shell脚本中 `basename`和 `dirname`命令的用法,包括去除路径信息、去除后缀、批量处理文件名和路径等。同时,通过文件备份和日志文件分离的实践应用,展示了这两个命令在实际脚本中的应用场景。希望本文能帮助您更好地理解和应用 `basename`和 `dirname`命令,提高Shell脚本编写的效率和灵活性。
121 32
|
6月前
|
一个用于添加/删除定时任务的shell脚本
一个用于添加/删除定时任务的shell脚本
174 1
多种脚本批量下载 Docker 镜像:Shell、PowerShell、Node.js 和 C#
本项目提供多种脚本(Shell、PowerShell、Node.js 和 C#)用于批量下载 Docker 镜像。配置文件 `docker-images.txt` 列出需要下载的镜像及其标签。各脚本首先检查 Docker 是否安装,接着读取配置文件并逐行处理,跳过空行和注释行,提取镜像名称和标签,调用 `docker pull` 命令下载镜像,并输出下载结果。使用时需创建配置文件并运行相应脚本。C# 版本需安装 .NET 8 runtime。
137 2
6种方法打造出色的Shell脚本
6种方法打造出色的Shell脚本
140 2
6种方法打造出色的Shell脚本
|
5月前
|
Shell脚本要点和难点以及具体应用和优缺点介绍
Shell脚本在系统管理和自动化任务中扮演着重要角色。尽管存在调试困难、可读性差等问题,但其简洁高效、易于学习和强大的功能使其在许多场景中不可或缺。通过掌握Shell脚本的基本语法、常用命令和函数,并了解其优缺点,开发者可以编写出高效的脚本来完成各种任务,提高工作效率。希望本文能为您在Shell脚本编写和应用中提供有价值的参考和指导。
200 1
ubuntu/debian shell 脚本自动配置 gitea git 仓库
这是一个自动配置 Gitea Git 仓库的 Shell 脚本,支持 Ubuntu 20+ 和 Debian 12+ 系统。脚本会创建必要的目录、下载并安装 Gitea,创建 Gitea 用户和服务,确保 Gitea 在系统启动时自动运行。用户可以选择从官方或小绿叶技术博客下载安装包。
178 2
ip和ip网段攻击拦截系统-绿叶结界防火墙系统shell脚本
这是一个名为“小绿叶技术博客扫段攻击拦截系统”的Bash脚本,用于监控和拦截TCP攻击。通过抓取网络数据包监控可疑IP,并利用iptables和firewalld防火墙规则对这些IP进行拦截。同时,该系统能够查询数据库中的白名单,确保合法IP不受影响。此外,它还具备日志记录功能,以便于后续分析和审计。
114 6
深入理解Linux系统下的Shell脚本编程
【10月更文挑战第24天】本文将深入浅出地介绍Linux系统中Shell脚本的基础知识和实用技巧,帮助读者从零开始学习编写Shell脚本。通过本文的学习,你将能够掌握Shell脚本的基本语法、变量使用、流程控制以及函数定义等核心概念,并学会如何将这些知识应用于实际问题解决中。文章还将展示几个实用的Shell脚本例子,以加深对知识点的理解和应用。无论你是运维人员还是软件开发者,这篇文章都将为你提供强大的Linux自动化工具。