Jenkins-在Centos上配置自动化部署(Jenkins+Gitlab+Rancher)

环境:centos7

首先在服务器上安装好Jenkins和Gitlab和Rancher

Gitlab安装:https://www.cnblogs.com/1285026182YUAN/p/10726539.html

Jenkins安装:https://www.cnblogs.com/1285026182YUAN/p/11791171.html

Rancher安装:https://www.cnblogs.com/1285026182YUAN/p/11546743.html

打开Jenkins,地址:http://192.168.122.199:8078/

添加凭据

增加全局凭据

类型:SSH类型

username:自定义

Key:C:\Users\lihongyuan\.ssh\id_rsa(如何生成 SSH 密钥可在网上查到)

确定后,添加成功

创建一个新任务

项目配置General

配置源码管理

注意提前安装GitLab 插件。

Repository URL:GitLab中的项目地址

credentials:凭据

获取代码的分支 此处以 master 为例

构建触发器

记下 这个地址,配置到 GitLab中 (当有分支有提交时,自动推送代码过来,自动构建)

GitLab 中的配置方式:https://www.cnblogs.com/1285026182YUAN/p/10726539.html

点击高级,生成密钥,密钥配置到 GitLab中 (当有分支有提交时,自动推送代码过来,自动构建)

构建 执行shell脚本。

需安装dotnet core 环境:https://www.cnblogs.com/1285026182YUAN/p/11833674.html

也可在服务器上 /var/lib/jenkins/workspace 目录下 运行下面的语句。

Jenkins在shell脚本运行docker权限报错解决,参考:https://www.cnblogs.com/morang/p/9536622.html

Jenkins在执行shell脚本时可能会报类似如下的错误,是由于Jenkins没有docker权限

Got permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock: Post http://%2Fvar%2Frun%2Fdocker.sock/v1.38/containers/create?name=my-node-8: dial unix /var/run/docker.sock: connect: permission denied.

解决方法

将jenkins用户加入docker组
重启Jenkins服务

sudo gpasswd -a jenkins docker
systemctl restart jenkins

查看权限组

cat /etc/group

OK 配置完成,可重新构建测试。

Jenkins自动部署Rancher:

获取Rancher API调用的语句,填写在Execute Shell 中。如下:

Rancher API调用的语句,请查询:https://www.cnblogs.com/1285026182YUAN/p/11546743.html

具体如下命令如下:

#!/bin/bash

var=`date +%Y%m%d%H%M%S`

