news 2026/6/10 13:56:21

蓝易云 - Java+Github+Jenkins部署

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
蓝易云 - Java+Github+Jenkins部署

蓝易云|Java + GitHub + Jenkins 一键式部署(从提交到上线的最小可用闭环)🚀

面向 2026 的默认建议:JDK 选Java 25 LTS(或保守用 Java 21 LTS),Jenkins 选LTS分支,保证“可升级、可回滚、可审计”。JDK 25 已在 2025-09-16 GA 且为 LTS。(openjdk.org) Jenkins LTS 会持续调整运行时 Java 要求(新 LTS 逐步走向 Java 17/21 作为底座)。(Jenkins)


目标架构(你要的不是“能跑”,而是“可运营”)🙂

flowchart LR A[GitHub Push/PR] --> B[Webhook 触发] B --> C[Jenkins Pipeline <span style="color:#e53935;font-weight:700;">Jenkinsfile</span>] C --> D[编译/单测/制品] D --> E[部署: Docker 或 systemd] E --> F[健康检查/回滚/通知]

1)Jenkins 用 Docker 起一个“标准化控制面”✅

docker run -d --name jenkins \ -p 8080:8080 -p 50000:50000 \ -v jenkins_home:/var/jenkins_home \ jenkins/jenkins:lts

解释:

  • -d:后台运行,避免占用当前终端。

  • -p 8080:8080:把 Jenkins Web 控制台映射到宿主机 8080。

  • -p 50000:50000:Jenkins agent 通信端口(后续分布式构建用)。

  • -v jenkins_home:...:把配置与任务数据做持久化,不然容器一重启你就“失忆”。

  • jenkins/jenkins:lts:用 LTS 线,升级节奏更稳;LTS 基线按周期选取并持续回补修复。(Jenkins)


2)把 GitHub 接进来:触发机制要“确定”🔔

Jenkins 侧(Pipeline Job)

在 Jenkins 创建Pipeline类型任务,源码选择 Git,凭据使用Credentials管理;Declarative Pipeline 支持credentials()注入密钥,避免把 Token 写进仓库。(Jenkins)

GitHub 侧(Webhook)

在仓库配置 Webhook,指向 Jenkins 的.../github-webhook/(路径固定)。这样每次 push/PR 就能触发构建;注意只触发你允许的分支(例如 main/release),避免“随手一推全线上线”的喜剧事故。


3)核心交付物:一份精简但可扩展的 Jenkinsfile 🧩

