Jenkins 流水线全流程实战笔记
核心架构思路
- 宿主机 (VPS):只安装 Docker,作为底层基座。
- Jenkins 容器:作为“指挥官”。
- 特权:挂载
/var/run/docker.sock,使其拥有调用宿主机 Docker 的能力(即 Docker-in-Docker)。 - 环境:通过自定义
Dockerfile,内置 JDK 8 (用于编译旧项目) 和 Maven。
- 特权:挂载
- 应用容器:由 Jenkins 指挥宿主机 Docker 生成并运行的最终服务。
第一阶段:搭建 Jenkins 基础设施
这一步的目标是构建一个**“全能版”**的 Jenkins 镜像,解决官方镜像没有 Maven 和 JDK 8 的问题。
1. 编写 Jenkins 基座 Dockerfile
文件名:Dockerfile(位于 Jenkins 部署目录)
Dockerfile
# 基础镜像:官方最新 Jenkins LTS FROM jenkins/jenkins:lts USER root # 1. 换源并安装基础工具 (Maven, Docker CLI) # 注意:这里安装 Docker CLI 是为了在容器内能敲 docker 命令 RUN apt-get update && \ apt-get install -y maven docker.io wget tar # 2. 【关键】手动安装 JDK 8 # 原因:Jenkins 新版运行需要 JDK 11/17,但我们的项目需要 JDK 8 编译 # 方案:从 Temurin 官方源下载解压,后续在流水线中通过环境变量指定路径 RUN wget -q https://github.com/adoptium/temurin8-binaries/releases/download/jdk8u402-b06/OpenJDK8U-jdk_x64_linux_hotspot_8u402b06.tar.gz -O /tmp/jdk8.tar.gz && \ mkdir -p /opt/jdk8 && \ tar -xzf /tmp/jdk8.tar.gz -C /opt/jdk8 --strip-components=1 && \ rm /tmp/jdk8.tar.gz # 3. 验证环境安装 RUN /opt/jdk8/bin/java -version && mvn -v && docker -v2. 编排服务 docker-compose.yml
文件名:docker-compose.yml
YAML
version: '3.8' services: jenkins: # "build: ." 表示使用当前目录的 Dockerfile 构建镜像,而不是直接拉取 build: . container_name: jenkins-pro restart: always ports: - "9090:8080" # 面板端口:宿主机 9090 -> 容器 8080 - "50000:50000" # 如果有从节点连接需要此端口 volumes: - ./jenkins_data:/var/jenkins_home # 数据持久化 - /var/run/docker.sock:/var/run/docker.sock # 【核心】挂载 Docker 守护进程 - /usr/bin/docker:/usr/bin/docker # 映射 Docker 二进制文件3. 启动与初始化
# 构建镜像并后台启动容器(串行执行:先 build 后 up) docker compose up -d --build- 解锁与安装:
- 查看初始密码:
docker logs -f jenkins-pro - 访问
http://<你的IP>:9090,输入密码。 - 选择“安装推荐插件”。
- 安装Gitee Plugin(系统管理 -> 插件管理)。
- 配置 Gitee 凭证 (API 令牌或账号密码) 和全局配置。
- 查看初始密码:
第二阶段:项目配置 (Git 仓库端)
这一步体现了Pipeline as Code (流水线即代码)的思想,将构建逻辑存放在代码仓库中。
1. 项目应用 Dockerfile
文件名:Dockerfile(位于项目根目录)
Dockerfile
# 运行阶段只需要 JRE,使用 alpine 版本体积最小 FROM eclipse-temurin:8-jre-alpine WORKDIR /app VOLUME /tmp # 拷贝编译后的 jar 包 (注意:这是 Jenkins 在上一阶段 maven package 生成的) COPY target/*.jar app.jar EXPOSE 8080 ENTRYPOINT ["java", "-jar", "app.jar"]2. 流水线脚本 Jenkinsfile
文件名:Jenkinsfile(位于项目根目录)
Groovy
pipeline { agent any // 【环境变量】强制指定使用我们在 Jenkins 容器里装好的 JDK 8 environment { JAVA_HOME = "/opt/jdk8" PATH = "/opt/jdk8/bin:$PATH" APP_NAME = "my-boot-app" } stages { stage('1. 环境检测') { steps { sh "java -version" // 确认是 1.8 sh "mvn -v" } } stage('2. 拉取代码') { steps { // 读取 Jenkins 任务配置的 Git 地址和凭证 ,scm代替了git clone checkout scm } } stage('3. 编译打包') { steps { // 跳过测试,利用外网环境快速下载依赖并打包 sh "mvn clean package -DskipTests" } } stage('4. Docker发布') { steps { script { // 利用挂载的 docker.sock,在宿主机上构建镜像 sh "docker build -t ${APP_NAME}:latest ." // 清理旧容器 (|| true 防止首次运行报错) sh "docker rm -f ${APP_NAME} || true" // 启动新容器,映射端口到宿主机 sh "docker run -d -p 8080:8080 --name ${APP_NAME} ${APP_NAME}:latest" } } } } }第三阶段:触发自动化 (Webhook)
实现Git Push -> 自动发布的闭环。
- Jenkins 端:
- 新建 Item -> 选择Pipeline (流水线)。
- 流水线定义:选择
Pipeline script from SCM-> Git -> 填入仓库地址。 - 构建触发器:勾选
Gitee webhook 触发构建,生成并复制WebHook 密码。
- Gitee 端:
- 仓库管理 -> WebHooks -> 添加。
- 填入 Jenkins 给出的 URL 和 密码。
- 事件勾选
Push。
总结:数据流向图
- 开发提交:你本地 IDEA
git push代码。 - 触发通知:Gitee 通过 Webhook 通知 Jenkins “有新代码了”。
- 环境准备:Jenkins 启动流水线,加载 JDK 8 环境。
- 编译构建:Jenkins 执行
mvn package,生成target/xxx.jar。 - 镜像制作:Jenkins 调用宿主机的 Docker,读取项目
Dockerfile,把 jar 包打成镜像。 - 服务部署:Jenkins 销毁旧容器,启动新容器(端口 8080)。
最终效果:代码提交后,喝杯水的功夫,服务器上的应用已经自动更新为最新版本。