《一线大厂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"mkdir−p/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/ SERVICEPORT−a−Dspring.profiles.active=test−l−f/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面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门,即可获取!