本来没想着要写这篇博客,但是在实操过程中,一个是被网络问题搞炸了心态(真心感觉网络能把人搞疯,别人下个包、下个镜像几秒钟搞定,我看着我的几KB小水管真是有苦说不出),另一个就是这里面坑还是有一些的,写出来也是为了让大家避免重复踩坑
几个注意点:
下方shell命令绝大部分都需要管理员权限,所以如果你使用的用户不是root,则都要加上sudo
对于较复杂的命令我都提供了注释版和无注释版,无注释版是为了让你复制起来方便
准备工作CentOS 7.x
Docker
Jenkins
一份支持 docker 的 ASP.NET Core 应用程序代码,可以直接用我的:https://github.com/xiaoxiaotank/MyAspNetCoreApp
安装Docker官方文档:https://docs.docker.com/engine/install/centos/
如果你选择的是一个新系统,则建议首先更新 yum 和系统内核
yum update确保卸载旧版docker
/var/lib/docker/ 下的镜像、容器、卷和网络都会保留
旧版本中Docker被命名为docker或docker-engine,现在被命名为docker-ce
yum remove docker \ docker-client \ docker-client-latest \ docker-common \ docker-latest \ docker-latest-logrotate \ docker-logrotate \ docker-engine安装 yum-utils(其提供了yum-config-manager,下方要用到)
yum install -y yum-utils配置 yum 阿里云 docker 仓库
docker官方仓库: https://download.docker.com/linux/centos/docker-ce.repo
yum-config-manager --add-repo安装 docker
yum install -y docker-ce docker-ce-cli containerd.io配置 docker 镜像加速器
获取加速器地址:https://cr.console.aliyun.com/cn-hangzhou/instances/mirrors
sudo mkdir -p /etc/docker sudo tee /etc/docker/daemon.json <<-'EOF' { "registry-mirrors": ["这里填入你的加速器url"] } EOF sudo systemctl daemon-reload sudo systemctl restart docker查看 docker 信息
docker infohello-world 测试
docker run hello-world 安装并初始化Jenkins官方文档:https://www.jenkins.io/doc/book/installing/docker/
先说一下:官方文档中使用了镜像docker:dind来执行docker命令和运行程序容器,我感觉完全没啥必要,而且引入这玩意会带来很多额外的问题,所以我没用它。
如果你想了解dind,请访问这里和这篇博客
安装Jenkins创建Dockerfile文件
vim Dockerfile在Dockerfile文件中填入以下内容
Tag参考:https://hub.docker.com/r/jenkins/jenkins
注意:不要使用过时的镜像 jenkins,而应该使用镜像 jenkins/jenkins
FROM jenkins/jenkins:lts-jdk11 USER root RUN apt-get update && apt-get install -y apt-transport-https \ ca-certificates curl gnupg2 \ software-properties-common RUN curl -fsSL https://download.docker.com/linux/debian/gpg | apt-key add - RUN apt-key fingerprint 0EBFCD88 RUN add-apt-repository \ "deb [arch=amd64] https://download.docker.com/linux/debian \ $(lsb_release -cs) stable" # 安装 docker-ce-cli 才能在 jenkins 中发送 docker 命令到 docker daemon RUN apt-get update && apt-get install -y docker-ce-cli构建镜像
docker build . -t myjenkins如果出现警告:[Warning] IPv4 forwarding is disabled. Networking will not work.
其实就是说你的linux没有开启 Ipv4 数据包转发功能
可以先尝试重启docker解决
systemctl restart docker如果无效,则
# 1. 打开 sysctl.conf vim /etc/sysctl.conf # 2.添加下面一行 net.ipv4.ip_forward=1 # 3.重启 network 和 docker systemctl restart network && systemctl restart docker运行Jenkins
注释版
docker run \ --name jenkins \ # 给容器起个名字,叫做 jenkins --detach \ # 以后台分离模式运行 --publish 8080:8080 \ # host 8080端口映射容器8080端口 --publish 50000:50000 \ # host 50000端口映射容器50000端口 --volume jenkins-data:/var/jenkins_home \ # 卷 jenkins-data 映射容器路径/var/jenkins_home,这样就可以在host上直接修改jenkins配置了 --volume /var/run/docker.sock:/var/run/docker.sock \ # host 上的docker sock映射容器的docker sock,这样容器内的docker命令都会发送到host上的docker中来执行 myjenkins # 使用刚刚构建的镜像 myjenkins 来运行容器无注释版
docker run \ --name jenkins \ --detach \ --publish 8080:8080 \ --publish 50000:50000 \ --volume jenkins-data:/var/jenkins_home \ --volume /var/run/docker.sock:/var/run/docker.sock \ myjenkins更换Jenkins插件源
前面我们将容器内的路径 /var/jenkins_home 映射到了volume jenkins-data,而所有的docker volume 都存放在目录 /var/lib/docker/volumes/下
打开hudson.model.UpdateCenter.xml
vim /var/lib/docker/volumes/jenkins-data/_data/hudson.model.UpdateCenter.xml将文件中的url改为清华大学官方镜像:
https://mirrors.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json即:
<?xml version='1.1' encoding='UTF-8'?> <sites> <site> <id>default</id> <!--原 url: https://updates.jenkins.io/update-center.json --> <url>https://mirrors.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json</url> </site> </sites>重启 Jenkins:
docker restart jenkins 初始化Jenkins访问:<host-ip>:8080
输入管理员初始密码
查看管理员初始密码:
cat /var/lib/docker/volumes/jenkins-data/_data/secrets/initialAdminPassword