加入收藏 | 设为首页 | 会员中心 | 我要投稿 拼字网 - 核心网 (https://www.hexinwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 服务器 > 搭建环境 > Unix > 正文

unix脚本 自动化部署

发布时间:2022-12-08 14:03:45 所属栏目:Unix 来源:转载
导读: Java代码自动部署【 ①Java代码自动部署-总结简介】
代码部署是每一个软件开发项目组都会有的一个流程,也是从开发环节到发布功能必不可少的环节。对于Java开发者来说,Java代码的发布部署

Java代码自动部署【 ①Java代码自动部署-总结简介】

代码部署是每一个软件开发项目组都会有的一个流程,也是从开发环节到发布功能必不可少的环节。对于Java开发者来说,Java代码的发布部署也是经常需要做的一件事unix脚本,特别是互联网公司。代码的发布上线关系到保证生产环境能够正常启动及功能是否能正常运行,所以代码部署在整个项目开发周期还是占据很重要的地位。

由于本人近期在学习Java代码自动发布相关的知识,此系列文章是对此次学习到的知识进行巩固和总结;同时,也希望能够帮助到和我一样对此方面知识感兴趣的同行们。言不多说,直接进入真题。下面针对此次系列文章做一个简要的概述。

1、学习代码自动部署的目的

高效且简化代码的部署发布

2、使用的相关工具及技术

1、 CentOS操作系统(可以使用虚拟机安装Linux系统)

2、 Maven

3、 Git

4、 Shell脚本

5、 Jenkins

3、学习代码自动发布相关技术的顺序

阶段1:

优点:部署流程简单方面,开发完成后开发人员在开发环境即可进行代码部署上线。

缺点:发布流程粗糙,代码部署不够严谨,不建议生产环境使用此方式。

阶段2:

优点:由Git进行项目版本管理,降低了代码发布的风险,发布过程有运维人员进行发布。

缺点:由于代码的发布由运维人员发布,需开发人员配合进行代码发布部署,与发布部署不成功,得由开发人员查找问题,增加了部署复杂性。

阶段3:

优点:由Jenkins工具进行代码的发布部署,规范了代码的发布流程,提供可视工具监听整个发布流程等。

缺点:对技术要求更高了,需要了解Jenkins工具,会编写Shell脚本等。

4、Java代码自动部署总结分为以下系列

①总结简介

②使用Maven进行代码部署

③使用Shell进行代码部署

④使用Jenkins进行代码部署

⑤课程总结及心得

【 ②使用Maven进行代码部署】

在使用maven进行代码发布的时候,需要用Maven工具的相关插件将需要部署的项目发布到指定的服务器的部署目录中。

在学习此技术时,我用的的是一个秒杀项目的ssm版,大家在学学习此技术的时候可以用简单一点的Maven项目进行测试。因本项目是学习如何进行部署项目技术的,本次就针对具体项目进行介绍。

1、 使用Maven进行部署项目要求

1) 项目本身属于Maven项目(必要条件)

2) 需要部署的是war包

3) 引入插件

在需要部署的项目的pom,xml文件中引入tomcat插件,在project->build-> plugins节点引入tomcat插件。

org.apache.tomcat.maven

tomcat7-maven-plugin

:8080/manager/text

admin

admin

8080

/seckill-manager

UTF-8

UTF-8

4) 执行Maven的redeploy操作

执行的命令:tomcat7:redeploy

在eclipse下配置的命令如下:

2、需要注意的问题点

1、在将项目发布到远程Tomcat时需要启动远程Tomcat管理控制台账号

开启tomcat管理控制台账号地址为:Tomcat安装目录/conf/tomcat-users.xml文件

在tomcat-users.xml文件中需要配置允许访问纯文本接口权限,以便maven的tomat插件能够通过此方式进行部署项目。

在tomcat-users节点新增role属性和user属性,如下:

解释:给账号admin配置manager-script及manager-gui权限

Tomcat角色解释图:

2、在需要远程发布到的目标Tomcat应该是运行状态,保证Maven的tomcat插件能够访问到目标Tomcat完成项目的部署。

【③使用Shell进行代码部署】

在使用Shell脚本进行重新部署项目时,需要掌握Shell脚本的编写,Shell脚本需要完成以下功能:

1、 将代码clone到服务器指定目录

2、 根据pom.xml文件将代码打包成war包

3、 将war发布到指定服务器

环境要求:

1、 安装Maven并配置环境变量

2、 Git客户端,并配置环境变量

3、 熟悉Shell脚本相关知识

1、编写Shell脚本

在Linux的指定目录新建shell脚本,我是在项目的专用tomcat根目录新建了shell脚本,方便进行tomcat集群部署操作。脚本内容如下:

#!/bin/bash

#shell功能概要:seckill的service提供者构建shell

#发布service提供者的服务器的进程名

serverName="seckill_provider"

#获取发布service提供者的服务器的进程PID

PID=$(ps -ef | grep $serverName | grep -v grep | awk '{ print $2 }')

#java代码本地仓库地址

javaBaseSrc="/opt/java_project_src/"

#项目路径

javaProjectSrc="sekill/seckill-manager/seckill-service/target/seckill-service.war"

#发布的tomcat集群,数组方式存储

projectServicersPath=(/opt/seckill-tomcat/seckill-tomcat-02 /opt/seckill-tomcat/seckill-tomcat-03)

projectName="sekill"

#循环强制停止指定tomcat

for var in ${PID};

do

echo "准备强制停止PID:$var"

kill -9 $var

done

echo "kill $serverName sucess"

#切换到git本地仓库目录

cd $javaBaseSrc

#删除仓库库中代码

