Day119 持续集成docker+jenkins

发布于:2025-08-19 ⋅ 阅读:(11) ⋅ 点赞:(0)

Day119 docker+jenkins

1.Dockerfile

Dockerfile 可以用于项目部署。通过编写 Dockerfile,可以将整个项目及其所需的依赖项打包到一个 Docker 镜像中,然后在任何支持 Docker 的环境中部署和运行该镜像

Dockerfile 是用于构建 Docker 镜像的文本文件。它包含一系列的指令,用于描述如何从一个基础镜像构建一个新的镜像,并在其中安装和配置软件环境

1.1 编写Dockerfile

1.1.1 准备工作

1.idea中对springboot项目打包,生产一个jar文件

注意:先clean,再package

在这里插入图片描述

2.jar文件上传到Linux

在这里插入图片描述

1.1.2 创建Dockerfile文件
vim dockerfile

在这里插入图片描述

编写dockerfile ,保存

FROM openjdk:8
MAINTAINER pcb
ADD FrameworkLearn-0.0.1-SNAPSHOT.jar /FrameworkLearn.jar  #前一个是打包之后的名字,后面一个是重命名的名字
EXPOSE 1002  #要和后端项目的一致
ENTRYPOINT ["java","-jar","/FrameworkLearn.jar"]   #重命名的jar名字

在这里插入图片描述

1.1.3 构建镜像 images
docker build -t demo1234:latest -f Dockerfile .

如果没有安装docker,就看Day95 docker安装

1.1.4 查看创建的镜像
docker images

在这里插入图片描述

1.1.5 创建容器
docker run -id --name demo1234 -p 1002:1002 demo:latest   #:1002要和项目的端口一致,前面那个无所谓
docker ps
docker logs -f demo1234

1.2 文件详解

1.2.1 Dockerfile 文件
FROM openjdk:8
MAINTAINER pcb
ADD FrameworkLearn-0.0.1-SNAPSHOT.jar /FrameworkLearn.jar  #前一个是打包之后的名字,后面一个是重命名的名字
EXPOSE 1002  #要和后端项目的一致
ENTRYPOINT ["java","-jar","/FrameworkLearn.jar"]   #重命名的jar名字

1.FROM openjdk:8 :指定基础镜像为 openjdk:8 ,表示该镜像将以 OpenJDK 1.8 作为基础环境

2.MAINTAINER pcb :设置镜像的作者

3.ADD FrameworkLearn-0.0.1-SNAPSHOT.jar /FrameworkLearn.jar :将主机上的 FrameworkLearn-0.0.1-SNAPSHOT.jar 文件添加到镜像中,并指定目标路径为 FrameworkLearn.jar

4.EXPOSE 9999 :声明容器将监听的端口号为 9999,要和后端项目的一致

5.ENTRYPOINT [“java”,“-jar”,“/FrameworkLearn.jar”]:设置容器的入口点,指定在容器启动时要运行的命令。这里的配置表示以 Java 命令执行 /FrameworkLearn.jar 文件,即运行主类为 /FrameworkLearn.jar 的 Java 应用程序

1.2.2 构建镜像
docker build -t demo1234:latest -f Dockerfile .

-t 选项: 用于指定构建镜像后的镜像名称和标签,格式为 -t <镜像名称>:<标签> ,可以自定义镜像名称和标签

-f 选项: 用于指定要使用的 Dockerfile 文件

默认情况下, docker build 命令会在构建上下文中寻找名为 Dockerfile 的文件进行构建

使用 -f 选项可以指定其他名称的 Dockerfile 文件,以便构建时使用不同的 Dockerfile

. 选项: 表示 Dockerfile 文件所在的路径是当前路径

2.Docker Compose

Docker Compose 是一个用于定义和管理多个 Docker 容器的工具。Docker Compose 提供了一种声明性的方式来定义和管理多个 Docker 容器,从而实现服务编排。通过一个单独的 YAML 文件,您可以定义各个服务的配置、依赖关系、网络连接和卷挂载等信息

2.1 安装

第一种:docker-compose离线安装文件:docker-compose-linux-x86_64

下载地址:https://github.com/docker/compose/releases/download/v2.15.1/docker-compose-linux-x86_64

进入/usr/local/bin目录,上传文件,对文件重命名,然后赋予执行权限:

cd /usr/local/bin
mv docker-compose-linux-aarch64 docker-compose
sudo chmod +x docker-compose

查看docker-compose版本号:

docker-compose --version

第二种:sudo curl -L “https://github.com/docker/compose/releases/download/v2.2.2/docker-compose- ( u n a m e − s ) − (uname -s)- (unames)(uname -m)” -o /usr/local/bin/docker-compose 安装

设置权限 sudo chmod +x /usr/local/bin/docker-compose

在这里插入图片描述

2.2 创建MySQL与Redis服务

