Docker => 1.31.1
Jenkins => 2.174
安装Docker
[root@localhost ~]# yum install -y docker
关于安装Docker的步骤,详情见我之前的博客
在Docker里面安装软件的镜像,我都是安装的最新版本
安装MySQL
[root@docker ~]# docker pull mysql
安装Tomcat
[root@docker ~]# docker pull tomcat
安装jenkins,这里要注意了,不能直接用jenkins这个镜像,得用jenkins/jenkins这个镜像,如果你用了jenkins镜像的话,后面安装jenkins的相关插件会出错版本不兼容的情况
[root@docker ~]# docker pull jenkins/jenkins
在当前用户的家目录里面创建一个jenkins_home目录,用来存放jenkins运行过程中所产生和文件,我的是直接放在/root/文件夹下
[root@docker ~]# mkdir -p /root/jenkins_home
生成一个可以运行的容器
[root@docker ~]# docker run -d -v /root/jenkins_home/:/var/jenkins_home -p 8080:8080 -p 50000:50000 --name jenkins jenkins:jenkins
如果执行这个命令的时候,报
touch: cannot touch '/var/jenkins_home/copy_reference_file.log': Permission denied
Can not write to /var/jenkins_home/copy_reference_file.log. Wrong volume permissions?
这是因为权限不足导致的,那就请执行一下下面这条语句然后再启动容器
[root@docker ~]# chown -R 1000:1000 /root/jenkins_home
启动容器后我们找到下面这段日志
INFO:
(*************************************************************
(*************************************************************
(*************************************************************
Jenkins initial setup is required. An admin user has been created and a password generated.
Please use the following password to proceed to installation:
dc89901a2b3141539c6ba6ad5a20d6cc
This may also be found at: /var/jenkins_home/secrets/initialAdminPassword
(*************************************************************
(*************************************************************
(*************************************************************
或者用语句
[root@docker ~]# docker exec -it jenkins /bin/bash
[root@docker ~]# cat /var/jenkins_home/secrets/initialAdminPassword
来查看jenkins生成的密码 dc89901a2b3141539c6ba6ad5a20d6cc
启动完成后,我们用浏览器来访问
我的地址是 http://192.168.0.177:8080 192.168.0.177是我的CentOS虚拟机地址
在管理员密码里输入我们之前查看到的密码:dc89901a2b3141539c6ba6ad5a20d6cc
选择安装推荐的插件
等待插件全部安装完成
创建第一个管理员用户
输入你的帐户信息,点保存并完成
实例配置,默认就好了
保存并完成后
就可以使用了
在创建一个新任务之前,我们安装两个插件,一个是Maven的插件,一个SSH的插件
系统管理->插件管理
在可选插件 搜索 Maven Integration 然后选择 直接安装
安装完成后,再安装SSH的插件 搜索 Publish Over SSH 然后选择 直接安装
安装完成后,重启jenkins
登陆
我们做一些配置 系统管理 -> 系统配置 -> Publish over SSH
在做配置之前,我们要在CentOS端生成私钥
[root@docker ~]# ssh-keygen -t rsa
Passphrase 生成私钥时填写的密码,如果没有填写密码,这里为空
Path to key 私钥的路径,因为我的是在Docker里面运行,因为权限的关系,这里会提示找不到文件
Key 私钥的串,打开私钥文件获得
Path to key 和 Key 二选一填写
Name 给SSH Server取个名字,可以随意取
Hostname 主机地址
Username 登陆用户
Remote Directory 登陆后默认打开的文件夹
配置完后,点应用 -> 保存
再配置 系统管理 -> 全局工具配置
因为我是走的Docker镜像运行,因为权限的原因,所以这里面的配置我都是选的自动安装
安装JDK
这里要注意,在Oracle网站下载的话,得输入Oracle的用户名和密码,没有的话,创建一个。
Git默认
安装Maven
点应用 保存
这些配置好了,只有等第一次构建项目的时候,Jenkins才会去下载安装相关的插件
这里要注意了,如果没有用Docker来启Jenkins,那就可以用手动指定相关的路径。Git配置的时候,要指定到具体的文件
新建一个任务
输入一个任务名称 选择构建一个maven项目 确定
源码配置
Repository URL 仓库的URL
Credentials 配置登陆仓库的用户名和密码
Branch Specifier (blank for 'any') 要拉取的分支
构建触发器
勾选 轮询SCM 日程表 填 H/1 * * * * 每小时一次,按需配置。
Build
Root POM pom.xml文件路径,一般都在项目的根目录下面
构建后操作
我们选择 Send build artifacts over SSH
这个配置就是构建完成后,我们把项目根目录下面的target/visa.war自动发送到我们在基础配置里面配置的路径/root/tomcat/publish文件夹里面
Remote directory 远程目录,我们直接放根目录,所以留空
Exec command 先不做任何操作
应用 保存 到以下页面。
点立即构建 然后 转到 控制台输出 就可以看到构建日志了
控制台输出
直到看到这个,我们就构建成功了
然后我们在服务器路径
/root/test_jenkins_home/workspace/visa/target 下面找到 visa.war 文件了
也能在
/root/tomcat/publish 下面找到visa.war 文件了
到这一步为止,我们构建完项目后,就能生成一个项目的 war 包了。
这里我们先用Docker来打包镜像后部署项目
在/root/tomcat/publish下面新建Dockerfile
[root@docker ~]# vim /root/tomcat/publish/Dockerfile
输入以下代码
from docker.io/tomcat:latest #你的 tomcat的镜像
MAINTAINER visa_test@163.com #作者
COPY visa.war /usr/local/tomcat/webapps #放置到tomcat的webapps目录下
保存
生成一个名为visa的镜像 记得后面有一个点,很重要。
[root@docker ~]# docker build -t visa .
启动新的名为visa的容器,用visa的镜像
[root@docker ~]# docker run -p 80:8080 --name visa visa
到这里为止,项目就能启动成功了
下面进行自动化部署配置
点配置后找到构建后操作
在Exec command 中输入
cd /root/tomcat/publish
docker stop visa
docker rm visa
docker rmi visa
docker build -t visa .
docker run -p 80:8080 --name visa visa
因为我们每次只要点构建,我们就完成整个流程的自动化。所以上面这一些命令,就是一套组合
cd /root/tomcat/publish => 定位到发布目录
docker stop visa => 停止之前已运行的容器
docker rm visa => 删除之前启用的容器
docker rmi visa => 删除之前构建好的镜像
docker build -t visa . => 重新构建本次新的镜像
docker run -p 80:8080 --name visa visa => 启用并运行新的容器