Git+Spring-boot+Docker+ Maven +Registry私有仓库 +jenkins 持续集成测试

来源:互联网 发布:不用网络的搜题软件 编辑:程序博客网 时间:2024/06/11 22:50

测试Github项目地址:https://github.com/cbamls/eureka-registry
这里写图片描述

第一步 pull docker-registry

#:docker pull registry//   此/opt/data/registry目录为私有仓库镜像宿主机映射目录#:/usr/bin/docker -d -v -v /opt/data/registry:/tmp/registry --insecure-registry 222.27.196.8:5000

第二步 build jekins镜像

创建一个包容以下内容的Dockerfile:

FROM jenkinsUSER rootRUN apt-get update \  && apt-get install -y sudo \  && rm -rf /var/lib/apt/lists/*RUN echo "jenkins ALL=NOPASSWD: ALL" >> /etc/sudoersUSER jenkinsCOPY plugins.txt /usr/share/jenkins/plugins.txtRUN /usr/local/bin/plugins.sh /usr/share/jenkins/plugins.txt

我们需要赋予jenkins用户sudo权限以便能在容器内运行Docker命令。当然,也可以将jenkins用户加入到Docker组中来避免在所有Docker命令前使用‘sudo’,不过由于这个组gid的不同会造成不可移植(如Pini文中所述)。

最后两行用于处理plugins.txt文件中定义的插件。如果你不需要任何插件可以忽略这两行,不过我推荐至少包括如下内容:

$ cat plugins.txtscm-api:latestgit-client:latestgit:latestgreenballs:latest

如果不想安装任何插件,可创建个空文件或将相关指令从Dockerfile中删除。本文并不需要上述插件。

现在来构建并运行容器,将Docker socket和程序映射进来。

$ docker build -t myjenkens....Successfully built 471fc0d22bff$ docker images

第四步 启动myjenkins容器

/home/jenkins_home 目录为jenkins的主目录本地映射, 只有这样jenkins容器干掉后,数据才不会丢失

#: docker run -d -p 8080:8080 -v /var/run/docker.sock:/var/run/docker.sock -v $(which docker):/usr/bin/docker -v /lib64/libdevmapper.so.1.02:/usr/lib/libdevmapper.so.1.02 -v /lib64/libsystemd.so.0:/usr/lib/libsystemd.so.0 -v /lib64/libgcrypt.so.20:/usr/lib/libgcrypt.so.20 -v /lib64/libudev.so.0:/usr/lib/libudev.so.0 -v /home/jenkins_home:/var/jenkins_home  myjenkins

第五步 jenkins设置

经过上面的配置,你可以访问你的Jenkins了,在浏览器中输入:http://your server ip:8080/,效果如下:

img

按照提示我们执行cat /var/lib/jenkins/secrets/initialAdminPassword得到Administrator password,注意var 要改成home ,输入后点击Continue,如下:

img

设置初始账户和密码

img

设置完成后进入界面:

img

下载其它插件

系统管理 –>管理插件
在可选插件中下载如下两个插件
这里写图片描述
这里写图片描述

配置Publish Over SSH

系统管理 –> 系统设置 –>Publish over SSH

这里写图片描述

配置GitHub Plugin

系统管理 –> 系统设置 –> GitHub –> Add GitHub Sever

如下图所示

img

API URL 输入 https://api.github.com,Credentials点击Add添加,Kind选择Secret Text,具体如下图所示。

img

设置完成后,点击TestConnection,提示Credentials
verified for user UUserName, rate limit: xxx
,则表明有效。

第六步 github配置

sercret text

注:此处需要一个对项目有写权限的账户

进入github –> setting –> Personal Access Token –> Generate new token

img

img

自己先保存此token,如果丢失,之后再也无法找到这个token

GitHub webhooks 设置

进入GitHub上指定的项目 –> setting –> WebHooks&Services –> add webhook –> Payload URL为下图要求

这里写图片描述
这部分内容等到在jenkins新增任务时会遇到 这里大家可以回头再配
img
jenkins 中点开用户, 拿到api token 最后Payload URL 完整写法是

http://userName:userApiToken@JENKENINS_URL/job/projectName?build?token=APITOKEN

这里写图片描述

第七步 构建一个maven项目

这里写图片描述
配置此项目
这里写图片描述
这里写图片描述

  1. 填写项目的git地址, eg. https://github.com/your_name/your_repo_name.git
  2. 添加github用户和密码
  3. 选择githubweb源码库浏览器,并填上你的项目URL,这样每次构建都会生成对应的changes,可直接链到github上看变更详情

-设置钩子token,触发远程构建
通过钩子 只要Github有push操作就会自动构建, 这里token就是上面的在Github配置的token=?
这里写图片描述
- 构建触发器,构建环境

这里写图片描述

- maven build 设置
这里写图片描述
- maven 通过ssh 远程部署设置
这里写图片描述
参数说明:

  1. Transfer SetSource files:表示要上传的本地的jar包及路径,可到工作空间去看。

  2. Remove prefix:表示要上传时要去除的文件夹,即只上传jar包。

  3. remote driectory:即表示执行时的路径,相当于把jar包上传到这里了。这里的base dirPublish Over SSH 设置的/jenkins_release

  4. exec commad:要执行的命令脚本。

脚本deploy.sh

#!/bin/shREGISTRY_URL=222.27.196.8:5000cd /jenkins_releasecp *.jar /opt/jenkinsWeb/releasecd /opt/jenkinsWeb/releasepath=`pwd`echo $pathif docker images | grep ${REGISTRY_URL}/eureka-registry        then                docker rmi ${REGISTRY_URL}/eureka-registryfidocker build -t ${REGISTRY_URL}/eureka-registry .docker push  ${REGISTRY_URL}/eureka-registryif docker ps -a | grep -i eureka-registry then        docker rm -f eureka-registryfidocker create --name eureka-registry ${REGISTRY_URL}/eureka-registrysh /opt/jenkinsWeb/bin/bootstrap.sh~                                    

最后点击保存即可
可以看到把通过ssh传过来的jar 扔到 /opt/jenkinsWeb/release 目录, 此目录下还有个Dockerfile 用来构建Spring-boot 应用镜像。内容:

FROM frolvlad/alpine-oraclejdk8:slimVOLUME /tmpADD kitty-eureka-registry.jar app.jarENV JAVA_OPTS="-Dlogging.path=/var/log"ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /app.jar" ]                                                                                  

- 构建后操作

img

第八步 测试构建效果:

-可以用curl 模拟

curl -s -u cbam:c4118bbe83b80a855eafc7939fd0xxxx -X POST http://222.27.196.8:8080/job/eureka-registry/build?token=yyyyy

如果出现Error 403 No valid crumb was included in the request错误, 在jenkins 全局安全设置中取消 对 防止跨站点请求伪造 的勾选
这里写图片描述
-或着直接在IDEA 中直接编辑项目并push 到remote ,看效果已经开始构建:
这里写图片描述
-Github效果
-测试效果1

img

-测试效果2

img

参考

Spring-boot日志管理:http://www.jianshu.com/p/59787a123b05
知秋大佬持续集成:https://github.com/muyinchen/woker/blob/master/%E9%9B%86%E6%88%90%E6%B5%8B%E8%AF%95%E7%8E%AF%E5%A2%83%E6%90%AD%E5%BB%BA/%E6%89%8B%E6%8A%8A%E6%89%8B%E6%95%99%E4%BD%A0%E6%90%AD%E5%BB%BAJenkins%2BGithub%E6%8C%81%E7%BB%AD%E9%9B%86%E6%88%90%E7%8E%AF%E5%A2%83.md
jenkins maven Spring Boot git Linux持续集成环境搭建教程 http://www.jianshu.com/p/d4f2953f3ce0