目标:通过docker-compose创建MySQL与Redis容器

它允许用户通过一个单独的 docker-compose.yml 模板文件(YAML格式)来定义一组相关联的应用容器为一个项目(project)

1.先创建文件:docker-compose.yml

vim docker-compose.yml

2.编写文件(注意:格式缩进问题,yaml格式)

version: "3.0"

services:
  mysqldb:
    image: mysql:8.0
    container_name: mysql
    ports:
      - "3306:3306"
    volumes:
      - /root/mysql/conf:/etc/mysql/conf.d
      - /root/mysql/logs:/logs
      - /root/mysql/data:/var/lib/mysql
    environment:
      MYSQL_ROOT_PASSWORD: root
    depends_on:
      - redis

  redis:
    image: redis:6.2.7
    container_name: redis  
    ports:
      - "6379:6379"
    volumes:
      - /root/redis/data:/data
    command: redis-server

在这里插入图片描述

3.运行文件

# 默认运行当前目录下的 docker-compose.yml 文件;
# 如果 docker-compose.yml 文件不在当前目录,可以使用 -f 选项指定文件路径:
docker-compose up
# -d 将容器设置为在后台运行
docker-compose up -d
# -f 指定文件名
docker-compose -f /path/to/docker-compose.yml up -d

在这里插入图片描述

2.3 测试项目

1.创建一个 init.sql 文件,放在项目目录下

2.创建文件:vim docker-compose-project.yml

version: "3.0"
services:
  mysql:
    image: mysql:8.0
    restart: always
    container_name: mysql8.0
    command: --default-authentication-plugin=mysql_native_password  # 解决外部无法访问
    volumes:
      - ./data:/var/lib/mysql #挂载目录,持久化存储
      - ./init.sql:/docker-entrypoint-initdb.d/init.sql
    ports:
      - "3306:3306" # 容器端口映射到宿主机的端口
    environment:
      MYSQL_ROOT_PASSWORD: 'root'   #设置密码是root,账号是root
      MYSQL_ALLOW_EMPTY_PASSWORD: 'no'
      MYSQL_DATABASE: 'securityrabc'

  mydemo: # 自己单独的springboot项目
    container_name: demo
    hostname: jet
    build: ./  # 需要构建的Dockerfile文件
    ports:
      - "8080:8080"
    depends_on:
      - mysql

  frameworklearn:
    image: openjdk:8-jdk-alpine # 使用Alpine版本的OpenJDK镜像
    container_name: frameworklearn
    working_dir: /root/pcb 
    volumes:
      - ./FrameworkLearn-0.0.1-SNAPSHOT.jar:/root/pcb/FrameworkLearn-0.0.1-SNAPSHOT.jar 
    command: ["java", "-jar", "/root/pcb/FrameworkLearn-0.0.1-SNAPSHOT.jar"] # 启动命令
    ports:
      - "1002:1002"   # 容器端口映射到宿主机的端口
    depends_on: # web服务依赖mysql服务,要等mysql服务先启动
      - mysql  

3.运行

docker-compose -f docker-compose-project.yml up -d

打印日志

docker-compose -f docker-compose-project.yml logs frameworklearn

注意: 服务器要开放1002端口

在这里插入图片描述

代码里面的yaml文件

server:
  # 服务端口
  port: 1002
  # 应用上下文路径
  servlet:
    context-path: /FrameworkLearn
  tomcat:
    uri-encoding: UTF-8

spring:

  # 数据源配置(Druid)
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    driver-class-name: com.mysql.cj.jdbc.Driver
    druid:
      url: jdbc:mysql://mysql:3306/securityrabc?characterEncoding=utf-8 #修改为mysql:3306
      username: root
      password: root

运行 http://47.108.146.63:1002/FrameworkLearn/test1

在这里插入图片描述

3.CICD

3.1 概念

CICD:持续集成/持续发布—开发(git) --> git主库 –> jenkins(git+jdk+tomcat+maven打包+测试)–> 发布到tomcat服务器

Jenkins是一个功能强大的应用程序,允许持续集成和持续交付项目,无论用的是什么平台。这是一个免费的源代码,可以处理任何类型的构建或持续集成。集成Jenkins可以用于一些测试和部署技术,Jenkins是一种软件

3.2 CI / CD 方法简介

软件开发的连续方法基于自动执行脚本,以最大限度地减少在开发应用程序时引入错误的可能性。从新代码的开发到部署,它们需要较少的人为干预甚至根本不需要干预

它涉及在每次小迭代中不断构建,测试和部署代码更改,从而减少基于有缺陷或失败的先前版本开发新代码的机会

这种方法有三种主要方法,每种方法都根据最适合您的策略进行应用。

持续集成( CI):代码合并,构建,部署,测试都在一起,不断地执行这个过程,并对结果反馈

持续部署(CD):部署到测试环境、预生产环境/灰度环境、生产环境

