Jenkins简介及Docker Compose部署

简介: Jenkins是一个开源的自动化服务器,用于自动化构建、测试和部署软件项目。它提供了丰富的插件生态系统,支持各种编程语言和工具,使得软件开发流程更加高效和可靠。在本文中,我们将介绍Jenkins的基本概念,并展示如何使用Docker Compose轻松部署Jenkins服务。

Jenkins是一个开源的自动化服务器,用于自动化构建、测试和部署软件项目。它提供了丰富的插件生态系统,支持各种编程语言和工具,使得软件开发流程更加高效和可靠。在本文中,我们将介绍Jenkins的基本概念,并展示如何使用Docker Compose轻松部署Jenkins服务。

jenkins.jpg

Jenkins简介

Jenkins的主要功能包括:

  • 持续集成(CI): Jenkins通过定期检查版本控制系统中的变更,触发构建和测试过程,以确保代码的稳定性。

  • 持续交付(CD): Jenkins支持自动化部署,使得软件的交付过程更加可靠和可重复。

  • 插件生态系统: Jenkins拥有庞大而活跃的插件生态系统,涵盖了几乎所有现代软件开发中可能用到的工具和技术。

  • 易扩展性: Jenkins采用Java编写,易于扩展和定制,可以满足各种复杂的构建和部署需求。

Docker Compose部署Jenkins

步骤一:构建镜像

我在此处是直接在镜像jenkinsci/jenkins:latest的基础上配置了自己使用版本的java、node、maven,也可以直接使用原镜像,然后在Jenkins的页面上进行插件配置下载。

Dockerfile

# 基础镜像
FROM jenkinsci/jenkins:latest

# 维护者信息
MAINTAINER "xj"

# 镜像用户
USER root

# 拷贝NODE安装文件到容器
ADD ./node-v14.16.0-linux-x64.tar.gz /home

#配置node
RUN mv /home/node-v14.16.0-linux-x64 /home/node \
  && ln -s /home/node/bin/node /usr/bin/node \
  && ln -s /home/node/bin/npm /usr/bin/npm

# 拷贝MAVEN安装文件到容器
ADD ./apache-maven-3.8.1-bin.tar.gz /home
RUN mv /home/apache-maven-3.8.1 /home/maven \
  && mkdir /home/maven/repository \
  && rm /home/maven/conf/settings.xml
ADD ./settings.xml /home/maven/conf/settings.xml

#配置maven
RUN ln -s /home/maven/bin/mvn /usr/bin/mvn

# 拷贝jdk安装文件到容器
ADD ./jdk-8u361-linux-x64.tar.gz /home
# 配置jdk
RUN mv /home/jdk1.8.0_361 /home/jdk \
  && ln -snf /home/jdk/bin/java /usr/bin/java

# 切换目录
WORKDIR /home

步骤二:创建Docker Compose文件

创建一个名为docker-compose.yml的文件,用于定义Jenkins服务及其依赖项。示例如下:

docker-compose.yml

version: "3.3"
services:
  jenkins:
    image: xj/jenkins:1.0
    container_name: jenkins
    restart: always
    privileged: true
    environment:
      TZ: 'Asia/Shanghai'
    ports:
      - 9003:8080
      - 50000:50000
    volumes:
      - ./data/jenkins_home:/var/jenkins_home
# 安装过程中会出现 Docker 数据卷 权限问题,用以下命令解决:
# sudo chown -R 1000 ./data

如果不需要自己构建镜像的话把image替换为jenkinsci/jenkins:latest即可。

步骤三:运行容器

在docker-compose.yml的同级目录下执行如下命令启动容器:

docker-compose up -d

查看容器日志

docker-compose logs -f

如果出现一下截图,则说明容器启动成功

_20231112212117.jpg

访问Jenkins Web界面,完成Jenkins安装

当Docker容器启动完成后,可以通过浏览器访问http://192.168.10.106:9003来打开Jenkins的Web界面。首次访问时,您需要提供初始管理员密码,该密码会在上述启动的容器日志中打印,也可以在/var/jenkins_home/secrets/initialAdminPassword文件中查看。

_20231112222516.jpg

输入密码之后会进入到插件安装界面,我们此处选择的是建议安装插件,你也可以自行选择插件安装。

_20231112222617.jpg

点击之后会进入到插件安装进度的页面

_20231112222631.jpg

安装好之后进入管理员密码设置页面,设置之后我们就可以使用jenkins了

