飞道的博客

Jenkins——Jenkins+harbor+gitlab(git) 部署maven项目

230人阅读  评论(0)

概述

环境介绍

服务器角色 ip
harbor 192.168.188.91
gitlab 192.168.188.92
jenkins 192.168.188.93

安装harbor仓库

Habor是由VMWare公司开源的容器镜像仓库。事实上,Habor是在Docker Registry上进行了相应的 企业级扩展,从而获得了更加广泛的应用,这些新的企业级特性包括:管理用户界面,基于角色的访 问控制 ,AD/LDAP集成以及审计日志等,足以满足基本企业需求。

Harbor核心组件解释

组件 功能
harbor-adminserver 配置管理中心
harbor-db Mysql数据库
harbor-jobservice 负责镜像复制
harbor-log 记录操作日志
harbor-ui web管理页面和API
nginx 前端代理,负责前端页面和镜像上传/下载转发
redis 会话
registry 镜像存储

Harbor部署

安装docker和compose

安装需要的安装包
yum install -y yum-utils

设置镜像仓库
我们用阿里云

yum-config-manager \
    --add-repo \
    http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

开启存储库
yum-config-manager --enable docker-ce-nightly
yum-config-manager --enable docker-ce-test

安装docker
yum install docker-ce docker-ce-cli containerd.io

systemctl enable docker --now

下载安装compose
curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.5/docker-compose-$(uname -s)-$(uname -m) > /usr/local/bin/docker-compose  

授权
chmod +x /usr/local/bin/docker-compose 

查看版本
docker-compose version

安装harbor

使用的 harbor-offline-installer-v1.9.1

[root@harbor ~]# tar -xf harbor-offline-installer-v1.9.1.tar 
[root@harbor ~]# ls
harbor  harbor-offline-installer-v1.9.1.tar
[root@harbor ~]# cd harbor
[root@harbor harbor]# ls
harbor.v1.9.1.tar.gz  harbor.yml  install.sh  LICENSE  prepare

修改harbor.yml 文件里面的hostname 改成本机地址
[root@harbor harbor]# vim harbor.yml 
hostname: 192.168.188.91

配置http镜像仓库可信任
vim /etc/docker/daemon.json
添加

{
   "insecure-registries": ["192.168.188.91"]}

systemctl restart docker

拉取镜像
./prepare

安装
./install.sh

当完成安装后,即可通过本机地址进行浏览器的访问,账户名为admin,密码默认为Harbor12345



测试推送镜像

换一台安装过docker的服务器

配置http镜像仓库可信任
vim /etc/docker/daemon.json
添加

{
   "insecure-registries": ["192.168.188.91"]}

登录仓库
docker login 192.168.188.91 -uadmin -pHarbor12345

[root@gitlab ~]# docker login 192.168.188.91 -uadmin -pHarbor12345
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /root/.docker/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded

现在下载一个镜像nginx
docker pull nginx

给镜像打tag
docker tag nginx:latest 192.168.188.91/maomao/nginx

上传镜像
docker push 192.168.188.91/maomao/nginx

再通过浏览器查看上传的镜像

安装git或者gitlab

使用git

  • Git是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。
  • Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。
安装git首先需要拥有ssh软件,但是该程序linux是自带拥有的,所以可以直接进行下载

yum install -y git

查看版本
git version

创建用户,用户名字随意,但是尽量还是使用和git相关的名字
[root@gitlab ~]# useradd gitme
[root@gitlab ~]# passwd gitme
Changing password for user gitme.
New password: 
BAD PASSWORD: The password is shorter than 8 characters
Retype new password: 
passwd: all authentication tokens updated successfully.

切换到gitme用户
su - gitme

在家目录创建
mkdir demo.git
cd demo.git
git --bare init

使用gitlab

GitLab 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭 建起来的web服务。安装方法是参考GitLab在GitHub上的Wiki页面。

国外站点下载比较慢,可以在国内镜像去下载,比如清华镜像

Centos7 gitlab 12.9.5社区版

下载完成之后将包上传至git服务器

下载依赖
yum install -y policycoreutils-python openssh-server

通过rpm安装
rpm -ivh gitlab-ee-12.9.5-ee.0.el6.x86_64.rpm

安装成功

修改配置文件
vim /etc/gitlab/gitlab.rb

修改地址
external_url 'http://192.168.188.95'

修改时区
gitlab_rails['time_zone'] = 'Asia/Shanghai'

将注释取消
gitlab_rails['manage_backup_path'] = true
gitlab_rails['backup_path'] = "/var/opt/gitlab/backups"

gitlab_rails['backup_archive_permissions'] = 0644
备份保持的时间
gitlab_rails['backup_keep_time'] = 604800