pipeline { agent any environment { DOCKERHUB = credentials('dockerhub-cred') // <span style="color:#e53935;font-weight:700;">密钥托管</span> } stages { stage('Checkout') { steps { checkout scm } } stage('Build&Test') { steps { sh 'mvn -U -e -DskipTests=false test package' } } stage('Docker Build') { steps { sh 'docker build -t myapp:${BUILD_NUMBER} .' } } stage('Deploy') { steps { sh 'docker compose up -d --no-deps --build app' } } } post { always { archiveArtifacts artifacts: 'target/*.jar', fingerprint: true } } }

逐段解释:

  • pipeline { ... }:定义流水线骨架,Declarative 语法可读性更强,适合团队协作。(Jenkins)

  • agent any:在任意可用节点执行;后续你可以把构建与部署拆到不同 agent,做权限隔离。

  • environment + credentials():把账号密钥放在 Jenkins 管控面,仓库只存逻辑不存秘密。(Jenkins)

  • Checkout:拉代码,保证构建基于“可追溯版本”。

  • mvn ... test package:先测再打包,避免把 bug 当成版本发布(这类成本最高)。

  • docker build:把运行环境与应用打成不可变镜像,减少“我本地能跑”的争议。

  • docker compose up -d ...:滚动重建并拉起服务;--no-deps避免无关依赖被误重启。

  • post always + archiveArtifacts:归档 jar 作为制品证据链,方便回滚与审计。


4)原理解释表(把风险点提前关进流程里)📌

环节关键控制点为什么重要常见坑
触发Webhook + 分支白名单防止误触发上线所有分支都触发
构建单测 + 可重复构建缺陷前移、降低返工跳过测试赶进度
制品制品归档回滚有抓手线上版本不可追溯
部署不可变镜像/幂等发布稳定、可回退手工改服务器
安全凭据托管/最小权限降低泄露面Token 写进仓库

你可以立刻落地的两条路线(务实选择)

  • 追求速度:Docker + Compose 直接部署(上面 Jenkinsfile 已覆盖)🙂

  • 追求管控:制品推到制品库,再由发布机拉取并 systemd 托管(适合更严格的权限分层)

如果你告诉我:你的项目是Spring Boot jar还是多模块 Maven,以及部署目标是单机还是多台,我可以把 Jenkinsfile 精准改成“可直接复制上线”的生产版(包含健康检查、灰度与一键回滚)。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 12:59:47

软考老金如何破解纸上谈兵?

软考高项培训界素有两大流派&#xff1a;「学院派」与「实战派」。一、 理论架构软考老金老师&#xff08;实战派宗师&#xff09;&#xff1a;他的理论架构是 「从战场反推的作战地图」 。同样是讲49个过程&#xff0c;他不是按书本顺序&#xff0c;而是按 「一个真实项目从启…

作者头像 李华
网站建设 2026/6/10 12:58:45

智能抠图Rembg部署教程:从零开始搭建图像去背景服务

智能抠图Rembg部署教程&#xff1a;从零开始搭建图像去背景服务 1. 引言 1.1 智能万能抠图 - Rembg 在电商、设计、内容创作等领域&#xff0c;图像去背景是一项高频且关键的需求。传统手动抠图耗时耗力&#xff0c;而基于AI的自动抠图技术正在迅速改变这一现状。Rembg&…

作者头像 李华
网站建设 2026/5/31 21:16:00

Rembg环境部署教程:解决常见问题全攻略

Rembg环境部署教程&#xff1a;解决常见问题全攻略 1. 引言 1.1 智能万能抠图 - Rembg 在图像处理领域&#xff0c;背景去除是一项高频且关键的任务&#xff0c;广泛应用于电商展示、设计合成、AI换装等场景。传统手动抠图效率低&#xff0c;而基于深度学习的自动去背技术正…

作者头像 李华
网站建设 2026/6/10 12:58:56

U2NET模型应用:Rembg高精度抠图部署案例详解

U2NET模型应用&#xff1a;Rembg高精度抠图部署案例详解 1. 引言&#xff1a;智能万能抠图 - Rembg 在图像处理与内容创作领域&#xff0c;自动去背景&#xff08;Image Matting / Background Removal&#xff09;是一项高频且关键的需求。无论是电商商品图精修、社交媒体头像…

作者头像 李华
网站建设 2026/6/6 16:43:12

ResNet18物体识别避坑指南:云端预置镜像,3步搞定环境配置

ResNet18物体识别避坑指南&#xff1a;云端预置镜像&#xff0c;3步搞定环境配置 引言 作为一名开发者&#xff0c;当你兴致勃勃地想在本地部署ResNet18进行物体识别时&#xff0c;是否遇到过这样的场景&#xff1a;花了两天时间折腾CUDA版本、PyTorch兼容性、依赖冲突等问题…

作者头像 李华
网站建设 2026/6/6 1:20:29

ResNet18新手指南:怕显存不足?云端随时扩容

ResNet18新手指南&#xff1a;怕显存不足&#xff1f;云端随时扩容 1. 为什么选择ResNet18&#xff1f; ResNet18是计算机视觉领域的经典模型&#xff0c;特别适合新手入门深度学习。它通过残差连接解决了深层网络训练困难的问题&#xff0c;在保持较高精度的同时&#xff0c…

作者头像 李华