【收集】Docker实战集锦初见

项目三 Java Spring+GitLab+Jenkins+M

2020-04-15  本文已影响0人  Explorer_z

在项目一和二 的基础上,进行项目三

通过命令管理k8s集群

1 Rancher平台K8S-M节点安装Kubectl工具替换阿里源

cd /etc/apt/sources.list.d
vim kubernetes.list
deb https://mirrors.aliyun.com/kubernetes/apt/ kubernetes-xenial main

apt-get update

问题 :
执行 apt-get update 后


Snipaste_2020-03-21_09-35-11.jpg

问题原因:主要是因为apt还在运行
解决方案:杀死所有的apt进程。
1:查找所有apt相关的进程,并用命令杀死。
ps afx|grep apt
2:删除锁定文件
锁定的文件会阻止 Linux 系统中某些文件或者数据的访问,这个概念也存在于 Windows 或者其他的操作系统中。
一旦你运行了 apt-get 或者 apt 命令,锁定文件将会创建于 /var/lib/apt/lists/、/var/lib/dpkg/、/var/cache/apt/archives/ 中。
这有助于运行中的 apt-get 或者 apt 进程能够避免被其它需要使用相同文件的用户或者系统进程所打断。当该进程执行完毕后,锁定文件将会删除
sudo rm /var/lib/dpkg/lock

2 Rancher平台K8S-M节点安装指定版本的kubecl1.8.3-00

先在rancher 的web 进入命令行 查看需要下载 kubectl 的版本


Snipaste_2020-03-21_10-29-36.jpg

执行 kubectl version


Snipaste_2020-03-21_10-30-52.jpg

然后在服务器端 执行(更新完后)
apt-cache madison kubectl # 查看可下载kubectl 版本
apt-get install kubectl=1.8.3-00 (安装)
kubectl version #查看版本号

3.Rancher平台配置K8S-M节点Kubectl环境变量

生成一个配置文件
mkdir ~/.kube
cd ./kube
vim config
把下面内容复制到 config中


Snipaste_2020-03-21_10-32-25.jpg
Snipaste_2020-03-21_10-32-39.jpg

测试
kubectl get node

4设置免密登录

4.1 Rancher平台K8S-M节点Ubuntu系统设置root用户ssh远程登录
(K8S-M节点 执行)
设置ssh
cd /etc/ssh

vim sshd_config (设置配置文件)
root 用户登录权限设置为yes


image.png

systemctl restart sshd #重启sshd 的服务

4.2 Jenkins向K8S-M节点做免密登录
ssh-key #生成秘钥
ssh-copy-id -i .ssh/id_rsa.pub root@ip(k8smaster 的地址)
ssh root@ip(k8smaster 的地址) # 测试是否成功

5 kubectl创建Delopyment和Pod Replicas以及Service服务
5.1kubectl命令基础
kubectl run tomcat-1 --replicas=1 --labels="app=tomcat-1" --image=镜像 --port=8080
(--replicas 指定副本数)

Kubectl expose depoyment/tomcat-1 --type="LoadBalancer" --port 8080
(--type 指定网络类型)
(tomcat-1 和 上面run 的 保持一致)
Kubectl get service (可查看网络类型)

测试

5.2通过脚本创建 通过shell脚本实现自动化部署容器
(先到阿里云 查看登录拉取命令,及需要拉取的镜像,再执行 下面脚本)

vim run.sh
#!/bin/bash
#登录到阿里云的镜像仓库
sudo docker login --username=少少少少少泽 --password=WsZ879991813 registry.cn-hangzhou.aliyuncs.com
#从仓库中pull 镜像
sudo docker pull registry.cn-hangzhou.aliyuncs.com/1907/tomcat:v4
#通过改镜像创建pod  副本  部署
kubectl run tomcat-1 --replicas=1 --labels="app=tomcat-1" --image=registry.cn-hangzhou.aliyuncs.com/1907/tomcat:v4  --port=8080
#创建service 服务 实现网络互通  负载均衡
kubectl expose deployment/tomcat-1  --type="LoadBalancer" --port 8080
#查看网络状态
kubectl get service

chmod +x  run.sh   # 给脚本执行权限
./run.sh                   # 运行测试

6 Jenkins构建Spring项目自动部署到K8S集群并外网访问
1 Jenkins配置远程执行脚本的步骤
(在项目二的基础上执行)
再添加执行shell 脚本


Snipaste_2020-03-21_10-52-40.jpg
Snipaste_2020-03-21_10-54-02.jpg

