jenkin配置gitlab持续化构建Spring Cloud微服务

3.源码管理

–源码管理选择Git, Repository URL输入项目的gitlab地址,点击添加,配置git的用户名和密码,配置用户名和密码是只需要输入用户名和密码,其他输入框可以不用管。然后选择你的用户名和密码。输入分支变量:*/${branch},匹配刚刚的branch变量值。方便拉取分支。

 4.构建,选择执行Excute Shell,输入写好的脚本

脚本如下,仅供参考:

#!/bin/bash

BUILD_ID=dontKillMe

elastic=htlb-elasticsearch-service

echo “部署开始

if $repackage; then

for SER_PORT_IP in $(echo $tar_server_port) ; do

SERVICE_NAME=$(echo $SER_PORT_IP | cut -f 1 -d ‘:’ )

SERVICE_PORT=$(echo $SER_PORT_IP | cut -f 2 -d ‘:’ )

SERVER_IP=$(echo $SER_PORT_IP | cut -f 3 -d ‘:’ )

JAR_NAME=$(echo $SER_PORT_IP | cut -f 4 -d ‘:’ )

if [[ “ H T Y S E R V I C E " = = " HTY_SERVICE" == " HTYSERVICE"=="SERVICE_NAME” || “$HTY_SERVICE” == “all” ]]; then

echo “$SERVICE_NAME部署打包开始

mvn clean package -Dmaven.test.skip=true -pl “${SERVICE_NAME}” -am

scp -P22 S E R V I C E N A M E / t a r g e t / SERVICE_NAME/target/ SERVICENAME/target/JAR_NAME.jar root@127.0.0.1:/root/home/deployer/projects

echo “$SERVICE_NAME部署打包结束

fi

done

fi

if $restart; then

if [ $HTY_SERVICE = $elastic ]; then

echo “current service is htlb-elasticsearch-service”

ssh root@127.0.0.1 “sh /root/elastic.sh stop”

fi

for SER_PORT_IP in $(echo $tar_server_port) ; do

SERVICE_NAME=$(echo $SER_PORT_IP | cut -f 1 -d ‘:’ )

SERVICE_PORT=$(echo $SER_PORT_IP | cut -f 2 -d ‘:’ )

SERVER_IP=$(echo $SER_PORT_IP | cut -f 3 -d ‘:’ )

JAR_NAME=$(echo $SER_PORT_IP | cut -f 4 -d ‘:’ )

if [[ “ H T Y S E R V I C E " = = " HTY_SERVICE" == " HTYSERVICE"=="SERVICE_NAME” || “$HTY_SERVICE” == “all” ]]; then

echo “$SERVICE_NAME部署服务开始

echo “scp /root/home/deployer/projects/ J A R N A M E . j a r r o o t @ {JAR_NAME}.jar root@ JARNAME.jarroot@{SERVER_IP}:/root/home/deployer/projects”;

scp /root/home/deployer/projects/ J A R N A M E . j a r r o o t @ {JAR_NAME}.jar root@ JARNAME.jarroot@{SERVER_IP}:/root/home/deployer/projects

echo “scp complete!”

ssh root@ S E R V E R I P " m k d i r − p / r o o t / h o m e / d e p l o y e r / w o r k s p a c e / {SERVER_IP} "mkdir -p /root/home/deployer/workspace/ SERVERIP"mkdirp/root/home/deployer/workspace/{SERVICE_NAME}-KaTeX parse error: Expected 'EOF', got '&' at position 16: {SERVICE_PORT} &̲& cp /root/home…{JAR_NAME}.jar /root/home/deployer/workspace/ S E R V I C E N A M E − {SERVICE_NAME}- SERVICENAME{SERVICE_PORT}/app.jar && curl -fsSL http://127.0.0.1/deployJar.sh | bash -s – -t/root/home/deployer/workspace/ S E R V I C E N A M E − {SERVICE_NAME}- SERVICENAME{SERVICE_PORT}/app.jar -p S E R V I C E P O R T − a − D s p r i n g . p r o f i l e s . a c t i v e = t e s t − l − f / v a r / l o g / d e p l o y e r / s e r v i c e / {SERVICE_PORT} -a-Dspring.profiles.active=test -l -f/var/log/deployer/service/ SERVICEPORTaDspring.profiles.active=testlf/var/log/deployer/service/{SERVICE_NAME}.log"

echo “$SERVICE_NAME部署服务结束

fi

if [ “$HTY_SERVICE” == “all” ]; then

sleep 5

fi

done

if [ $HTY_SERVICE = $elastic ]; then

echo “current service is htlb-elasticsearch-service”

sleep 10

ssh root@127.0.0.1 “sh /root/elastic.sh restart”

fi

fi

echo “部署结束

代码部分解释:es服务单独判断是由于es启动的时候失败了,需要先停掉es的节点,启动成功以后再启动es节点。所以写了个脚本去操作。
all变量是当初想要一键启动所有服务,但是由于服务越来越多,一键启动的话风险太大,所以还是老老实实该启动啥就启动啥吧。
代码中有一段需要执行的shell脚本。http://127.0.0.1/deployJar.sh,里面就是一些普通脚本,判断服务端口,杀掉以后进程,已经重启服务的,也是该配置的核心,我就不放出来。需要的朋友可以私我哈。关注公众号:FOSSspace,联系我哈。如果有困难,也可以帮你参考一下。

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
你有帮助,需要这份全套学习资料的朋友可以戳我获取!!**](https://bbs.csdn.net/topics/618164986)

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

  • 28
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值