开源项目ChatGPT-Next-Web的容器化部署(二)-- jenkins CI构建并推送镜像

本文介绍了如何在Jenkins中使用JNLP-H5模板创建新Docker容器,配置groovylibrary以构建和推送Node.js应用镜像到阿里云镜像仓库,包括解决连接Dockerdaemon的问题和安全凭证管理。
摘要由CSDN通过智能技术生成

一、背景

接着上文已制作好了Dockerfile,接下来就是docker build/tag/push等一系列操作了。

不过在这之前,你还必须在jenkins等CI工具中,拉取源码,然后build构建应用。

因为本文的重点不是讲述jenkins ci工具,所以只会把核心的一些知识交待清楚。
包括以下:

  • jenkins pod template 新增docker容器
  • 新增groovy library库,构建并推送镜像
  • nodejs.jenkinsfile构建应用,调用库函数

但是,本文的内容,都是由jenkins完成。

二、 pod template 新增docker容器

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
选择jnlp-h5模板:

在这里插入图片描述
新增docker容器:(注意红线勾选出来的部分,特别是需要分配伪终端)
在这里插入图片描述
如果你就这么配置,不出意外的话,docker build就会报错如下:

12:32:14  Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?

啥意思,明明我们在pod模板里增加了docker客户端,怎么还说没有运行。
这是因为它依赖host的docker环境。

增加以下配置,把主机的/var/run/docker.sock挂载到pod的/var/run/docker.sock:
在这里插入图片描述

三、新增groovy library库

构建并推送镜像,前提是你必须登录阿里云镜像仓库服务。

在 docker.groovy 文件里新增函数pushToAly():

def pushToAly(appName, version, dockerfileName, repoDomain = "xxx-harbor-registry.cn-hangzhou.cr.aliyuncs.com", repoProject= "xxx") {
    // 1、构建
    sh """
        docker build -f ${dockerfileName} -t ${repoProject}/${appName}:${version} .
       """
    // 2、登录、打标签、推送
    withCredentials([usernamePassword(passwordVariable: 'DOCKER_PASSWORD', usernameVariable: 'DOCKER_USERNAME', credentialsId: "95197cab-bb78-4e45-97df-2c7414adea98",)]) {
        sh """
            docker login --username=${DOCKER_USERNAME} --password=${DOCKER_PASSWORD} ${repoDomain}
            docker tag ${repoProject}/${appName}:${version} ${repoDomain}/${repoProject}/${appName}:${version}
            docker push ${repoDomain}/${repoProject}/${appName}:${version}
           """
    }
    // 3、删除本地镜像
    sh """
        docker rmi -f ${repoProject}/${appName}:${version}
        docker rmi -f ${repoDomain}/${repoProject}/${appName}:${version}
       """
}

1、登录阿里云镜像仓库

需要把用户名和密码一并输入,username和password前面是两个横杆字符,而非一个横杆字符。
如果你输入的用户名和密码无误,却遇到了下面同样的错误,请检查自己的格式:

12:40:21  + docker login '-username=xxx' '-password=****' xxx-harbor-registry.cn-hangzhou.cr.aliyuncs.com
12:40:21  WARNING! Using --password via the CLI is insecure. Use --password-stdin.
12:40:21  Error response from daemon: Get https://xxx-harbor-registry.cn-hangzhou.cr.aliyuncs.com/v2/: unauthorized: authentication required

2、新增Credentials

在这里插入图片描述
在这里插入图片描述
选择“Username with password”,输入用户名和密码。

在这里插入图片描述
注意credentialsId的值是否一致,

这里使用了jenkins的插件,简单地对密码进行保护。用户名字段是DOCKER_USERNAME, 密码字段是DOCKER_PASSWORD。

withCredentials([usernamePassword(passwordVariable: ‘DOCKER_PASSWORD’, usernameVariable: ‘DOCKER_USERNAME’, credentialsId: “95197cab-bb78-4e45-97df-2c7414adea98”,)])

3、系统配置Global Pipeline Libraries

下文jenkinsfile中将调用 docker.groovy 的 函数pushToAly(),所以你需要再次确认,是否配置好了全局pipeline库。

在这里插入图片描述

四、nodejs.jenkinsfile构建应用

因为Nodejs是需要容器化部署的,和h5等静态页面的项目所有不同,故这里新增一个jenkinsfile。它的步骤只有三步:

  • 1、拉取源码
  • 2、build构建
  • 3、构建并推送镜像
