Docker+Jenkins+Gitee+Maven构建自动化部署

简介: Docker+Jenkins+Gitee+Maven构建自动化部署

正文


一、安装Jekins


      1、安装docker-compose

       2、编辑docker-compose.yml


version: '3.1'
services:
  jenkins:
    image: jenkins/jenkins:2.324-centos7
    volumes:
      - /data/jenkins/:/var/jenkins_home
      - /var/run/docker.sock:/var/run/docker.sock
      - /usr/bin/docker:/usr/bin/docker
      - /usr/lib/x86_64-linux-gnu/libltdl.so.7:/usr/lib/x86_64-linux-gnu/libltdl.so.7
    ports:
      - "8080:8080"#jenkins启动的端口
      - "8085:8085" #对应你的项目的端口
    expose:
      - "8080"
      - "50000"
    privileged: true
    user: root
    restart: always
    container_name: jenkins
    environment:
      JAVA_OPTS: '-Djava.util.logging.config.file=/var/jenkins_home/log.properties'


3、进入/usr/local/bin目录启动,然后等待安装完成


docker-compose up -d


二、jekins配置


1、访问yourip:8080/后出现如下页面,因为是docker容器部署需要进入到容器内部获取密码


333.png


docker exec -it jenkins /bin/bash   #jenkins为容器名称,或者写容器id


获取密码登录

8074245061964fd5a3b4850740109991.png


2、默认安装推荐的插件之外还需安装


  • Maven插件 Maven Integration plugin。
  • 发布插件 Deploy to container Plugin,安装到tomcat的插件
  • Publish Over SSH :部署到远程服务上的插件


3、环境准备


在容器内上安装git 、maven和jdk


1、yum -y install git #安装git
   git version #检查是否安装成功
2、yum install maven -y #安装maven
   mvn -version #检查是否安装成功


由于本人是jdk17,将jdk17的安装包上传到宿主机上然后复制到容器内安装,解压配置java环境


docker cp /root/jdk-17_linux-x64_bin.tar.gz jenkins:/root #复制到容器内


修改变量环境


vim /etc/profile ,如果不支持请在容器上安装vim指令 yum install vim,

然后执行如下 source /etc/profile使环境变量生效。环境变量配置如下


JAVA_HOME=/usr/local/jdk-17.0.1
CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
PATH=$JAVA_HOME/bin:$PATH
export PATH JAVA_HOME CLASSPATH


4、配置全局环境


a、maven配置


111.png

 

b、jdk配置


222.png


c、git配置


333.png


4、其他配置


三、构建项目


1、新建一个maven项目,源码配置,可以全局配置证书,也可以就一个项目配置,此处是单个项目配置


770259d1a417490293a94d9fc2494375.png


2、maven构建配置


clean install -Dmaven.test.skip=true -Ptest


111.png


3、启动脚本配置


222.png

 

SERVER_NAME=test-jenkins #镜像和服务的名称,请对应项目pom.xml中的配置
TAG=1.0-SNAPSHOT #信息
 #容器id
 CID=$(docker ps | grep "$SERVER_NAME" | awk '{print $1}')
 #镜像id
 IID=$(docker images | grep "$SERVER_NAME" | awk '{print $3}')
 # 构建docker镜像
         if [ -n "$IID" ]; then
                 echo "存在$SERVER_NAME镜像,IID=$IID"
                  docker stop $SERVER_NAME   # 停止运行中的容器
                  docker rm $SERVER_NAME     ##删除原来的容器
                  docker rmi $IID   ## 删除原来的镜像
         else
                 echo "不存在$SERVER_NAME镜像,开始构建镜像"
        fi
mvn docker:build
echo "当前docker 镜像:"
docker images | grep $SERVER_NAME
echo "启动容器----->"
docker run --name $SERVER_NAME -p 8090:8085 -d $SERVER_NAME:$TAG
echo "启动服务成功!"


4、Dockerfile配置,docker建立在main下的docker文件中


111.png

 

FROM openjdk:17 ##拉取镜像
VOLUME /tmp
ADD *.jar app.jar
ENV JAVA_OPTS="\  ##jvm参数
-server \
-Xmx512m \
-Xms512m \
-Xmn64m \
-XX:+UseG1GC \
-XX:GCTimeRatio=99 \
-XX:MaxGCPauseMillis=20 \
-XX:MetaspaceSize=256m \
-XX:MaxMetaspaceSize=256m \
-XX:+PrintGC \
-XX:+PrintGCDetails \
-Xloggc:/var/log/gc-%t.log"
ENTRYPOINT java ${JAVA_OPTS} --add-opens java.base/java.lang=ALL-UNNAMED -Djava.security.egd=file:/dev/./urandom -jar /app.jar
#--add-opens java.base/java.lang=ALL-UNNAMED 解决jdk9之后模块化反射失败问题
#-Djava.security.egd=file:/dev/./urandom 添加随机数使tomcat可以快速启动


