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

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!

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,联系我哈。如果有困难,也可以帮你参考一下。

最后

关于面试刷题也是有方法可言的,建议最好是按照专题来进行,然后由基础到高级,由浅入深来,效果会更好。当然,这些内容我也全部整理在一份pdf文档内,分成了以下几大专题:

  • Java基础部分

  • 算法与编程

  • 数据库部分

  • 流行的框架与新技术(Spring+SpringCloud+SpringCloudAlibaba)

这份面试文档当然不止这些内容,实际上像JVM、设计模式、ZK、MQ、数据结构等其他部分的面试内容均有涉及,因为文章篇幅,就不全部在这里阐述了。

作为一名程序员,阶段性的学习是必不可少的,而且需要保持一定的持续性,这次在这个阶段内,我对一些重点的知识点进行了系统的复习,一方面巩固了自己的基础,另一方面也提升了自己的知识广度和深度。
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!
点的知识点进行了系统的复习,一方面巩固了自己的基础,另一方面也提升了自己的知识广度和深度。**
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!

  • 18
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值