rm -rf $projectName

echo "从/opt/java_project_src仓库中删除项目$projectName成功"

#从远程仓库下载代码,因涉及到账户信息,此处更改为描述信息

git clone 远程git仓库项目URL

cd $javaBaseSrc/sekill/seckill-manager

#安装项目并跳过测试

mvn -Dmaven.test.skip=true clean install

#判断执行上面mvn操作的返回值是否为0

if [ $? -ne 0 ]

then

echo "构建失败,请查看代码问题!"

exit 1;

fi

#循环将项目部署到集群tomcat中

for projectServicer in ${projectServicersPath[@]}

do

cp $javaBaseSrc$javaProjectSrc $projectServicer/webapps

echo "$projectServicer 代码发布成功!"

sh $projectServicer/bin/startup.sh

if [ $? -ne 0 ]

then

echo "$projectServicer 启动失败"

exit 1;

else

echo "$projectServicer 启动成功";

fi

done

echo "启动 $serverName 成功"

2、需要注意的问题点

在编写Shell脚本时需要知道每句Shell的含义,尽可能将所有问题点都能考虑到,比如:

a) 强杀进程问题

进行PID=$(ps -ef | grep $serverName | grep -v grep | awk '{ print $2 }')时,要确定查询的只是目标Tomcat的进程pid,防止在后续强制停止时将其他应用Tomcat误强行停止,这里建 议给每一个目标Tomcat设置指定的进程名,设置方法为:

在指定tomcat的bin/ setclasspath.sh文件中找到if [ -z "$_RUNJAVA" ]判断语句,进行以下设置即可

if [ -z "$_RUNJAVA" ]; then

#_RUNJAVA="$JRE_HOME"/bin/java

#注释tomcat默认进程名,设置指定的进程名称,集群的时候可以进行编号01,02,03设置

cp "$JAVA_HOME/bin/java" "$JAVA_HOME/bin/seckill_consumer01"

_RUNJAVA="$JRE_HOME/bin/seckill_consumer01"

fi

b) Shell脚本尽可能通用

我吸取了现在比较流行的一句话“约定大于配置”及平时所看所想,在编写Shell脚本时可以提取可变或多处使用的变量,使整个Shell脚本尽可能提炼成通用,以便类似项目部署可以使用现有脚本进行更改后使用,减少重新编写新Shell脚本带来不可控的问题。

【④使用Jenkins进行代码部署】

在使用Jenkins进行项目部署时,需要将Jenkins的war包放在服务器的指定位置。Jenkins的war的下载可以去Jenkins的官网进行下载。

使用Jenkins进行代码部署时需要的环境支持:

1、安装Maven并配置环境变量

2、Git客户端,并配置环境变量

3、熟悉Shell脚本相关知识

4、对Jenkins有一定了解

使用Jenkins进行代码部署如下:

1、 启动Jenkins工具

在jenkins.war目录执行以下命令操作启动Jenkins工具。

[xiongshx@localhost jenkins]$ java -jar jenkins.war

Jenkins工具初始化的一些操作可以百度或者去Jenkins查看可以参考【】

初始化后需要进行的配置

工具配置

【系统管理】->【全局工具配置】

Jdk配置:

Git配置:

Maven配置:

2、 新建任务

需要注意的点:

1、填写源码仓库地址

2、构建时操作及自定义shell代码

Shell代码如下:

#!/bin/bash

#shell功能概要:seckill的Web消费者构建shell

#引用的技术有:git、maven

#发布web消费者的服务器的进程名

serverName="seckill_consumer"

#获取发布web消费者的服务器的进程PID

PID=$(ps -ef | grep $serverName | grep -v grep | awk '{ print $2 }')

#需要在脚本开始时添加export BUILD_ID=dontKillMe。

#原因:因为Jenkins执行完当前任务之后需要执行下一个任务,此时Jenkins会直接把tomcat进程杀掉,

#因此在脚本中编写的tomcat启动命令是不会执行的。

export BUILD_ID=dontKillMe

#java代码本地仓库地址

javaBaseSrc="/home/xiongshx/.jenkins/workspace/"

#项目路径

javaProjectSrc="seckill/seckill-web/target/seckill-web.war"

#发布的tomcat

projectServicersPath=(/opt/seckill-tomcat/seckill-tomcat-01)

projectName="sekill"

for var in ${PID};

do

echo "准备强制停止PID:$var"

kill -9 $var

done

echo "kill $serverName sucess"

#如果上一个命令执行失败,执行的状态码不为0

if [ $? -ne 0 ]

then

echo "构建失败,请查看代码问题!"

exit 1;

fi

for projectServicer in ${projectServicersPath[@]}

do

cp $javaBaseSrc$javaProjectSrc $projectServicer/webapps

echo "$projectServicer 代码发布成功!"

/bin/bash $projectServicer/bin/startup.sh

if [ $? -ne 0 ]

then

echo "$projectServicer 启动失败"

exit 1;

else

echo "$projectServicer 启动成功";

fi

done

echo "启动 $serverName 成功"

3、 启动项目

【立即构建】->【点击构建的链接】->【控制台输出】即可查看整个代码部署过程中的信息输出。

4、需要注意的问题点:

1、Jenkins的war问题

最简单jenkins.war的启动方式是在控制台终端执行命令:java -jar jenkins.war;但是此方法会占用一个终端窗口,且关闭后Jenkins工具就不能进行访问,可以使用命令进行后台执行,命令如下:

nohup java -jar jenkins.war --httpPort=9090 > /dev/null 2>&1 &

命令解释:

nohup 后台执行操作

(编辑:拼字网 - 核心网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章