加载配置
gitlab-ctl reconfigure

重启
gitlab-ctl restart

安装查看系统负载工具,这个工具必 须安装阿里云epplo源
yum -y install htop 

浏览器登录gitlab仓库

创建账号

修改密码之后 登录
账号是root
密码是你修改的

创建授权一个账号给开发使用



给新用户设置密码

再创建一个jenkins账号 给jenkins用来拉取代码

上传项目

gitlab创建maven项目
创建项目
登录gitlab,创建一个项目springbootdemo

添加成员

添加2个成员,一个是jenkins用户,用来拉取代码的。一个是maomao,用来提交代码的。

将gitlab仓库来去到开发本地

yum install -y git

git clone http://192.168.188.95/maomao/springbootdemo.git

[root@gitlab ~]# git clone http://192.168.188.95/maomao/springbootdemo.git
Cloning into 'springbootdemo'...
Username for 'http://192.168.188.95': maomao  
Password for 'http://maomao@192.168.188.95': 
warning: You appear to have cloned an empty repository.

当前目录就会有一个仓库目录springbootdemo 
[root@gitlab ~]# ls
gitlab-ce-12.9.5-ce.0.el7.x86_64.rpm  springbootdemo  SpringBootDemo-master  SpringBootDemo-master.zip

然后将项目目录移动到仓库目录
[root@gitlab ~]# mv SpringBootDemo-master springbootdemo/
[root@gitlab ~]# cd springbootdemo/
[root@gitlab springbootdemo]# ls
SpringBootDemo-master

git add .

git commit -m 'v1'

如果这里出现
*** Please tell me who you are.

则需要验证用户
git config user.name "maomao"
git config user.email "123@qq.com"

我们重来一次
[root@gitlab springbootdemo]# git add .
[root@gitlab springbootdemo]# git commit -m 'v1'
[master (root-commit) 608f5ef] v1
 14 files changed, 656 insertions(+)
 create mode 100644 SpringBootDemo-master/.gitignore
 create mode 100644 SpringBootDemo-master/.mvn/wrapper/maven-wrapper.jar
 create mode 100644 SpringBootDemo-master/.mvn/wrapper/maven-wrapper.properties
 create mode 100644 SpringBootDemo-master/Dockerfile
 create mode 100644 SpringBootDemo-master/README.md
 create mode 100644 SpringBootDemo-master/kube.yaml
 create mode 100644 SpringBootDemo-master/mvnw
 create mode 100644 SpringBootDemo-master/mvnw.cmd
 create mode 100644 SpringBootDemo-master/pom.xml
 create mode 100644 SpringBootDemo-master/src/main/java/com/example/demo/SpringBootDemoApplication.java
 create mode 100644 SpringBootDemo-master/src/main/java/com/example/demo/web/controller/IndexController.java
 create mode 100644 SpringBootDemo-master/src/main/java/com/example/demo/web/controller/RandomController.java
 create mode 100644 SpringBootDemo-master/src/main/resources/application.yml
 create mode 100644 SpringBootDemo-master/src/test/java/com/example/demo/SpringBootDemoApplicationTests.java

推送代码至仓库
[root@gitlab springbootdemo]# git push -u origin master
Username for 'http://192.168.188.95': maomao
Password for 'http://maomao@192.168.188.95': 
Counting objects: 33, done.
Delta compression using up to 2 threads.
Compressing objects: 100% (21/21), done.
Writing objects: 100% (33/33), 48.63 KiB | 0 bytes/s, done.
Total 33 (delta 0), reused 0 (delta 0)
To http://192.168.188.95/maomao/springbootdemo.git
 * [new branch]      master -> master
Branch master set up to track remote branch master from origin.

打开浏览器查看是否上传成功


安装Jenkins

Jenkins是一款开源自动化服务器,旨在自动化连续集成和交付软件所涉及的重复技术任务。 Jenkins是基于Java的,可以从yum安装,也可以通过下载和运行其Web应用程序ARchive(WAR)文件进行安装 - 构成一个完整的Web应用程序的集合,该文件旨在在服务器上运行。

安装jenkins所需环境

安装maven
yum install -y maven

安装jdk
yum install -y java

安装tomcat,上传安装包
tar xf apache-tomcat-8.3.5.tar -C /usr/local
cd /usr/local
mv apache-tomcat-8.5.16 tomcat

安装docker
安装需要的安装包
yum install -y yum-utils

设置镜像仓库
我们用阿里云

yum-config-manager \
    --add-repo \
    http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

安装docker
yum install -y docker-ce docker-ce-cli containerd.io

systemctl enable docker --now

docker version

安装jenkins

我使用jenkins.war包进行安装

