datacenter构建修改

This commit is contained in:
XinWei 2024-08-30 11:23:38 +08:00
parent 544f20b6f7
commit c924ee7bb7
4 changed files with 26 additions and 109 deletions

View File

@ -2,80 +2,11 @@ kind: pipeline # 定义对象类型还有secret和signature两种类型
type: docker # 定义流水线类型还有kubernetes、exec、ssh等类型 type: docker # 定义流水线类型还有kubernetes、exec、ssh等类型
name: ludu-system-drone # 定义流水线名称 name: ludu-datacenter-drone # 定义流水线名称
steps: # 定义流水线执行步骤,这些步骤将顺序执行 steps: # 定义流水线执行步骤,这些步骤将顺序执行
# - name: package # 流水线名称
#
# image: maven:3-jdk-8 # 定义创建容器的Docker镜像
#
# volumes: # 将容器内目录挂载到宿主机仓库需要开启Trusted设置
#
# - name: maven-cache
#
# path: /root/.m2 # 将maven下载依赖的目录挂载出来防止重复下载
#
# - name: maven-build
#
# path: /app/build # 将应用打包好的Jar和执行脚本挂载出来
#
# commands: # 定义在Docker容器中执行的shell命令
#
# - mvn package -Dmaven.test.skip=true # 应用打包命令
# - mkdir -p /app/build/ludu-module-datacenter/target
# - cp ./ludu-module-datacenter/ludu-module-datacenter-biz/target/ludu-module-datacenter-biz.jar /app/build/ludu-module-datacenter/target
# - cp ./ludu-module-datacenter/ludu-module-datacenter-biz/Dockerfile /app/build/ludu-module-datacenter
# - cp ./ludu-module-datacenter/ludu-module-datacenter-biz/run.sh /app/build/ludu-module-datacenter
#
# - name: copy-to-object # 构建基础模块和复制票务停车场到轮渡服务器
#
# image: appleboy/drone-ssh # SSH工具镜像
#
# settings:
#
# host: 101.43.112.107 # 远程连接地址
#
# username: root # 远程连接账号
#
# password:
#
# from_secret: ssh_password # 从Secret中读取SSH密码
#
# port: 22 # 远程连接端口
#
# command_timeout: 15m # 远程执行命令超时时间
#
# script:
#
# - scp -r /ludu/maven/build/ludu-module-datacenter root@120.46.37.243:/ludu/maven/build
# - echo "datacenter done"
#
# - name: build-old-service
#
# image: appleboy/drone-ssh # SSH工具镜像
#
# settings:
#
# host: 120.46.37.243 # 远程连接地址
#
# username: root # 远程连接账号
#
# password:
#
# from_secret: ssh_password2 # 从Secret中读取SSH密码
#
# port: 22 # 远程连接端口
#
# command_timeout: 5m # 远程执行命令超时时间
#
# script:
#
# - cd /ludu/maven/build/ludu-module-datacenter/
# - chmod +x ./run.sh # 更改为可执行脚本
# - ./run.sh || echo "ludu-module-datacenter build failed" # 运行脚本打包应用镜像并运行
- name: build-new-service - name: build-new-service
image: appleboy/drone-ssh # SSH工具镜像 image: appleboy/drone-ssh # SSH工具镜像
@ -97,22 +28,7 @@ steps: # 定义流水线执行步骤,这些步骤将顺序执行
script: | script: |
cd /root/ludu-cloud cd /root/ludu-cloud
git pull origin master git pull origin master
rm -f ludu-module-datacenter/ludu-module-datacenter-biz/src/main/java/cn/iocoder/yudao/module/datacenter/framework/nacos/config/BeanInit.java /root/apache-maven-3.9.4/bin/mvn package -Dmaven.test.skip=true
/root/apache-maven-3.9.4/bin/mvn clean package -Dmaven.test.skip=true cd ludu-module-datacenter/ludu-module-datacenter-biz/
port=48092 # 指定端口号 chmod +x run.sh
pid=$(lsof -t -i:$port) # 获取占用指定端口的进程号 ./run.sh || echo "ludu-module-datacenter build failed"
if [ -n "$pid" ]; then
echo "Killing process $pid"
kill -9 $pid
fi
nohup java -jar ludu-module-datacenter/ludu-module-datacenter-biz/target/ludu-module-datacenter-biz.jar --spring.profiles.active=dev > api.log &
volumes: # 定义流水线挂载目录,用于共享数据
- name: maven-build
host:
path: /ludu/maven/build # 从宿主机中挂载的目录
- name: maven-cache
host:
path: /ludu/maven/cache # 从宿主机中挂载的目录

