tomcat批量升级

本地升级文件

user="user"

iparray=("ip1","ip2")


mv /home/hwt/workspacej2ee/wmscopy/wms/admin/target/wms-0.8.0-SNAPSHOT.war /home/hwt/workspacej2ee/wmscopy/wms/admin/target/web.war
for ip in ${iparray[*]}  
do  
 
#远程复制
scp web.war root@$ip:/home/distribute/apache-tomcat-distribute/webapps/
sleep 10
ssh -t  $user@$ip "/home/update/frontupdate.sh"

done

问题:ssh Neither the JAVA_HOME nor the JRE_HOME environment variable is defined At least one of these environment variable is needed to run this program

我的JAVA_HOME是定义在/etc/profile 里面的
略做研究之后发现结果如下:
      /etc/profile: 当用户登录时,该文件被执行.
      /etc/bashrc: 当bash shell被打开时,该文件被执行.
ssh作为non-login方式进入,当然就无法触发/etc/profile的执行了。
所以应该设置到/etc/bashrc里面去.
其他的配置文件还有
      ~/.bash_profile
      ~/.bashrc
      ~/.bash_logout  
以上引用:http://blog.sina.com.cn/s/blog_64693fd40101eyyh.html

问题2:ssh 远程调用frontupdate.sh 后,ssh不退出,tomcat有进程,ssh 退出,tomcat 直接关闭
使用nohub 命令如下,可以 不挂断运行
nohup command_here & 注意:调用该命令后sleep 下,不然不起作用
问题3:必须输入密码才能远程调用

无密码上传文件处理:

1、本地生成一对秘钥文件(公钥和私钥);

$ ssh-keygen

#以上命令等价于 ssh-keygen -t rsa

#-t:指定密钥的类型,默认为SSH-2 的rsa类型;

运行上面的命令后,系统会出现一系列提示,可以一路回车。特别说明,其中有一个问题是,要不要对私钥设置口令(passphrase),如果担心私钥的安全,可以设置一个。运行结束以后,会在 ~/.ssh/ 目录下新生成两个文件:id_rsa.pubid_rsa。前者公钥,后者是私钥。

2、将公钥传送到远程主机host上面;

$ ssh-copy-id user@host

经过以上两步之后,就可以实现无密码远程登录了(远程主机将用户的公钥保存在~/.ssh/authorized_keys文件中)。

以上 转载:http://my.oschina.net/jean/blog/290461

frontupdate.sh:

#!/bin/sh
#升级站点数组
proarray=(tomcat1 tomcat2)
#遍历数组
for data in ${proarray[@]}
do
echo "apache-tomcat-${data} update"
    #抽取Tomcat进程号PID
                pid=`ps -ef | grep apache-tomcat-${data}|grep -v 'grep' |  awk '{print $2}'`
        #测试当前进程是否处于活动状态
                test "$pid" != "" && kill $pid && echo "Stop apache-tomcat-${data} Successful!" || echo "Stop apache-tomcat-${data} Failed!"


echo "apache-tomcat-${data} shutdown"
echo "复制web.war"
rm -rf /home/apache-tomcat-${data}/webapps/web.war
cp /home/distribute/apache-tomcat-distribute/webapps/web.war /home/apache-tomcat-${data}/webapps/
echo "启动apache-tomcat-${data}"
    bash /home/update/updatebyone.sh ${data}
echo "apache-tomcat-${data}启动结束"
updatebyone.sh 这个文件不公开。



Linux 多tomcat服务 统一安装 统一部署 工具 shell编写 1 引言 基于JAVA开发项目,随着服务的越来越多,配置文件更是眼花缭乱,每次不知道因为配置问题浪费多少时间,更不知道因为配置问题出过多少问题。多台服务器来回切换,如果服务需要依赖,启动更是问题。 1.1 目的 一次修改,统一安装;操作简单,实用高效。 1.2 范围 本项目使用范围包括: * 基于JAVA开发项目 * 项目相关服务繁多 * 服务启动有依赖关系 1.3 读者 本需求规格说明书的阅读者或其他文档干系人有平台总监、产品经理、项目总监、项目经理、开发人员、测试人员、用户体验设计人员等。 2 项目总体描述 2.1 系统总体功能框架 2.2 系统功能列表 Exec 建立信任、初始命令 初始 Tools 提供服务与服务列表 扫描提供服务列表,获取配置信息 Conf 自动获取需要修改配置 自动生成 Bin 执行脚本 提供总执行与单一执行脚本 New 存放修改后配置文件 与bak保留文件成反比 Bak 存放原始配置文件 便于问题分析 Temp 存放临时文件 临时文件将及时删除无任何冗积 Workapp 存放war包 上传war包 3 功能描述 3.1 获取配置文件 通过本系统获取配置文件非常简单,只需用户提供服务列表,其他无需操作。服务列表如下: name ip serve 服务名称 192.168.0.1 /home/tomcat_服务名称 服务名称 192.168.1.2 /home/tomcat_服务名称 服务名称 192.168.1.2 /home/tomcat_服务名称 名词解释: name :服务名称,需与war包名称一致。 ip :服务器ip地址。 serve :Tomcat部署路径。 执行脚本,“.. /unifyDeploy/conf”自动生成用户所需修改配置文件,配置文件是通过筛选后生成,所以一个服务不管需要配置多少文件,这里只生成一个,方便修改与管理。 3.2 自动化统一安装部署 自动化统一安装部署,包括:上传解压war包、同步配置、启动服务、监控服务等。 list.ll one.sh pass.war startup.sh syn.cn two.sh 部署支持统一安装于分布式安装,每个脚本可以拆分开任意组合使用,比如: 1) 一套新环境tomcat中还未部署服务,只需调整上传war包脚本顺序,先上传war后,后续操作正常执行。 2) 迭代更新,功能稍作修改,原配置项无需修改,也只需调整上传war包脚本顺序,先获取原有配置,再上传更新war包,后续操作正常执行。 3.3 优缺点描述 优点描述: * 适用于统一安装部署,也适用于单独服务安装部署。 * 保留原始备份,方便部署前后配置对比。 * 操作简单、需求扩展能力强。 不足描述: * 暂时只适用于基于tomcat服务器项目。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值