删除tomcat所有的网页文件并将jenkins解压到ROOT下
cd /usr/local/tomcat/webapps/ROOT
rm -rf ./*

将jenkins.war放入/usr/local/tomcat/webapps/ROOT
[root@jenkins ROOT]# mv /root/jenkins.war ./
[root@jenkins ROOT]# ls
jenkins.war

解压war包
unzip jenkins.war

开启tomcat
/usr/local/tomcat/bin/startup.sh

配置镜像加速
curl -sSL https://get.daocloud.io/daotools/set_mirror.sh | sh -s http://f1361db2.m.daocloud.io

docker version >= 1.12
{
   "registry-mirrors": ["http://f1361db2.m.daocloud.io"]}
Success.
You need to restart docker to take effect: sudo systemctl restart docker

设置信任192.168.188.91 harbor仓库
vim /etc/docker/daemon.json

添加
{
   "registry-mirrors": ["http://f1361db2.m.daocloud.io"],
        "insecure-registries":["192.168.188.91"]
}

重启docker
systemctl restart docker

生成ssh密钥对传送给git仓库主机
ssh-keygen
ssh-copy-id gitme@192.168.188.92

这里gitme就是之前gitlab服务器创建的账户

通过浏览器打开jenkins

[root@jenkins ~]# cat .jenkins/secrets/initialAdminPassword 
ab2c9e68357e41c79267e0ac57bcaf7c

将密码输入

选择安装推荐的插件


配置jenkins流水线工作

从公开的git仓库下载课件代码文件
git clone https://github.com/407777853/java-demo

cd java-demo

.git为隐藏文件目录
vim .git/config

将这个参数修改为自己创建的git仓库地址和仓库路径
url =  gitme@192.168.188.92:/home/gitme/demo.git

将java-demo代码上传到自己的git仓库上
cd ~/java-demo
添加指定目录到暂存区
git add . 	

描述
git commit -m “all”

将代码推送至远程仓库的master节点
git push origin master

浏览器中打开jenkins

  1. 添加凭据


[root@jenkins java-demo]# cat /root/.ssh/id_rsa
-----BEGIN RSA PRIVATE KEY-----
MIIEpQIBAAKCAQEAuyQpoTeiy/Nn8XJsfA4+oXPsiA7P0t2eK964B0mSowWjiFjt
Cw0ynLpIYA2FcZ6E+fXO7z+u/NKLYpMbf29jQSf9tYIlITePEewM5i0rHwst+deq
lybocPAhJGW3h3G1IgV17uWd3DHr+fk+Js4WaEtmIUvryQjbFQrHsMuR2Q/21bUt
HgFvrGTOIfBg74jGnqR3Uy5vA27wFvfGtn77HF4M7SP7rbmZ3Wg8jJLrzsm1dJoR
qo/qSsZ7VkhbVTk1lD7/WF0Mqd9oE9JQz4OQOp1XHckKvybGxYmYG2hnfcqXwL3v
MzUubFiMRTD9J9wlBT2LOTj8+VO/4As0fi2kOQIDAQABAoIBAQCv9YejC4HpzHq+
Xj08w9QF0M7k+zBTb4eKbkaQq4/R8rpZuGthic496TWmAvCm7UrREFu7PyDUnU7r
p7AiOWSU3fpCkRVCT1AZpN5YCr5R2Rwon6zJpI7HqjEvXOic1MBgNcw2jPXKFbJw
fvb+W6Zb+BEWW6FejBIajeFHDZGcCjgIUj8PnH3rthIIfqY9X8RRLowPw5tIZvKC
mVSe1/NXLrmblDLkHikk01aAAENyc2rBrvYlAZ6qDOiWOrMnohN9NfE6d3DG1IMK
8qbyDpcr5Twb3ZMhvHF9oOWRpR+iohb28jsU1Rd5uBPN68/HpTwhlkIU/mESsV2v
xItYAE41AoGBANy7Tk+IVeyF1cHs52je9wDScP92TgZn8v3e9VhuKeHPT5sTfPBe
U9nWpZsci/mVadofa1WHmkAhZLHeXIqVjN0rM/oZD/rz5eY3a9zXGVSNTVeQUncv
vv9JT1RdewiSNOJdBc/v9pEwfC9QEHHztkYvPZJaCh5KGkTf1YM/aTm7AoGBANkK
5GX4kFcTUMUMO0e8/ZkTUS3+61r35PD+v+rglN5YT3zBGtSNsFEcjnqODmsLXE3K
fPe4MRp8fSqKTJU6Ev0A34WVi1BgBtGOvRTikZqKlX1GAiLYWLB9fjrwyXmxQO05
kl3XLtv8vHJWEoHXhU+hH/d+4rxMR+YfR5011BCbAoGBAM2o3zAPMS+tCxsipgH6
LF3htVLwYYZqd+a+RA5epjs0s1Ej+TbkTHAdJDO/h1PGONf4ikMokznJY06uhb7B
1HuFc2pEy7TgZoX3gVJEP9+dwEAjwhI2tFibb4SFjMrRnuCCF5ZEWJGygSJ8ELZ7
gosmHNItflv2Yz9k5kThYiNdAoGBAId189zsyPF/va5uFuWMP971HnqNmsjY5QvA
g3mNl3w6M8oSH7O/hubo4sf8t2T53y8yDNLzI7p7LgeJ74hHiahcjiUqk5ujgz3x
T3OkgOmqSui39AdZbekhOdKBi82m4nXss7xb3AQy9k6KB9z/7VUoo/HtQIfzOACZ
TzIAcY23AoGAfYgpJCIoOD6uL65CkohqE34R6LBZoyoUiuPsUFSu2YyoyOrYaRvK
P1RPe8E0+7ias+NtCk2YGxyj1xYnYMTq8goxF688H2P/vTYLwgF7jVXeW3IFl7L1
jWuBx5B3IfyhPATh67nYjbyxff1sj4YgkmwOkRX0VJ63B6vzud93C3s=
-----END RSA PRIVATE KEY-----

将上面的密钥复制到浏览器里
  1. 创建流水线项目



    添加字符参数

    流水线语法
node {
    
   // 拉取代码
   stage('Git Checkout') {
    
       checkout([$class: 'GitSCM', branches: [[name: '*/master']], doGenerateSubmoduleConfigurations: false, extensions: [], submoduleCfg: [], userRemoteConfigs: [[credentialsId: 'a426fefe-9cbc-4bc0-abc7-7a5ac5d11a27', url: 'gitme@192.168.188.92:/home/gitme/demo.git']]])
   }
   // credentialsId就是之前的凭据ID url为通过ssh方式再git仓库服务器拉去代码的用户@地址:仓库目录
   // 代码编译
   stage('Maven Build') {
   
        sh '''
        /usr/bin/mvn clean package -Dmaven.test.skip=true
        '''
   }
   // 项目打包到镜像并推送到镜像仓库
   stage('Build and Push Image') {
   
        sh '''
        REPOSITORY=192.168.188.91/maomao/java-demo:${Branch}
        echo ' 
        FROM 192.168.188.91/maomao/tomcat:v1
        MAINTAINER maomao
        RUN rm -rf /usr/local/tomcat/webapps/*
        ADD target/*.war /usr/local/tomcat/webapps/ROOT.war 
        ' > Dockerfile 
        docker build -t  $REPOSITORY .
        docker login -u admin -p Harbor12345 192.168.188.91
        docker push $REPOSITORY
        '''
   }
   // 部署到Docker主机
   stage('Deploy to Docker') {
   
        sh '''
        REPOSITORY=192.168.188.91/maomao/java-demo:${Branch}
        docker rm -f java-demo |true
        docker image rm $REPOSITORY |true
        docker login -u admin -p Harbor12345 192.168.188.91
        docker run -d --name java-demo -p 88:8080 $REPOSITORY
        '''
   }
}
  1. 构建项目

    构建成功
  2. 验证
    通过浏览器输入jenkins服务器的ip+流水线脚本里的端口号

    修改代码 测试项目能否改变
[root@jenkins java-demo]# pwd
/root/java-demo
[root@jenkins java-demo]# vim src/main/resources/templates/index.ftl 
修改项目主页文字

whatToType: "学生管理系统-Test版本",

将代码推送至仓库
[root@jenkins java-demo]# git add .
[root@jenkins java-demo]# git status
# On branch master
# Changes to be committed:
#   (use "git reset HEAD <file>..." to unstage)
#
#	modified:   src/main/resources/templates/index.ftl
#
[root@jenkins java-demo]# git commit -m "test"
自动检测出哪个文件发生了变化
[master 82dcff9] test
 1 file changed, 1 insertion(+), 1 deletion(-)
[root@jenkins java-demo]# git push origin master
Counting objects: 13, done.
Delta compression using up to 2 threads.
Compressing objects: 100% (6/6), done.
Writing objects: 100% (7/7), 561 bytes | 0 bytes/s, done.
Total 7 (delta 3), reused 0 (delta 0)
To gitme@192.168.188.92:/home/gitme/demo.git
   bf670b2..82dcff9  master -> master

我们重新构建项目

构建完成之后 项目发生变化


转载:https://blog.csdn.net/Cantevenl/article/details/116497794
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场