_20231112235055.jpg

具体项目自动构建打包部署我们虾片文章再介绍

总结

通过使用Docker Compose,我们轻松地部署了Jenkins服务,并使其在容器环境中运行。这为我们提供了一个独立、可移植且易于维护的Jenkins实例。希望这篇文章对您理解Jenkins以及如何使用Docker Compose进行部署有所帮助。

目录
相关文章
|
9天前
|
搜索推荐 应用服务中间件 数据安全/隐私保护
【Docker项目实战】使用Docker部署Organizr个人导航页
【Docker项目实战】使用Docker部署Organizr个人导航页
157 75
【Docker项目实战】使用Docker部署Organizr个人导航页
|
9天前
|
存储 测试技术 数据安全/隐私保护
【Docker项目实战】使用Docker部署dufs文件服务器
【Docker项目实战】使用Docker部署dufs文件服务器
76 16
【Docker项目实战】使用Docker部署dufs文件服务器
|
11天前
|
供应链 测试技术 开发者
用 Docker 轻松部署 ERPNext 15:多场景实战指南
ERPNext 15 是一款功能全面的开源企业资源规划系统,结合 Docker 容器化部署,具备高效、灵活、低成本等优势。适用于小微企业数字化起步、多分支机构协同办公、开发者测试环境搭建、短期项目管理及企业内部培训等多种场景。模块化设计支持按需扩展,满足不同规模企业需求,是实现高效企业管理的理想选择。
用 Docker 轻松部署 ERPNext 15:多场景实战指南
|
16天前
|
应用服务中间件 nginx Docker
静态资源管理:Nginx在Docker中的部署
部署Nginx到Docker中作为静态资源服务器是一种既简单又高效的方法,可以节省时间和资源,并能确保一致性和可扩展性。我们通过编写Dockerfile指定了基础镜像和所需指令,编写Nginx配置管理请求处理,构建自定义Docker镜像,并运行容器以启动服务。这一过程即符合开发规范,也保证了资源的高效管理和访问速度。
74 13
|
19天前
|
弹性计算 关系型数据库 Nacos
低配阿里云 ECS 如何 docker 环境部署 NACOS : 单机版模式
NACOS 单机版 Docker 安装指南。使用指定端口和 custom.env 配置文件启动 Nacos 服务,适用于 2.X 版本,包含 gRPC 支持及 MySQL 数据源配置。 -e MODE=standalone \
91 5
|
16天前
|
Prometheus 监控 Cloud Native
Docker 部署 Prometheus 和 Grafana 监控 Spring Boot 服务
Docker 部署 Prometheus 和 Grafana 监控 Spring Boot 服务实现步骤
|
19天前
|
关系型数据库 Linux Nacos
Rocky Linux 部署 Docker 和 NACOS 实例
本文介绍在阿里云环境下基于 Rocky Linux 搭建 Docker 并部署 Nacos 的完整流程。涵盖 Docker 安装、镜像加速配置、网络设置及 MySQL 与 Nacos 容器的创建,适用于开发与生产环境。
87 0
|
存储 机器学习/深度学习 中间件
快速上手 Elasticsearch:Docker Compose 部署详解
本文介绍了如何使用Docker Compose快速搭建Elasticsearch学习环境。Elasticsearch是一款用于实时搜索和分析的分布式中间件,适用于多种场景,如搜索、日志分析、机器学习等。首先,创建docker网络,拉取最新版8.12.2镜像。接着,编写docker-compose.yml文件,配置单节点集群,设置端口映射、内存限制及数据卷挂载。然后,创建并配置数据卷目录,允许远程访问和跨域。最后,启动服务并验证,通过浏览器访问确认服务运行正常。本文为初学者提供了一个简便的Elasticsearch部署方法。
1278 4
快速上手 Elasticsearch:Docker Compose 部署详解
|
存储 数据可视化 数据安全/隐私保护
使用 Docker Compose 部署 Docker Registry
【1月更文挑战第2天】 在内网环境中,我们期望能够在本地共享镜像。为了解决这一问题,Docker Registry成为了我们的救星。Docker Registry是一个用于存储和管理Docker镜像的开源工具。通过在本地部署Docker Registry,您可以轻松地构建、存储和分享自己的Docker镜像。
656 3
使用 Docker Compose 部署 Docker Registry
|
Java Docker 微服务
如何使用Docker和Docker Compose部署微服务
【2月更文挑战第12天】
1030 0