保存 build 测试

2 扩展1.迭代脚本实现版本号自动更新
把tag的值传过去 动态的传参


Snipaste_2020-03-21_11-03-15.jpg

现在 post steps 是这样的


Snipaste_2020-03-21_11-06-48.jpg Snipaste_2020-03-21_11-07-11.jpg

修改 远程服务器的脚本

把 版本 改为$1 , 获得参数
Vim run.sh
#!/bin/bash
#登录到阿里云的镜像仓库
sudo docker login --username=少少少少少泽 --password=WsZ879991813 registry.cn-hangzhou.aliyuncs.com
#从仓库中pull 镜像
sudo docker pull registry.cn-hangzhou.aliyuncs.com/1907/tomcat:$1
#通过改镜像创建pod  副本  部署
kubectl run tomcat-$1 --replicas=1 --labels="app=tomcat-$1" --image=registry.cn-hangzhou.aliyuncs.com/1907/tomcat:$1  --port=8080
#创建service 服务 实现网络互通  负载均衡
kubectl expose deployment/tomcat-$1  --type="LoadBalancer" --port 8080
#查看网络状态
kubectl get service

jenkins 服务器上 build 测试

扩展2 邮件通知的形式发送
1
先到163 邮箱配置
登录163 邮箱 查找配置信息
设置--pop3---检查开启的服务


image.png

2 系统配置
配置系统管理员的邮箱


Snipaste_2020-03-21_11-13-21.jpg
Snipaste_2020-03-21_11-15-08.jpg image.png
image.png
自己写的 发送内容(也可以不改)
<!DOCTYPE html>    
<html>    
<head>    
<meta charset="UTF-8">    
<title>${ENV, var="JOB_NAME"}-第${BUILD_NUMBER}次构建日志</title>    
</head>    
    
<body leftmargin="8" marginwidth="0" topmargin="8" marginheight="4"    
    offset="0">    
    <table width="95%" cellpadding="0" cellspacing="0"  style="font-size: 11pt; font-family: Tahoma, Arial, Helvetica, sans-serif">    
        <tr>    
            本邮件由系统自动发出,无需回复!<br/>            
            各位同事,大家好,以下为${PROJECT_NAME }项目构建信息</br> 
            <td><font color="#CC0000">构建结果 - ${BUILD_STATUS}</font></td>   
        </tr>    
        <tr>    
            <td><br />    
            <b><font color="#0B610B">构建信息</font></b>    
            <hr size="2" width="100%" align="center" /></td>    
        </tr>    
        <tr>    
            <td>    
                <ul>    
                    <li>项目名称 : ${PROJECT_NAME}</li>    
                    <li>构建编号 : 第${BUILD_NUMBER}次构建</li>    
                    <li>触发原因: ${CAUSE}</li>    
                    <li>构建状态: ${BUILD_STATUS}</li>    
                    <li>构建日志: <a href="${BUILD_URL}console">${BUILD_URL}console</a></li>    
                    <li>构建  Url : <a href="${BUILD_URL}">${BUILD_URL}</a></li>    
                    <li>工作目录 : <a href="${PROJECT_URL}ws">${PROJECT_URL}ws</a></li>    
                    <li>项目  Url : <a href="${PROJECT_URL}">${PROJECT_URL}</a></li>    
                </ul>    

<h4><font color="#0B610B">失败用例</font></h4>
<hr size="2" width="100%" />
$FAILED_TESTS<br/>

<h4><font color="#0B610B">最近提交(#$SVN_REVISION)</font></h4>
<hr size="2" width="100%" />
<ul>
${CHANGES_SINCE_LAST_SUCCESS, reverse=true, format="%c", changesFormat="<li>%d [%a] %m</li>"}
</ul>
详细提交: <a href="${PROJECT_URL}changes">${PROJECT_URL}changes</a><br/>

            </td>    
        </tr>    
    </table>    
</body>    
</html>

点击 Default Triggers,然后配置


image.png

3 . 配置项目


image.png

构建后的操作,选择邮件通知


Snipaste_2020-03-21_11-22-51.jpg Snipaste_2020-03-21_11-27-42.jpg

再点击高级
点新增 ,添加接受列表


Snipaste_2020-03-21_11-31-08.jpg
Snipaste_2020-03-21_11-31-49.jpg image.png

保存后,重启构建build 测试 是否收到邮件


Snipaste_2020-03-21_11-33-22.jpg
上一篇 下一篇

猜你喜欢

热点阅读