持续交付(CD):将最终产品发布到生产环境、给用户使用

4.Jenkins 姐肯死

概述

Jenkins是帮我们将代码进行统一的编译打包、还可以放到tomcat容器中进行发布

我们通过配置,将以前:编译、打包、上传、部署到Tomcat中的过程交由Jenkins,Jenkins通过给定的代码地址URL(代码仓库地址),将代码拉取到其“宿主服务器”(Jenkins的安装位置),进行编译、打包和发布到Tomcat容器中

Jenkins目标

1.持续、自动地构建/测试软件项目

2.监控软件开放流程,快速问题定位及处理,提高开发效率

Jenkins特性

1.开源的java语言开发持续集成工具,支持CICD

2.易于安装部署配置:可通过yum安装或下载war包以及通过docker容器等快速实现安装部署,可方便web界面配置管理

3.消息通知及测试报告:集成RSS/E-mail通过RSS发布构建结果或当构建完成时通过e-mail通知,生成JUnit测试报告

4.分布式构建:支持Jenkins能够让多台计算机一起构建/测试

工作流程:

1.首先,开发人员将代码提交到 Git 仓库

2.然后 Jenkins 使用 Git 插件来拉取 Git 仓库的代码,然后配合 JDK、Maven 等软件完成代码编译, 测试、审查、测试和打包等工作

3.最后 Jenkins 将生成的 jar/war 推送到 测试/生产 服务器 ,供用户访问

4.整套步骤下来,作为开发人员我们只需要提交下代码,剩下的工作都交给了 Jenkins

在这里插入图片描述

4.1 环境准备

安装jdk、maven、git、docker、docker-compose

4.1.1 安装jdk
yum install java-1.8.0-openjdk.x86_64
java -version

在这里插入图片描述

4.1.2 安装maven

下载 maven linux版本

https://maven.apache.org/download.cgi

在这里插入图片描述

上传到linux 下面的opt下面的soft ,解压到/usr/local/

tar -xvf apache-maven-3.9.11-bin.tar.gz -C /usr/local

在这里插入图片描述

配置maven仓库,设置阿里镜像仓库

cd /usr/local
cd apache-maven-3.9.11
mkdir ck    #创建ck仓库存储目录

在这里插入图片描述

进入cd conf目录,编辑 vi settings.xml文件

配置maven的仓库位置

cd conf   # 进入conf目录
vi settings.xml  # settings.xm文件

<localRepository>/usr/local/apache-maven-3.9.11/ck</localRepository>
    
  <mirror>
      <id>alimaven</id>
      <name>aliyun maven</name>
       <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
      <mirrorOf>central</mirrorOf>
</mirror>

在这里插入图片描述

在这里插入图片描述

配置maven环境变量

vi /etc/profile

export MAVEN_HOME=/usr/local/apache-maven-3.6.3
export PATH=$PATH:$MAVEN_HOME/bin

source /etc/profile #重新加载,使新增配置生效

在这里插入图片描述

mvn -v

在这里插入图片描述

4.1.3 安装git
yum -y install git # 安装
git version # 安装是否成功

在这里插入图片描述

4.2 安装Jenkins

1.下载rpm文件:Index of jenkins-local/redhat,选择合适的版本。这里我选择了jenkins-2.344-1.1.noarch.rpm,因为低版本很多插件不支持,要更新版本

2.新建目录存放安装包

cd /opt
 
mkdir jenkins # 新建目录
 
rpm -ivh jenkins-2.344-1.1.noarch.rpm # 上传.rpm文件之后,安装

在这里插入图片描述

3.查看Jenkins的相关目录:rpm -ql jenkins

在这里插入图片描述

4.修改配置文件 vim /usr/lib/systemd/system/jenkins.service

# 修改用户和权限
User=root
Group=root
 
# 修改JDK路径
Environment="/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.462.b08-2.0.1.1.al8.x86_64/jre"  
 
# 修改启动端口
Environment="JENKINS_PORT=36080"

在这里插入图片描述

在这里插入图片描述

5.刷新配置文件 systemctl daemon-reload

6.开启防火墙和指定端口

# 开启防火墙
systemctl start firewalld
# 开放指定端口
firewall-cmd --zone=public --add-port=36080/tcp --permanent
# 重启防火墙
firewall-cmd --reload
# 查看所有端口使用情况
netstat -ntlp   

7.服务器开放63080端口

在这里插入图片描述

8.启动Jenkins,访问

# 启动
systemctl start jenkins
# 停止
systemctl stop jenkins

9.启动完成后,输入服务器ip+端口访问,初次访问会有一个初始密码

cat /var/lib/jenkins/secrets/initialAdminPassword #查看初始密码

在这里插入图片描述

注意:记得下载中文插件及设置密码


网站公告

今日签到

点亮在社区的每一天
去签到