5、项目pom.xml添加docker-maven-plugin插件


   <build>
        <finalName>jenkins</finalName>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <mainClass>com.xiaojie.JenkinsApp</mainClass>
                </configuration>
                <executions>
                    <execution>
                        <goals>
                            <goal>repackage</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
            <!-- Docker maven plugin start -->
            <plugin>
                <groupId>com.spotify</groupId>
                <artifactId>docker-maven-plugin</artifactId>
                <version>1.2.2</version>
                <configuration>
                    <imageName>${project.artifactId}:${project.version}</imageName>
                    <dockerDirectory>${project.basedir}/src/main/docker</dockerDirectory>
                    <!--复制到容器内的地址-->
                    <resources>
                        <resource>
                            <targetPath>/</targetPath>
                            <directory>${project.build.directory}</directory>
                            <include>${project.build.finalName}.jar</include>
                        </resource>
                    </resources>
                </configuration>
            </plugin>
            <!-- Docker maven plugin end -->
        </plugins>
    </build>


相关文章
|
6月前
|
敏捷开发 测试技术 API
测试金字塔:构建高效自动化测试策略的基石
测试金字塔:构建高效自动化测试策略的基石
499 116
|
6月前
|
测试技术 API 数据库
测试金字塔:构建高效自动化测试策略的基石
测试金字塔:构建高效自动化测试策略的基石
527 114
|
6月前
|
设计模式 前端开发 测试技术
告别脆弱:构建稳定UI自动化测试的3个核心策略
告别脆弱:构建稳定UI自动化测试的3个核心策略
635 113
|
6月前
|
JSON 监控 API
n8n错误处理全攻略:构建稳定可靠的自动化工作流
在n8n自动化工作流中,错误是提升系统可靠性的关键。本文详解常见错误类型、节点级与全局处理机制,结合重试、熔断、补偿事务等高级模式,助您构建稳定、可维护的生产级自动化流程。
|
6月前
|
Java 项目管理 Maven
Maven项目管理与构建自动化完全指南
Maven彻底改变了Java项目管理方式,通过POM模型、依赖管理和标准化构建流程,大幅提升开发效率。本文深入解析其核心概念、多模块管理、私服搭建及与Spring Boot、Docker等现代技术栈的集成实践,助力开发者实现高效、规范的项目构建与团队协作。
1061 156
Maven项目管理与构建自动化完全指南
数据采集 Web App开发 人工智能
409 0
|
8月前
|
人工智能 自然语言处理 安全
Milvus x n8n :自动化拆解Github文档,零代码构建领域知识智能问答
本文介绍了在构建特定技术领域问答机器人时面临的四大挑战:知识滞后性、信息幻觉、领域术语理解不足和知识库维护成本高。通过结合Milvus向量数据库和n8n低代码平台,提出了一种高效的解决方案。该方案利用Milvus的高性能向量检索和n8n的工作流编排能力,构建了一个可自动更新、精准回答技术问题的智能问答系统,并介绍了部署过程中的可观测性和安全性实现方法。
1110 0
|
8月前
|
Java jenkins 应用服务中间件
结合Jenkins与Tomcat,实施Maven项目的自动构建和部署流程。
任何项目构建和部署的自动化流程,总离不开对各个环节精细把控与密切配合。涉及到源代码管理、构建工具、持续集成服务器以及最终的运行时环境的协调。通过上述简洁实用的步骤,可以实现Maven项目从源代码到运行状态的无缝过渡,进而提升软件开发的效率与质量。
450 0
|
Java Maven 开发者
maven项目中官方setting.xml文件
`settings.xml` 是 Maven 的配置文件,用于定义用户或全局级别的构建行为。它包含本地仓库路径、网络代理、服务器认证、仓库镜像及构建配置文件等设置,帮助开发者根据环境定制 Maven 行为,提升构建效率与灵活性。
1547 0
|
9月前
|
Java 区块链 Maven
关于引入maven项目后出现‘parent.relativePath’ of POM错误时的解决方法
关于引入maven项目后出现‘parent.relativePath’ of POM错误时的解决方法
717 3
下一篇
开通oss服务