#!groovy
@Library('jenkinslib') _
# 持久化目录
String sharefile = "/opt"

# 引用pipeline库
def docker = new com.xxx.devops.docker()

# 应用的名称
String zipName = "${env.zipName}".trim()
# 应用的版本
String appVersion = ""
# Dockerfile所在路径
String dockerfileName = sharefile + "/" + zipName + "/Dockerfile"

pipeline {
    agent {
        kubernetes {
            inheritFrom 'jnlp-h5'
        }
    }
    options {
        timestamps()  //日志会有时间
        skipDefaultCheckout()  //删除隐式checkout scm语句
        disableConcurrentBuilds() //禁止并行
        timeout(time: 1, unit: 'HOURS')  //流水线超时设置1h
    }
    stages {
        # 1、拉取源码
        
        # 2、构建,并对appVersion赋值

        # 3、推送镜像到阿里云镜像仓库
        stage('Push Docker Image') {
            steps {
                script {
                    container('docker') {
                        dir("${env.WORKSPACE}") {
                            docker.pushToAly(zipName, appVersion, dockerfileName)
                        }
                    }
                }
            }
  
        }
    }
}

五、jenkins job打包

在这里插入图片描述
在这里插入图片描述

可以看到,成功推送了镜像到远程的仓库,最后删除本地的镜像。

12:52:45 1.0.4: digest: sha256:4e6f6f526fc7d9f402e6dbca3a766f9ca447e59e6c12b33e2696eca9561a0b04 size: 2002

通过sha2569(它类似于md5值),去阿里云镜像仓库查看核实。

在这里插入图片描述

  • 16
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 安装DockerDocker Compose 在安装DockerDocker Compose之前,需要先安装Docker的依赖包。 首先,更新apt-get: ``` sudo apt-get update ``` 然后安装Docker的依赖包: ``` sudo apt-get install apt-transport-https ca-certificates curl software-properties-common ``` 接下来,添加Docker的GPG密钥: ``` curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add - ``` 添加Docker的APT仓库: ``` sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" ``` 更新apt-get: ``` sudo apt-get update ``` 安装Docker: ``` sudo apt-get install docker-ce ``` 安装Docker Compose: ``` sudo curl -L "https://github.com/docker/compose/releases/download/1.28.5/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose ``` 添加执行权限: ``` sudo chmod +x /usr/local/bin/docker-compose ``` 2. 编写Docker Compose文件 在本地创建一个文件夹,用于存放Docker Compose文件和Jenkins的数据: ``` mkdir jenkins cd jenkins mkdir jenkins-data ``` 然后,在该文件夹下创建一个docker-compose.yml文件,用于定义Jenkins容器和相关配置: ``` version: '3' services: jenkins: container_name: jenkins image: jenkins/jenkins:lts ports: - "8080:8080" - "50000:50000" volumes: - "./jenkins-data:/var/jenkins_home" networks: - jenkins_network networks: jenkins_network: ``` 此配置文件会创建一个名为“jenkins”的容器,使用jenkins/jenkins:lts镜像,映射8080和50000端口,并将/var/jenkins_home目录映射到本地的./jenkins-data目录。 3. 启动Jenkins容器 启动Jenkins容器: ``` docker-compose up -d ``` 访问http://localhost:8080,输入初始管理员密码,完成Jenkins的安装。 4. 配置Jenkins 登录Jenkins后台,安装Git插件和Maven插件。 在Jenkins后台,选择“新建任务”,配置任务信息,选择“自由风格项目”。 在“源码管理”中选择“Git”,填写Git仓库地址和用户凭证,保存并应用配置。 在“构建触发器”中选择“轮询SCM”,填写轮询时间间隔。 在“构建”中选择“执行shell命令”,填写构建命令,如: ``` mvn clean package ``` 在“构建后操作”中选择“部署war/ear到容器”,填写部署配置信息,如: ``` Container: Tomcat 8.x Remote Tomcat URL: http://localhost:8080 Credentials: Jenkins WAR/EAR files: **/*.war Context path: / ``` 保存并应用配置。 5. 获取远程代码并构建Jenkins任务列表中,选择要构建的任务,点击“立即构建”按钮,Jenkins会自动获取远程Git仓库中的代码,并执行构建命令。 构建完成后,Jenkins会自动将构建好的war包部署到Tomcat容器中,访问http://localhost:8080即可查看部署的应用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值