解放双手 | Jenkins + gitlab + maven 自动打包部署项目
前言
记录 Jenkins + gitlab + maven
自动打包部署后端项目详细过程!
需求背景
不会偷懒的程序员不是好码农,传统的项目部署,有时候采用本地手动打包,再通过ssh
传到服务器部署运行,这种方式对于单应用部署还算可以,不会耗费太大时间,但假如分布式项目,拆分为多个微服务部署,那么每个服务都打包部署一遍,发布上线可能会耗时非常久,Jenkins + gitlab + maven
可以实现自动打包,部署到远程服务器~
什么是gitlab
?
程序员肯定都懂的,跟gayhub
一样的东西,可以在内网自己搭建一套来管理项目代码。
什么是Jenkins
?
可以简单地理解为可以代替你实现自动从gitlab
拉取代码,打包,部署到远程服务器的工具。
环境准备
- Centos7 64位,内核版本不低于 3.10
- 安装 docker ,具体参考 这是一次 docker 入门实践
使用`docker`安装`gitlab`
gitlab
的安装这里不做过多记录,可以参考以下内容:
https://www.cnblogs.com/zuxing/articles/9329152.html
https://hub.docker.com/r/beginor/gitlab-ce/
使用`docker`安装`Jenkins`
1docker run --name jenkins --privileged=true -d -v /home/docker/data/jenkins_home:/var/jenkins_home -p 8090:8080 -p 50000:50000 jenkins/jenkins:lts
参数解析:
--name jenkins
:指定Jenkins
容器名称--privileged=true
:防止docker
容器没有权限-d
:容器在后台启动-v /home/docker/data/jenkins_home:/var/jenkins_home
:将容器的/var/jenkins_home
映射到本机的/home/docker/data/jenkins_home
目录,为了便于管理Jenkins
容器的数据,需要注意的是,挂载出来的目录允许我们往容器里面添加文件或者目录,也就是在`/home/docker/data/jenkins_home:/var/jenkins_home`中添加的文件或者目录都会被映射到容器目录`/var/jenkins_home`,那么我们最终在`Jenkins`中配置软件环境时应当使用容器目录路径,因为`Jenkins`实际上是在容器中跑的,比如JDK
家目录,你放在/home/docker/data/jenkins_home/jdk_home
,那么最终配置应当写成/var/jenkins_home/jdk_home
-p 8090:8080 -p 50000:50000
:将容器的8080
端口映射到本机的8090
端口,5000
端口映射为5000
端口jenkins/jenkins:lts
:指定镜像名称跟 tag
可能会踩的坑:
1chmod 777 /home/docker/data/jenkins_home
2chown -R 1000 /home/docker/data/jenkins_home
至此,Jenkins
已经部署好了,然而….折腾才刚刚开始…
`Jenkins`基础配置
- 访问
http://192.168.2.219:8090
打开Jenkins
首页如下图:
按照界面提示,为了管理员安全地设置Jenkins
,已将密码写入日志文件:/var/jenkins_home/secrets/initialAdminPassword
,提示写的是Jenkins
容器中的文件,映射到本机文件则是/home/docker/data/jenkins_home/secrets/initialAdminPassword
,复制文件中的文本,输入,点击继续…滴滴滴~掉坑里了。
- 如果不出意外的话,这里有个坑,上一步之后会一直卡在如下图所示的加载界面:
这是怎么肥事? 原来Jenkins
在启动的时候,请求Google
,检查当前机器是否可以联网,在请求/home/docker/data/jenkins_home/updates/default.json
中存在如下数据:
而由于天朝的网络原因,请求Google
失败,则一直卡住,解决办法是修改为www.baidu.com
即可解决。
- 选择下载推荐的插件,还是自选插件,这里我选择下载推荐的插件,然后进入下载loading
- 创建管理员账号
- 配置
Jenkins
资源url
,使用默认即可
至此,Jenkins
基础配置完成,开始使用。随后登录Jenkins
后发现页面空白,没找到具体原因,重启下Jenkins
容器后再登录就好了。
`Jenkins`插件安装
Jenkins
插件安装的步骤为:系统管理-->插件管理.. 相信聪明的你一定知道怎么安装了。我们需要安装的插件如下:
Maven
项目插件:Maven Integration plugin
,这个插件可以让我们创建一个maven
构建任务ssh
传输工具插件:Publish Over SSH
项目打包完成后,使用这个插件,通过ssh
的方式传输到远程服务器Gitlab
插件:允许Jenkins
访问gitlab
服务器,拉取代码
全局工具配置
系统管理-->全局工具配置,安装一些打包必须的配置环境,如 jdk
,maven
,git
,maven
安装git客户端:
下载
1#下载 git
2yum update
3yum install git
4
5# 配置用于拉取gitlab代码的用户名和邮箱
6git config --global user.name "yourname"
7git config --global user.email "youremail"配置公钥
生成ssh
秘钥, 首先查看是否已经有ssh秘钥:
1cd ~/.ssh`
如果没有则提示没有此文件夹, 此时手动生成秘钥:
1ssh-keygen -t rsa -C “youremail”
连续按三次回车,生成id_rsa
和id_rsa.pub
文件夹,查看公钥文件内容:cat id_rsa.pub
,复制公钥到gitlab
配置ssh key
.
- 测试
1ssh -T git@192.168.2.219
如下结果表示配置成功:
1The authenticity of host '192.168.2.210 (192.168.2.210)' can't be established.
2RSA key fingerprint is SHA256:7oKBkxcwp5naXUzohvjPwEJsow6Y/pF1fSpWFZPVscA.
3RSA key fingerprint is MD5:9c:a1:39:7c:2c:6c:d0:a2:4b:e8:8d:3a:73:6e:c9:c1.
4Are you sure you want to continue connecting (yes/no)? yes
5Warning: Permanently added '192.168.2.210' (RSA) to the list of known hosts.
6Welcome to GitLab, jenkins_easywits!
7
最终配置如下图:
安装 jdk:
如图:
安装maven:
如图:
添加凭据
凭据是为了访问Gitlab
拉取代码使用的,分别创建三个凭据:账号密码类型,api token
访问类型,git
私钥访问类型,总体配置如下图:
解析:
- 账号密码类型凭据,只需要上
gitlab
创建一个账户,同时这个账户拥有访问项目仓库的权限即可。 api token
类型则是使用上述步骤创建的账户登录GitLab
,去生成一个访问令牌,如下图:
git
私钥访问类型,拷贝git
客户端私钥配置即可,如下图:
全局系统配置
系统管理-->系统配置。。主要是配置访问GitLab
服务器拉取代码,还有配置`ssh`远程服务器地址,目的是为了打包后上传文件到远程服务器。
GitLab
配置如下图,使用git api token
依据访问:
ssh
远程服务器配置如下图,主要配置远程主机名,主机ip,用户名/密码,还有远程根目录从/开始:
至此,所有配置完成,可以创建构建任务了。
实战场景,自动部署web项目
- 创建一个
maven
构建任务
- 项目信息描述,指定远程连接
gitlab
- 配置构建的缓存数量
- 拉取远程代码配置
- 构建触发器配置
- 打包配置
- 打包后操作,配置
ssh
传输到远程服务器,执行远程shell
脚本
最后保存,点击构建按钮,即可自动打包,并且部署到远程tomcat
服务器。远程shell
脚本如下:
1#!/bin/bash
2# 配置java环境变量
3export JAVA_HOME=/usr/java/jdk/jdk1.8.0_161 # jdk 根目录
4export JRE_HOME=/usr/java/jdk/jdk1.8.0_161/jre # jre 目录
5export CLASSPATH=.:$JAVA_HOME/lib:$JRE_HOME/lib:$CLASSPATH
6export PATH=$JAVA_HOME/bin:$JRE_HOME/bin:$JAVA_HOME:$PATH
7
8# 配置tomcat环境变量
9export CATALINA_BASE=/home/wwwroot/easywits-operation/tomcat-easywits-operation
10export CATALINA_HOME=/home/wwwroot/easywits-operation/tomcat-easywits-operation
11export TOMCAT_HOME=/home/wwwroot/easywits-operation/tomcat-easywits-operation
12
13echo "stopping tomcat_easywits_operation......"
14#关闭tomcat
15port=xxxx
16#根据端口号查询对应的pid
17pid=$(netstat -nlp | grep :$port | awk '{print $7}' | awk -F"/" '{ print $1 }');
18#杀掉对应的进程,如果pid不存在,则不执行
19if [ -n "$pid" ]; then
20 kill -9 $pid;
21fi
22#删除tomcat旧war包
23rm -rf /home/wwwroot/easywits-operation/tomcat-easywits-operation/webapps/easywits
24rm -rf /home/wwwroot/easywits-operation/tomcat-easywits-operation/webapps/easywits.war
25#复制war包到tomcat/webapps目录,并重命名
26cp /home/wwwroot/easywits-operation/deploy_history/easywits.war /home/wwwroot/easywits-operation/tomcat-easywits-operation/webapps/easywits.war
27# 文件名 + 当前日期时间错,备份发布文件包
28#DEPLOY_DATE=`date +%Y%m%d%H%M%S`
29#DEPLOY_FILE_NAME=easywits-op-server_$DEPLOY_DATE.war
30#mv /home/wwwroot/easywits-operation/deploy_history/easywits.war /home/wwwroot/easywits-operation/deploy_history/$DEPLOY_FILE_NAME
31rm -rf /home/wwwroot/easywits-operation/deploy_history/*
32echo "restarting tomcat_easywits_operation......"
33sleep 5
34/home/wwwroot/easywits-operation/tomcat-easywits-operation/bin/startup.sh
35
整个shell
脚本很常规,就是将文件复制到tomcat
的webapp
目录下,并重启。
- 部署结果,看看日志信息如下,表示成功:
提交代码,自动打包部署
当gitlab
代码仓库发生事件:提交代码等操作时,触发打包部署动作
Jenkins
配置
GitLab
代码仓库配置
这样,当推送代码到指定代码仓库时候就会触发自动打包部署啦!
总结
Jenkins
自动打包部署操作,理论上跟本地打包部署是一个道理,该安装的环境一个不能少,只不过可以自动化罢了Jenkins
可以做的事情还有很多,配置太多啦,一篇文章也只能做个引导作用,更多配置还是需要多看
最后
记录一个自动部署的操作,后续会不定期更新原创文章,欢迎关注公众号 「张少林同学」!
解放双手 | Jenkins + gitlab + maven 自动打包部署项目的更多相关文章
- jenkins+git+maven搭建自动化部署项目环境
简介 折腾了两个晚上,趁着今晚比较有空,把jenkins+git+maven搭建自动化部署项目环境搭建的过程记录一下,这里我把github作为git的远程仓库(https://github.co ...
- jenkins自动打包部署项目
首先去jenkins的官网下载安装包 https://jenkins.io/ 个人下载是长期稳定的那个版本,下载后,得到一个.msi的安装包: 点击进行安装,然后一直点击下一步. jenkins会 ...
- Maven 插件打包部署项目
clean install -Dmaven.test.skip=true:打包工具 clean package
- jenkins+Gitlab+maven+tomcat实现自动集成、打包、部署
一.前言 首先出于提高自己技术水平和琢磨能做点什么能提高工作效率,上线工作实在无聊.重复(手动编译.打包,传包,重启),于是就想到了jenkins,jenkins持续集成已经不是什么新鲜的话题,网上文 ...
- Jenkins结合shell脚本实现(gitLab/gitHub)前端项目自动打包部署服务器
原始发布部署: 石器时代的我们,先是本地打包好项目,在去服务器上把原来的文件删了,然后回到本地copy到服务器: 这操看起来简单,实际部署的人就知道多烦了,假如来几个项目都要重新发布:那就爽了: 今天 ...
- DevOps系列——Jenkins/Gitlab自动打包部署
前面只说了DevOps的两个基础组件Jenkins和GitLab,客官也不要着急,我们玩就玩的深入一点,Gitlab和Jenkins的各种配置和 插件很多,也够啃一阵子的,不要照着操作一通就感觉万事大 ...
- SpringCloud+Docker+Jenkins+GitLab+Maven实现自动化构建与部署实战
1.前言与初衷 本文章会涉及Docker常见命令基础知识点结合不同场景实操一起使用. 本文章会涉及结合工作过程中部署不同环境服务器的项目案例场景为初心进行实际细讲. 本文章主要讲述Docker.Jen ...
- 【iOS】Jenkins Gitlab持续集成打包平台搭建
Jenkins Gitlab持续集成打包平台搭建 SkySeraph July. 18th 2016 Email:skyseraph00@163.com 更多精彩请直接访问SkySeraph个人站点: ...
- 使用Jenkins进行Android自动打包,自定义版本号等信息【转】
之前App在提交测试和最终部署的过程中App打包一直是由开发人员来完成的,由于项目比较大, 再加上Android打包本身就比较慢,所以每次打包还是很耗时的.并且按照严格的研发流程来讲,开发人员应该只负 ...
随机推荐
- 学习刘伟择优excel视频
for each 字符串函数: 默认参数,在子函数中必须要有默认值. 在工作表输入时,F9的功能是把区域编程数组,shift+ctrl+enter功能是把数组分开填入单元格. 创建数组: 1. 2. ...
- VSS + Eclipse 管理源码
- 合理提升WEB前端性能
前端的优化包括四个部分:HTML结构优化.CSS样式优化.JS行为优化.服务器的优化.合理的前端优化不仅能够提升网站加载速度,而且能够更好的提升用户体验和团队开发效率.所以前端性能优化的重要性是不言而 ...
- (概率 01背包) Just another Robbery -- LightOJ -- 1079
http://lightoj.com/volume_showproblem.php?problem=1079 Just another Robbery As Harry Potter series i ...
- 王家林系列之scala--第69讲:Scala并发编程react、loop代码实战详解
刚才看了一下,群里王家林老师又更新课程了,真为王老师的勤奋感到佩服,于是迫不及待的下载下来观看学习.本期讲的是关于scala并发编程的react.loop代码实战. 信息来源于 DT大数据梦工厂微信公 ...
- java并发编程基础-ReentrantLock及LinkedBlockingQueue源码分析
ReentrantLock是一个较为常用的锁对象.在上次分析的uil开源项目中也多次被用到,下面谈谈其概念和基本使用. 概念 一个可重入的互斥锁定 Lock,它具有与使用 synchronized 相 ...
- hdu 5094 状压bfs+深坑
http://acm.hdu.edu.cn/showproblem.php?pid=5094 给出n*m矩阵 给出k个障碍,两坐标之间存在墙或门,门最多10种,状压可搞 给出s个钥匙位置及编号,相应的 ...
- Codeforces Beta Round #27 E. Number With The Given Amount Of Divisors 含n个约数最小数
http://codeforces.com/problemset/problem/27/E RT,求含n个约数的最小的数 我们设答案p = 2^t1 * 3^t2 * -- * p^tk(其中p是第k ...
- SRM475
250pt: 题意:有最长N=17的一条格子,每个格子是W.B和R三种颜色之一,当某个格子上有兔子时,下一个回合该兔子按照以下的规则移动: 如果兔子在第一个格子,则向右移动一格: 否则如果兔子在倒数两 ...
- RxSwift学习笔记6:Subjects/PublishSubject/BehaviorSubject/ReplaySubject/Variable
// 从前面的几篇文章可以发现,当我们创建一个 Observable 的时候就要预先将要发出的数据都准备好,等到有人订阅它时再将数据通过 Event 发出去. // 但有时我们希望 Observabl ...