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. greenplum 导入数据方式

    参考: http://gpdb.docs.pivotal.io/4390/admin_guide/load/topics/g-working-with-file-based-ext-tables.ht ...

  2. Zabbix WebUI 配置监控Zabbix Agent

    Zabbix WebUI 配置监控Zabbix Agent 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.部署zabbix服务 1>.部署zabbix server 和z ...

  3. vue :style 动态绑定style

    <div class="right userPicture" :style="[{'background':`url(${userImg}) no-repeat c ...

  4. 06.Delphi接口的不对等的多重继承

    uSayHello代码如下 unit uSayHello; interface uses SysUtils, Windows, Messages, Classes, Graphics, Control ...

  5. 京东云与AI 10 篇论文被AAAI 2020 收录,京东科技实力亮相世界舞台

    美国时间2月7-12日,AAAI 2020大会在纽约正式拉开序幕,AAAI作为全球人工智能领域的顶级学术会议,每年评审并收录来自全球最顶尖的学术论文,这些学术研究引领着技术的趋势和未来.京东云与AI在 ...

  6. 读取多张MNIST图片与利用BaseEstimator基类创建分类器

    读取多张MNIST图片 在读取多张MNIST图片之前,我们先来看下读取单张图片如何实现 每张数字图片大小都为28 * 28的,需要将数据reshape成28 * 28的,采用最近邻插值,如下 def ...

  7. Python基础笔记:高级特性:切片、迭代、列表生成式、生成器、迭代器

    题记: 在python中,代码不是越多越好,而是越少越好.代码不是越复杂越好,而是越简单越好. 1行代码能实现的功能,绝不写5行代码. 请始终牢记:代码越少,开发效率越高. 切片 >>&g ...

  8. SpringBoot 系列教程之事务隔离级别知识点小结

    SpringBoot 系列教程之事务隔离级别知识点小结 上一篇博文介绍了声明式事务@Transactional的简单使用姿势,最文章的最后给出了这个注解的多个属性,本文将着重放在事务隔离级别的知识点上 ...

  9. Vulkan Device Memory

    1.通过下面的接口,可以获得显卡支持的所有内存类型: MemoryType的类型如下: 2.引用索引3对内存的描述 我们可以通过调用vkGetPhysicalDeviceMemoryPropertie ...

  10. IDEA 分屏显示

    效果: 步骤: 对着某个标签页单击右键,选择Split Vertically或者Split Horizontally即可.