#发布
dotnet publish ProjNetCore2/ProjNetCore2.csproj -c Release -o ../publish/
#打镜像
docker build -t mestest.cn:/proj_netcore2:$var publish/.
#tag
docker tag mestest.cn:/proj_netcore2:$var mestest.cn:/proj_netcore2:latest
#登录
docker login -p -u admin mestest.cn:
#推送
docker push mestest.cn:/proj_netcore2:$var
docker push mestest.cn:/proj_netcore2:latest curl -k -u "token-lgwv7:dvrkw5498mhlpczf8zn2sl99bbfgq69qhcfl2wblt4qtgsrhdh6fws" \
-X PUT \
-H 'Accept: application/json' \
-H 'Content-Type: application/json' \
-d '{
"annotations": {
"cattle.io/timestamp": "2019-11-21T00:58:54Z",
"workload.cattle.io/state": "{\"bWVzdGVzdA==\":\"c-gqr2n:m-8e84afdc263f\"}"
},
"containers": [{
"allowPrivilegeEscalation": false,
"image": "mestest.cn:8085/proj_netcore2:'$var'",
"imagePullPolicy": "IfNotPresent",
"initContainer": false,
"name": "mycoreweb",
"ports": [{
"containerPort": ,
"dnsName": "mycoreweb-nodeport",
"kind": "NodePort",
"name": "8089tcp300051",
"protocol": "TCP",
"sourcePort": ,
"type": "/v3/project/schemas/containerPort"
}],
"privileged": false,
"readOnly": false,
"resources": {
"type": "/v3/project/schemas/resourceRequirements"
},
"restartCount": ,
"runAsNonRoot": false,
"stdin": true,
"stdinOnce": false,
"terminationMessagePath": "/dev/termination-log",
"terminationMessagePolicy": "File",
"tty": true,
"type": "/v3/project/schemas/container"
}],
"created": "2019-11-13T05:21:50Z",
"creatorId": null,
"deploymentConfig": {
"maxSurge": ,
"maxUnavailable": ,
"minReadySeconds": ,
"progressDeadlineSeconds": ,
"revisionHistoryLimit": ,
"strategy": "RollingUpdate"
},
"deploymentStatus": {
"availableReplicas": ,
"conditions": [{
"lastTransitionTime": "2019-11-20T12:05:09Z",
"lastTransitionTimeTS": ,
"lastUpdateTime": "2019-11-20T12:05:09Z",
"lastUpdateTimeTS": ,
"message": "Deployment has minimum availability.",
"reason": "MinimumReplicasAvailable",
"status": "True",
"type": "Available"
}, {
"lastTransitionTime": "2019-11-21T00:43:28Z",
"lastTransitionTimeTS": ,
"lastUpdateTime": "2019-11-21T00:58:56Z",
"lastUpdateTimeTS": ,
"message": "ReplicaSet \"mycoreweb-74797bc87\" has successfully progressed.",
"reason": "NewReplicaSetAvailable",
"status": "True",
"type": "Progressing"
}],
"observedGeneration": ,
"readyReplicas": ,
"replicas": ,
"type": "/v3/project/schemas/deploymentStatus",
"unavailableReplicas": ,
"updatedReplicas":
},
"dnsConfig": {
"type": "/v3/project/schemas/podDNSConfig"
},
"dnsPolicy": "ClusterFirst",
"gids": [],
"hostAliases": [],
"hostIPC": false,
"hostNetwork": false,
"hostPID": false,
"imagePullSecrets": [],
"labels": {
"workload.user.cattle.io/workloadselector": "deployment-default-mycoreweb"
},
"name": "mycoreweb",
"namespaceId": "default",
"nodeId": "",
"ownerReferences": [],
"paused": false,
"projectId": "c-gqr2n:p-4zqh9",
"publicEndpoints": [],
"readinessGates": [],
"restartPolicy": "Always",
"scale": ,
"schedulerName": "default-scheduler",
"scheduling": {
"node": {
"nodeId": "c-gqr2n:m-8e84afdc263f"
}
},
"selector": {
"matchLabels": {
"workload.user.cattle.io/workloadselector": "deployment-default-mycoreweb"
},
"type": "/v3/project/schemas/labelSelector"
},
"state": "active",
"sysctls": [],
"terminationGracePeriodSeconds": ,
"transitioning": "no",
"transitioningMessage": "",
"uuid": "7ede4f06-05d5-11ea-b16e-000c296c6b53",
"volumes": [],
"workloadAnnotations": {
"deployment.kubernetes.io/revision": "",
"field.cattle.io/creatorId": "user-257tk"
},
"workloadLabels": {
"cattle.io/creator": "norman",
"workload.user.cattle.io/workloadselector": "deployment-default-mycoreweb"
},
"workloadMetrics": []
}' \
'https://192.168.122.199:8443/v3/project/c-gqr2n:p-4zqh9/workloads/deployment:default:mycoreweb'

保存。

当Jenkins重新构建时,会自动调用Rancher的API,使Rancher项目重新部署。

