diff --git a/.gitea/workflows/master_sellrt_build_manual.yaml b/.gitea/workflows/master_sellrt_build_manual.yaml
index 9d50316..635fa02 100644
--- a/.gitea/workflows/master_sellrt_build_manual.yaml
+++ b/.gitea/workflows/master_sellrt_build_manual.yaml
@@ -4,8 +4,7 @@ on:
jobs:
build_and_deploy:
- runs-on: java21
-
+ runs-on: ubuntu-latest
outputs:
build_status: ${{ job.status }}
build_url: ${{ gitea.server_url }}/${{ gitea.repository.owner.name }}/${{ gitea.repository.name }}/actions/runs/${{ gitea.run_id }}
@@ -15,7 +14,7 @@ jobs:
packages: write
env:
- REMOTE_DEPLOY_PATH: /workspace/workspace_aida/DevelopVersion/master-aida-seller-back
+ REMOTE_DEPLOY_PATH: /workspace/workspace_aida/DevelopVersion/develop-MS-version-aida-back
steps:
- name: 0.记录开始时间
@@ -25,22 +24,54 @@ jobs:
- name: 1.检出代码
uses: actions/checkout@v4
with:
- ref: master
+ ref: dev/3.1_release_merge_MS
-
- - name: 3.缓存 Maven 依赖
- uses: actions/cache@v5
+ - name: 2.Set up JDK 21
+ uses: actions/setup-java@v5
with:
- path: ~/.m2/repository
- key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }}
- restore-keys: |
- ${{ runner.os }}-maven-
+ java-version: '21'
+ distribution: 'temurin'
- - name: 4.构建项目
+ - name: 3.设置JAVA Maven 环境
run: |
- java -version
- mvn -v
- mvn clean package -DskipTests
+ # 适配root/普通用户
+ SUDO=""
+ [ "$(id -u)" != "0" ] && SUDO="sudo"
+
+ # 安装依赖
+ $SUDO apt update && $SUDO apt install -y wget tar --no-install-recommends
+
+ # 下载Maven
+ MAVEN_VERSION="3.9.11"
+ MAVEN_TAR="apache-maven-${MAVEN_VERSION}-bin.tar.gz"
+ MAVEN_URL="https://archive.apache.org/dist/maven/maven-3/${MAVEN_VERSION}/binaries/${MAVEN_TAR}"
+ wget --no-verbose -O /tmp/${MAVEN_TAR} ${MAVEN_URL}
+
+ # 解压+软链接
+ $SUDO tar -xzf /tmp/${MAVEN_TAR} -C /usr/local/
+ $SUDO ln -sf /usr/local/apache-maven-${MAVEN_VERSION} /usr/local/maven
+
+ # 配置PATH
+ echo "/usr/local/maven/bin" >> $GITHUB_PATH
+ export PATH="/usr/local/maven/bin:$PATH"
+
+ # 验证
+ mvn -v
+
+ - name: 4.构建jar包
+ run: |
+ echo "===== 开始构建JAR包 ====="
+ # 新增:打印当前构建分支(两种方式双重确认)
+ echo "当前工作目录分支:$(git branch --show-current)"
+ echo "Gitea检出分支:${{ github.ref_name }}"
+ echo "预期构建分支:dev/3.1_release_merge_MS"
+ echo "========================"
+ mvn -B clean install -DskipTests -Pdev 2>&1
+ # 检查构建是否成功
+ if [ $? -ne 0 ]; then
+ echo "JAR包构建失败!"
+ exit 1
+ fi
- name: 5.生成Dockerfile
run: |
@@ -50,7 +81,7 @@ jobs:
VOLUME /tmp
RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
RUN echo 'Asia/Shanghai' > /etc/timezone
- ADD ./aida-seller-1.0.0.jar /app.jar
+ ADD ./aida-0.0.1-SNAPSHOT.jar /app.jar
ENTRYPOINT ["java","-jar","/app.jar"]
EOF
echo "Dockerfile内容:"
@@ -62,8 +93,8 @@ jobs:
cat > docker-compose.yml << 'EOF'
version: '3'
services:
- master-aida-seller:
- container_name: master-aida-seller
+ aida_back:
+ container_name: develop-aida-ms
build: .
volumes:
# 数据挂载
@@ -71,41 +102,79 @@ jobs:
- ./temp:/temp
- ./uploads:/temp/uploads
ports:
- - '10093:10093'
+ - '10092:10092'
+ networks:
+ - aida_java_net
restart: always
+ networks:
+ aida_java_net:
+ external: true
+ name: aida_java_net
EOF
# 验证docker-compose.yml生成
echo "docker-compose.yml内容:"
cat docker-compose.yml
- - name: 7.上传jar到远程服务器
- uses: appleboy/scp-action@master
- with:
- host: ${{ secrets.SERVER_HOST }}
- port: 22
- username: ${{ secrets.SERVER_USER }}
- key: ${{ secrets.SSH_KEY }}
- source: "target/*.jar,Dockerfile,docker-compose.yml"
- target: ${{ env.REMOTE_DEPLOY_PATH }}
- preserve_host_directory_structure: false
+ - name: 7.安装SSH工具
+ run: |
+ $SUDO apt install -y sshpass openssh-client --no-install-recommends
+ # 配置SSH免密
+ mkdir -p ~/.ssh
+ echo "${{ secrets.SSH_KEY }}" > ~/.ssh/id_rsa
+ chmod 600 ~/.ssh/id_rsa
+ ssh-keyscan -H ${{ secrets.SERVER_HOST }} >> ~/.ssh/known_hosts
- - name: 8. 重启 Docker 服务
- uses: appleboy/ssh-action@master # 👈 专门执行命令的 action
- with:
- host: ${{ secrets.SERVER_HOST }}
- username: ${{ secrets.SERVER_USER }}
- key: ${{ secrets.SSH_KEY }}
- key_base64: true
- script: |
- echo "========= 进入部署目录 ========="
+ - name: 8.同步文件到远程服务器
+ run: |
+ echo "===== 同步文件到远程服务器 ====="
+ # 使用scp同步文件
+ scp -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null \
+ ./target/*.jar ./Dockerfile ./docker-compose.yml \
+ ${{ secrets.SERVER_USER }}@${{ secrets.SERVER_HOST }}:${{ env.REMOTE_DEPLOY_PATH }} 2>&1
+
+ - name: 9.部署和运行服务
+ run: |
+ echo "===== 开始部署服务 ====="
+ # SSH执行部署命令
+ ssh -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null \
+ ${{ secrets.SERVER_USER }}@${{ secrets.SERVER_HOST }} << 'EOF_SSH'
cd ${{ env.REMOTE_DEPLOY_PATH }}
- ls -l
-
- echo "========= 停止旧服务 ========="
- docker compose down
-
- echo "========= 启动新服务 ========="
- docker compose up -d --build
-
- echo "========= 查看运行状态 ========="
- docker compose ps
\ No newline at end of file
+ echo "停止旧容器..."
+ docker compose down || true
+ echo "构建镜像..."
+ docker compose build --no-cache
+ echo "启动服务..."
+ docker compose up -d
+ echo "验证容器状态..."
+ docker compose ps
+ echo "部署完成!"
+ EOF_SSH
+
+ - name: 10.发送构建结果邮件
+ if: always() # 无论上一步是否失败,都执行此步骤
+ uses: dawidd6/action-send-mail@v3
+ with:
+
+ from: ${{ secrets.MAIL_USERNAME }}
+ # --- 邮件配置 ---
+ server_address: smtp.gmail.com # 替换为你的SMTP服务器地址
+ server_port: 465 # 替换为你的SMTP端口 (通常是465或587)
+ username: ${{ secrets.MAIL_USERNAME }} # 存储在Secrets中的邮箱用户名
+ password: ${{ secrets.MAIL_PASSWORD }} # 存储在Secrets中的邮箱密码
+ subject: 'Gitea Actions 构建通知: ${{ job.status }} - AiDA back-java Develop'
+ # 收件人列表,可以根据需要更改
+ to: 'cgzhou@aidlab.hk,zchengrong@yeah.net' # 替换为实际收件人邮箱
+
+ # --- 邮件正文内容 ---
+ body: |
+ 项目: AiDA back-java Develop
+ 分支: dev/3.1_release_merge_MS
+
+ 🎉 构建结果: ${{ job.status }}
+
+ 📅 构建时间: ${{ steps.build_start_time.outputs.current_time }}
+
+ 🔗 构建链接: ${{ gitea.server_url }}/${{ gitea.repository.owner.name }}/${{ gitea.repository.name }}/actions/runs/${{ gitea.run_id }}
+
+ # 确保邮件内容为纯文本,或者你可以设置为 html: true 并调整 body
+ content_type: text/plain
\ No newline at end of file
diff --git a/src/main/resources/logback-spring.xml b/src/main/resources/logback-spring.xml
index a8ff19d..35c4763 100644
--- a/src/main/resources/logback-spring.xml
+++ b/src/main/resources/logback-spring.xml
@@ -3,7 +3,7 @@
-
+