当前位置: 首页 > news >正文

使用 Docker Compose 部署 Jenkins(LTS 版)持续集成环境

一、前言

Jenkins 是目前最流行的开源持续集成工具之一。本教程将手把手带你使用 Docker Compose 快速部署 Jenkins LTS(长期支持版本),同时保留数据持久化、Docker 命令转发等功能,适合用于生产或本地开发测试环境。


二、环境准备

确保你的 Linux 系统中已安装以下软件:

  • Docker(建议 20.x+)
  • Docker Compose(建议 2.x+)

检查版本:

docker -v
docker compose version

三、创建目录结构

mkdir -p ~/jenkins-docker
cd ~/jenkins-docker# 创建用于数据持久化的目录
mkdir -p /home/jenkins

建议将 /home/jenkins 权限赋给非 root 用户,例如当前用户:

sudo chown -R 1000:1000 /home/jenkins

其中 1000:1000 是 Jenkins 容器中的默认运行用户 ID。


四、创建 docker-compose.yml

~/jenkins-docker 目录下创建 docker-compose.yml 文件:

services:jenkins:image: jenkins/jenkins:lts  # 使用官方 LTS 版本container_name: jenkinsuser: "1000:1000"ports:- "8080:8080"     # Jenkins Web UI- "50000:50000"   # JNLP Agent 通信端口volumes:- /home/jenkins:/var/jenkins_home         # 持久化 Jenkins 数据- /var/run/docker.sock:/var/run/docker.sock  # 容器内访问宿主机 Dockerrestart: unless-stopped

五、启动 Jenkins

执行以下命令启动 Jenkins:

docker compose up -d

首次启动后,你可以访问 Jenkins Web UI:

http://<你的IP>:8080

查看初始管理员密码:

cat /home/jenkins/secrets/initialAdminPassword

复制后粘贴进浏览器完成首次配置(安装插件等)。


六、常用命令

操作命令
启动 Jenkinsdocker compose up -d
查看日志docker compose logs -f
停止 Jenkinsdocker compose down
进入容器内部docker exec -it jenkins bash

七、常见问题与建议

  1. 权限问题:
    如果 Jenkins 容器内出现权限错误,确保挂载目录 /home/jenkins 的属主为 1000:1000

  2. 容器内无法使用 docker 命令:
    因为 /var/run/docker.sock 被挂载到容器内,你可以安装 Docker CLI:

    docker exec -it jenkins bash
    apt update && apt install docker.io -y
    
  3. 数据备份:
    定期备份 /home/jenkins 目录,以防数据丢失。


八、总结

通过本文你已经成功使用 Docker Compose 部署了 Jenkins LTS 环境。这种方式不仅便于管理,还可以轻松迁移与扩展。

如需进一步配合 GitLab、Maven、Nexus 或 Kubernetes 进行 CI/CD,可以在 Jenkins 安装相关插件并配置流水线。

http://www.lqws.cn/news/189145.html

相关文章:

  • JAVA-什么是JDK?
  • TP6 实现一个字段对数组中的多个值进行LIKE模糊查询(OR逻辑)
  • HTTP协议
  • 影楼精修-AI衣服祛褶皱算法解析
  • LLM Agent 如何颠覆股价预测的传统范式
  • PL/SQLDeveloper中数值类型字段查询后显示为科学计数法的处理方式
  • 高效复用 Cursor 请求,提升开发效率 —— 使用 interactive-feedback-mcp 工具详解
  • 三维GIS开发cesium智慧地铁教程(4)城市白模加载与样式控制
  • Python 训练营打卡 Day 45
  • 【001】frida API分类 总览
  • css元素的after制作斜向的删除线
  • 飞云智能波段主图+多空短线决策副图指标,组合操盘技术图文解说
  • SpringCloud学习笔记-2
  • 【Elasticsearch】映射:Nested 类型
  • day46python打卡
  • 【Linux】虚拟机代理,自动化脚本修改~/.bashrc
  • vue3子组件获取并修改父组件的值
  • 【计算机网络】非阻塞IO——poll实现多路转接
  • 【佳易王个体诊所电子处方软件】助力智慧诊疗! #医疗数字化 #电子处方效率提升
  • 【 知你所想 】基于ernie-x1-turbo推理模型实现趣味猜心游戏
  • QT自定义资源管理器
  • 使用UDP连接ssh
  • maven私服
  • vanna+deepseek+chainlit 实现自然语言转SQL的精度调优
  • Auto-Coder使用GPT-4o完成:在用TabPFN这个模型构建一个预测未来3天涨跌的分类任务
  • MySQL 性能调优入门 - 慢查询分析与索引优化基础
  • 行业案例 | ASOS 借助 Azure AI Foundry(国际版)为年轻时尚爱好者打造惊喜体验
  • [electron]预脚本不显示内联script
  • AIGC 基础篇 Python基础 01
  • [特殊字符]解决 “IDEA 登录失败。不支持早于 14.0 的 GitLab 版本” 问题的几种方法