Jenkins-在Centos上配置自动化部署(Jenkins+Gitlab+Rancher)的更多相关文章

  1. Jenkins-在windows上配置自动化部署(Jenkins+Gitblit)

    Jenkins-在windows上配置自动化部署(Jenkins+Gitblit) 1. 安装好 Jenkins(注:安装目录需没有空格,否则安装gitlab hook 插件时会报错,安装在c盘跟目录 ...

  2. Jenkins-在windows上配置自动化部署(Jenkins+Gitlab+IIS)

    Jenkins-在windows上配置自动化部署(Jenkins+Gitlab+IIS) web部署样例 windows服务部署样例 系统备份 在服务器上创建后缀名为.ps1的文件,例:BackUpD ...

  3. Jenkins-在windows上配置自动化部署(Jenkins+Bonobo.Git.Server)

    本文配置Jenkins.git服务器采用 Bonobo.Git.Server 1. 登录后,打开Jenkins界面,新建一个任务 2. 配置信息 3. 配置git项目地址,我们先进行其他配置,等会再继 ...

  4. 持续集成之⑤:jenkins结合脚本实现代码自动化部署及一键回滚至上一版本

    持续集成之⑤:jenkins结合脚本实现代码自动化部署及一键回滚至上一版本 一:本文通过jenkins调用shell脚本的的方式完成从Git服务器获取代码.打包.部署到web服务器.将web服务器从负 ...

  5. jenkins结合脚本实现代码自动化部署及一键回滚至上一版本

    持续集成之⑤:jenkins结合脚本实现代码自动化部署及一键回滚至上一版本 一:本文通过jenkins调用shell脚本的的方式完成从Git服务器获取代码.打包.部署到web服务器.将web服务器从负 ...

  6. Windows+.Net Framework+svn+IIS在Jenkins上的自动化部署入门

    关于Jenkins的使用及安装,上一篇文章我已经介绍过了,Windows+.NetCore+git+IIS在Jenkins上的自动化部署入门.这篇主要是在jenkins如何安装SVN和MSBuild. ...

  7. Jenkins+windows+.netcore+git+iis自动化部署入门

    什么是自动化部署,就不介绍了,喜欢直接进入主题. 一. 所需环境: 1.系统为windows10 . 2.asp.net core3.1 runtime必须安装,因为我的代码是asp.net core ...

  8. AWS DevOps – 配合Jenkins和CodeDeploy实现代码自动化部署

    AWS DevOps – 配合Jenkins和CodeDeploy实现代码自动化部署 Amazon ElastiCache 连接至 Redis 节点 通过 AWS Command Line Inter ...

  9. Laravel学习笔记(三)--在CentOS上配置Laravel

    在Laravel框架上开发了几天,不得不说,确实比较优雅,处理问题逻辑比较清楚.     今天打算在CentOS 7上配置一个Laravel,之前都是在本机上开发,打算实际配置一下.     1)系统 ...

随机推荐

  1. c++生成的动态库移到其他电脑上,动态库不能运行

    最近的一个项目中遇到了一个问题,C++的一个动态库在我自己的电脑上可以被C#程序引用,我把程序安装到其他电脑上出现了异常,提示找不到DLL,偶然间发现我安装vsc++,C#的程序就不会报错.因为这个C ...

  2. HDFS 命令行基本操作

    1.hdfs命令行 (1)查看帮助 hdfs dfs -help (2)查看当前目录信息 hdfs dfs -ls / (3)上传文件 hdfs dfs -put /本地路径 /hdfs路径 (4)剪 ...

  3. UVA10820 交表 Send a Table

    \(\Large\textbf{Description:} \large{输入n,求有多少个二元组(x,y)满足:1\leqslant x,y\leqslant n,且x和y互素.}\) \(\Lar ...

  4. 官方关于Dialog的介绍

    将Activity显示成Dialog的形式: Tip: If you want a custom dialog, you can instead display an Activity as a di ...

  5. springboot 中单机 redis 实现分布式锁

    在微服务中经常需要使用分布式锁,来执行一些任务.例如定期删除过期数据,在多个服务中只需要一个去执行即可. 以下说明非严格意义的分布式锁,因为 redis 实现严格意义的分布式锁还是比较复杂的,对于日常 ...

  6. 利用Python实现自动扫雷

    自动扫雷一般分为两种,一种是读取内存数据,而另一种是通过分析图片获得数据,并通过模拟鼠标操作,这里我用的是第二种方式. 一.准备工作 我的版本是 python 3.6.1python的第三方库:win ...

  7. Ican协议建立连接我的感悟

    有一个情形我突然之间想明白了. 注意下面情形:                             假设节点A与节点B已经 正常的建立了连接,并且进行了通讯. 假设 节点B收到了 节点A 的 &q ...

  8. ping不通www.baidu.com,但可以访问www.baidu.com网页

    https://blog.csdn.net/stpeace/article/details/45116425 了解网络的人, 基本上都用过ping命令, 这个优秀的小工具通常能非常靠谱地检测网络的连通 ...

  9. WTL之手动编写框架窗口

    新版博客已经搭建好了,有问题请访问 htt://www.crazydebug.com 本人是一个实践主义者,不罗嗦上一篇工程搭建好以后,这一篇就开始写代码,写之前再说几句,如果你熟悉MFC分析过MFC ...

  10. 如何禁用AD OU 下面的邮箱用户的Exchange ActiveSync 和 适用于设备的OWA

    Get-Mailbox -OrganizationalUnit QQ禁用名单 | Set-CASMailbox  -ActiveSyncEnabled $false -OWAforDevicesEna ...