http://www.pczh.cn/news/21701.html
1、运行前准备环境
- jenkins.war:下载地址https://get.jenkins.io/war-stable/ 我的是Jenkins 2.387.3
- Java:jdk8或者jdk11,参考jenkins官方文档中的建议,本文以jdk11为例;下载地址: https://www.oracle.com/java/technologies/downloads/#java11
如果服务器上已经有jdk了,不需要做什么改动,也不需要配置环境变量,另外找路径安装即可;
启动jenkins时可以用
/usr/local/java/jdk-11.0.19/bin/java -jar jenkins.war --httpPort=55555
- node:部署vue会用到。下载地址:https://registry.npmmirror.com/binary.html?path=node/
我们以 node-v14.15.4-linux-x64.tar.xz为例, 上传到服务器/app/env下
cd /app/env
解压xz包
tar -xJvf node-v14.15.4-linux-x64.tar.xz
cd /usr/bin/
创建软连接
ln -s /app/env/node-v14.15.4-linux-x64/bin/node node
ln -s /app/env/node-v14.15.4-linux-x64/bin/npm npm
npm -v
会出现版本号,说明配置完毕!如果出错。删除/usr/bin/下的npm 和 node 重创建软连接
- maven:下载对应版本下载项目所用到的包。下载地址:https://archive.apache.org/dist/maven/maven-3/
安装maven就比较简单,我们以apache-maven-3.5.4-bin.tar.gz为例,下载对应的版本,上传服务器
解压
tar -zxvf apache-maven-3.5.4-bin.tar.gz
配置环境变量
vi /etc/profile
将以下代码贴到末尾
export MAVEN_HOME=/usr/local/maven/apache-maven-3.5.4
export PATH=$MAVEN_HOME/bin:$PATH
刷新配置
source /etc/profile
- liunx服务器最好有外网,如果没有就得手动下载相关插件,但是 jenkins的插件是个套娃,一个套一个,你永远不知道要下载哪些插件,就算下载完也会因为版本的问题给你弄到🤮吐!所以最好有访问外网权限;如果实在没有外网,那就试试在本地安装一个相同版本的jenkins,下载插件后,打包直接上传到服务器上,jenkins插件的位置基本上都在 /root/.jenkins/plugins
以上都准备完毕
2、启动jenkins.war
nohup /usr/local/java/jdk-11.0.19/bin/java -jar jenkins.war --httpPort=55555 &
浏览器打开 http://ip:55555/ 出现以下界面
打开nohup文件,会看到初始密码
输入之后,该输入啥就输入啥,最后出现以下界面
你以为到这就结束了?no,远远不止,接下来下载对应插件,以及写脚本,调试脚本才是最费时间的
- 首先,我们需要能够下载代码,所以需要安装svn插件,Subversion Plug-in版本2.17.2
安装之后,我们新建一个item
确定以后就是以下界面
再起一个部署工程
首先是打包的脚本
export NODE_HOME=/app/env/node-v14.5.0-linux-x64
export PATH=$PATH:$NODE_HOME/bin
cd $WORKSPACE
export DEPLOY_ID=deploy_`date +%Y%m%d_%H%M%S`_$BUILD_ID
echo $DEPLOY_ID
mvn clean package -U
cd $WORKSPACE/sd-airline-admin
npm install
npm run build
rm -rf dist.zip
rm -rf ./dist/.svn
rm -rf ./dist/static/.svn
zip -r dist.zip dist
mkdir /nas/share/deploy/$DEPLOY_ID
mv $WORKSPACE/.bin/jars/* /nas/share/deploy/$DEPLOY_ID/
mv $WORKSPACE/sd-airline-admin/dist.zip /nas/share/deploy/$DEPLOY_ID/
echo ==================BUILD OK $BUILD_ID=========================
然后是部署发布脚本
echo ${deploy_id}
if [ ! -d "/nas/share/deploy/${deploy_id}" ]; then
echo "DEPLOY_ID ERROR:${deploy_id}"
exit 1
fi
OLD_BUILD_ID=$BUILD_ID
echo $OLD_BUILD_ID
BUILD_ID=DONTKILLME
echo "FULL:"$deploy_id >> /app/share/deploy.history
#sh /app/env/deploy.sh $deploy_id
ssh 172.19.13.40 'sh /app/env/deploy.sh' $deploy_id
ssh 172.19.13.39 'sh /app/env/deploy.sh' $deploy_id
ssh 172.19.13.41 'sh /app/env/deploy.sh' $deploy_id
ssh 172.16.9.26 'sh /app/env/deploy.sh' $deploy_id
BUILD_ID=$OLD_BUILD_ID
echo $BUILD_ID OK
最后是服务器上的辅助脚本比如上述所提到的/app/env/deploy.sh
#!/bin/sh
DEPLOY_ID=$1
echo `hostname`:$DEPLOY_ID
if [ ! -f "/app/env/apps.list" ]; then
cp /app/share/env/apps.list /app/env/
fi
for line in `cat /app/env/apps.list`
do
if [ -z "$line" ]; then
continue
fi
if [[ $line == \#* ]]; then
continue
fi
if [[ $line == sd-airline-admin ]]; then
rm -rf /app/web/dist
unzip /nas/share/deploy/$DEPLOY_ID/dist.zip -d /java/web/
continue
fi
echo $line
sh /app/$line/app.sh stop
rm -rf /app/$line/*.jar
cp /nas/share/deploy/$DEPLOY_ID/$line-1.0-SNAPSHOT.jar /app/$line/
sh /app/$line/app.sh start
echo $line STARTING...
done
#bff-provider
#api-gateway
#api-job-service
#api-mng-service
#crm-provider
#crm-monitor
msg-audit
msg-provider
#refresh-provider
#search-provider
#third-party-provider
encouragement-provider
#!/bin/bash
export JAVA_HOME=/app/env/jdk1.8.0_221
export PATH=$PATH:$JAVA_HOME/bin
export classpath=.:$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar
_PWD=`/bin/pwd`
if [ $2x == ""x ]; then
SCRIPT_DIR=$(cd $(dirname ${BASH_SOURCE[0]}); pwd)
else
SCRIPT_DIR="/app/$2"
fi
JAR_NAME=`ls $SCRIPT_DIR/*.jar`
#####################################################################################
#准生产、测试及开发环境使用:
APP_ARGS="-Dcfg.addr=172.16.9.25:8848 -Dreg.addr=172.16.9.25:8848 -Dcfg.ns=crm -Dreg.ns=crm"
#####################################################################################
#使用说明,用来提示输入参数
usage() {
echo "Usage: sh app.sh [start|stop|restart|status]"
exit 1
}
#检查程序是否在运行
is_exist(){
echo $2
if [ ! -f "$SCRIPT_DIR/pid" ]; then
return 1
fi
#pid=`ps -ef|grep $APP_NAME|grep -v grep|awk '{print $2}' `
pid=`cat $SCRIPT_DIR/pid`
#如果不存在返回1,存在返回0
if [ -z "${pid}" ]; then
return 1
else
return 0
fi
}
#启动方法
start(){
is_exist
if [ $? -eq "0" ]; then
echo "${JAR_NAME} is already running. pid=${pid} ."
else
#echo "java $APP_ARGS -jar $JAR_NAME"
cd $SCRIPT_DIR
nohup java $APP_ARGS -jar $JAR_NAME > /dev/null 2>&1 &
#java $APP_ARGS -jar $JAR_NAME
cd $_PWD
_PID=$!
echo "$_PID" > $SCRIPT_DIR/pid
echo "${JAR_NAME} IS STARTING(pid=$_PID)..."
fi
}
#停止方法
stop(){
is_exist
if [ $? -eq "0" ]; then
kill -9 $pid
rm -rf $SCRIPT_DIR/pid
echo "${JAR_NAME} SHUTDOWN!"
else
echo "${JAR_NAME} is not running"
fi
}
#输出运行状态
status(){
is_exist
if [ $? -eq "0" ]; then
echo "${JAR_NAME} is running. Pid is ${pid}"
else
echo "${JAR_NAME} is NOT running."
fi
}
#重启
restart(){
stop
start
}
#根据输入参数,选择执行对应方法,不输入则执行使用说明
case "$1" in
"start")
start
;;
"stop")
stop
;;
"status")
status
;;
"restart")
restart
;;
*)
usage
;;
esac
对于我这种菜鸡来讲调试脚本时最费时间,希望自己下次有些耐心,
完成以上步骤,jenkins一键部署才算完成