View File

@ -1,6 +1,6 @@
## AdoptOpenJDK 停止发布 OpenJDK 二进制,而 Eclipse Temurin 是它的延伸,提供更好的稳定性 ## AdoptOpenJDK 停止发布 OpenJDK 二进制,而 Eclipse Temurin 是它的延伸,提供更好的稳定性
## 感谢复旦核博士的建议!灰子哥,牛皮! ## 感谢复旦核博士的建议!灰子哥,牛皮!
FROM eclipse-temurin:8-jre FROM openjdk:8-jre
## 创建目录,并使用它作为工作目录 ## 创建目录,并使用它作为工作目录
RUN mkdir -p /ludu-module-datacenter-biz RUN mkdir -p /ludu-module-datacenter-biz

View File

@ -1,6 +1,6 @@
app_name='ludu-module-datacenter2' app_name='ludu-module-datacenter1'
# 定义应用版本 # 定义应用版本
app_version='2.0.0' app_version='1.0.0'
# 定义应用环境 # 定义应用环境
#profile_active='prod' #profile_active='prod'
echo '----stop container----' echo '----stop container----'
@ -13,4 +13,4 @@ docker rmi ${app_name}:${app_version}
echo '----build image----' echo '----build image----'
docker buildx build -f Dockerfile -t ${app_name}:${app_version} . docker buildx build -f Dockerfile -t ${app_name}:${app_version} .
echo '----start container----' echo '----start container----'
docker run -d -p 9091:48092 --name ${app_name} ${app_name}:${app_version} docker run -d -p 48092:48092 --name ${app_name} ${app_name}:${app_version}

View File

@ -9,24 +9,25 @@ import org.springframework.context.annotation.Primary;
import java.net.InetAddress; import java.net.InetAddress;
import java.net.UnknownHostException; import java.net.UnknownHostException;
@Configuration // TODO 由于datacenter走网关内网不指定外网IP和端口自动获取本地
//@Configuration
public class BeanInit { public class BeanInit {
/** /**
* 用于改变程序自动获取的本机ip * 用于改变程序自动获取的本机ip
*/ */
@Value("${spring.profiles.active}") // @Value("${spring.profiles.active}")
private String activeEnv; // private String activeEnv;
@Bean // @Bean
@Primary // @Primary
public NacosDiscoveryProperties nacosProperties() throws UnknownHostException { // public NacosDiscoveryProperties nacosProperties() throws UnknownHostException {
NacosDiscoveryProperties nacosDiscoveryProperties = new NacosDiscoveryProperties(); // NacosDiscoveryProperties nacosDiscoveryProperties = new NacosDiscoveryProperties();
if ("dev".equals(activeEnv)){ // if ("dev".equals(activeEnv)){
// 直接指定域名 // // 直接指定域名
String customIp = "120.46.37.243"; // 替换为你的域名 // String customIp = "120.46.37.243"; // 替换为你的域名
int customPort = 9091; // 替换为你的端口 // int customPort = 9091; // 替换为你的端口
nacosDiscoveryProperties.setIp(customIp); // nacosDiscoveryProperties.setIp(customIp);
nacosDiscoveryProperties.setPort(customPort); // nacosDiscoveryProperties.setPort(customPort);
} // }
return nacosDiscoveryProperties; // return nacosDiscoveryProperties;
} // }
} }