jenkins+docker+git+etcd实现应用配置文件管理
两台机器:
一台机器安装gitlab: http://www.cnblogs.com/cjsblogs/p/8716932.html
另一台机器安装etcd+docker+jenkins
jenkins-docker: https://www.cnblogs.com/cjsblogs/p/8717602.html
防火墙端口启动;
firewall-cmd --zone=public --add-port=2379/tcp --permanent
firewall-cmd --zone=public --add-port=2380/tcp --permanent
firewall-cmd --reload
安装etcd:
yum install etcd -y
systemctl start etcd
安装setuptools
wget --no-check-certificate https://pypi.python.org/packages/69/56/f0f52281b5175e3d9ca8623dadbc3b684e66350ea9e0006736194b265e99/setuptools-38.2.4.zip#md5=e8e05d4f8162c9341e1089c80f742f64
unzip setuptools-38.2.4.zip
cd setuptools-38.2.4
python setup.py install
cd ..
安装pip
wget --no-check-certificate https://github.com/pypa/pip/archive/1.5.5.tar.gz
tar -xvf 1.5.5.tar.gz #解压文件
cd pip-1.5.5/
python setup.py install
安装python etcd模块:
pip install python-etcd
在git创建dev组,以及dev_etcd项目, 并且制作好的etcd脚本:
git目录如下:

etcdGet.py
#!/usr/bin/env python2.7
# -*- coding:utf-8 -*-
from __future__ import print_function import etcd
import sys
import os
import re
etcdCli=etcd.Client(host=sys.argv[1],port=2379)
f = open(sys.argv[3],'wb')
f.write(etcdCli.get('%s' % sys.argv[2]).value.encode('utf-8'))
f.close()
etcdPush.py
#!/usr/bin/env python2.7
# -*- coding:utf-8 -*-
from __future__ import print_function
import etcd
import sys
import time
import os
import re
reload (sys)
etcdCli=etcd.Client(host=sys.argv[1],port=2379)
def push(local_dir, top_path='/', with_local_path=False):
try:
for root, dirs, files in os.walk(local_dir):
if '.' not in dirs and '.' not in root:
for name in files:
file = os.path.join(root, name)
f = open(file)
content = f.read()
f.close()
if not with_local_path:
etcd_path = '/' + top_path.strip('/') + '/' + file[re.match(local_dir, file).end():].strip(
'/')
else:
etcd_path = '/' + top_path.strip('/') + '/' + file.strip('/')
print(etcd_path)
etcdCli.write(etcd_path, content)
except Exception as e:
etcd.EtcdException(e)
push(sys.argv[2],top_path=sys.argv[3])
etcdRead.py
#!/usr/bin/env python
import etcd
import sys
import time
import os
import re
reload (sys)
def getValue(host,port,location):
etcdCli=etcd.Client(host=host,port=port)
context=etcdCli.read(location).value
return context envValue=getValue(host=sys.argv[1],port=int(sys.argv[2]),location=sys.argv[3])
print(envValue)
getRegistryTagList.py
#!/usr/bin/env python2.7
import requests
import json
import sys def getRegistryTagList():
registry="http://harbor.xxx.com"
res=requests.get(registry+"/v2/")
assert res.status_code == 200 res=requests.get(registry+"/v2/_catalog?n=1000")
assert res.status_code == 200 repositories = res.json().get("repositories",[]) for repository in repositories:
res = requests.get(registry + "/v2/{}/tags/list".format(repository))
tags = res.json().get("tags",None)
if tags:
for tag in tags:
image = format(repository)
tag = format(tag)
if len(sys.argv) <2:
print (image+":"+tag)
else:
AppTargetName=sys.argv[1]
if image.endswith(AppTargetName):
print (image+":"+tag)
if __name__ == "__main__":
getRegistryTagList()
此处需要修改对应的私有docker仓库地址
healthyCheck.py
#!/usr/bin/env python
import requests,sys,os def healthyCheck():
if len(sys.argv) < 2: sys.exit("need 1 argument")
url = sys.argv[1]
try:
code = requests.get(url,timeout=1).status_code
if code >= 200 and code < 400:
print "healthy check ok , status_code:%s" % code
else:
print "healthy check not ok, status_code:%s" % code
sys.exit("healthy check not ok")
except Exception,e:
print "e"
if __name__ == "__main__":
healthyCheck()
import.sh
/opt/dev_etcd/etcdPush.py 172.16.5.113 appCfgs /xxx.com/instances
此处建立etcd推送的配置文件服务器以及路径
以上所有的脚本全部完毕
接下来需要在jenkins上创建job结合git的webhooks推送应用配置文件
jenkins创建job:


截图处创建git的webhooks能用到


以上git clone直接提交用户名和密码拉取git代码, 其中我的密码带有@符号, git clone无法识别@符号, 需要将@转义为%40故账号需要特殊处理:

最后在git上创建webhooks

综上全部创建完毕, 在jenkins上点击job立即构建测试吧
jenkins+docker+git+etcd实现应用配置文件管理的更多相关文章
- 基于 Jenkins+Docker+Git 的CI流程初探
在如今的互联网时代,随着软件开发复杂度的不断提高,软件开发和发布管理也越来越重要.目前已经形成一套标准的流程,最重要的组成部分就是持续集成(Continuous Integration,CI)及持续部 ...
- 从0到1体验Jenkins+Docker+Git+Registry实现CI自动化发布
一.前言 Jenkins是一款开源 CI&CD 软件,用于自动化各种任务,包括构建.测试和部署软件.Jenkins 支持各种运行方式,可通过系统包.Docker 或者通过一个独立的 Java ...
- Jenkins+Docker+Git+Registry
从0到1体验Jenkins+Docker+Git+Registry实现CI自动化发布 笔者:@拿着保温瓶的年轻人 目录: 一.前言 二.发布流程 三.环境准备 四.部署思路梳理 五.三台机器上操作 ...
- Jenkins+Docker+Git+Harbor流水线打包
Jenkins+Docker+Git+Harbor流水线打包 环境: CentOS Linux release 7.6.1810 (Core) 192.168.247.214 Jenkins+dock ...
- Jenkins+Docker+Git 自动化部署
Jenkins+Docker+Git 自动化部署图文教程 https://blog.csdn.net/qq_38252039/article/details/89791247 前言: 通过几天的学习和 ...
- Docker 搭建 etcd 集群配置
#关闭selinux.防火墙 systemctl stop firewalld.service systemctl disable firewalld.service firewall-cmd --s ...
- jenkins+docker+git+harbor构建及代码回滚(未完)
目录 一.部署 环境工作流程介绍 部署harbor 一.部署 前提环境说明 192.168.111.3 该机器为git本地仓库,及git远程仓库(git用户创建),及Harbor镜像仓库 192.16 ...
- jenkins+docker持续集成实验
在互联网时代,对于每一家公司,软件开发和发布的重要性不言而喻,目前已经形成一套标准的流程,最重要的组成部分就是持续集成(CI)及持续部署.交付(CD).本文基于Jenkins+Docker+Git实现 ...
- Jenkins 基于 Docker git JAVA CI/CD
准备两台机器 192.168.31.200 centos7 docker harbor git 192.168.31.201 centos7 docker jenkins maven git Ha ...
随机推荐
- ACM之路(16)—— 数位DP
题目就是kuangbin的数位DP. 先讲C题,不要62,差不多就是一个模板题.要注意的是按位来的话,光一个pos是不够的,还需要一维来记录当前位置是什么数字,这样才能防止同一个pos不同数字的dp值 ...
- layer是一款近年来备受青睐的web弹层组件
layer.closeAll(); //疯狂模式,关闭所有层 layer.closeAll('dialog'); //关闭信息框 layer.closeAll('page'); //关闭所有页面层 l ...
- 使用selenium IDE 等一系列需要下载的东西的地址
转载来自:http://blog.csdn.net/u012246342/article/details/53005730 selenium 官网 IDE 等一系列 下载地址:http://www.s ...
- 预处理、const、static与sizeof-为什么要引入内联函数
1:引入内联函数的主要目的是,用它替代C语言中表达形式的宏定义来解决程序中函数调用的效率问题.在C语言里可以使用如下的宏定义: #define ExpressionName(Var1,Var2) (V ...
- leetcode题目142.环形链表Ⅱ(中等)
题目描述: 给定一个链表,返回链表开始入环的第一个节点. 如果链表无环,则返回 null. 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始). 如果 p ...
- 将蓝牙rssi(信号强度)转换成距离
遇到一个问题,是将蓝牙rssi(信号强度)转换成距离的问题. 这一问题没有准确的解决办法,但是有人做过一个拟合回归函数,其变化规律比较类似于rssi的变化规律,函数如下: d = ^(abs(rssi ...
- 【批处理】ren命令_批量重命名文件
[ren命令] 说明:ren是“rename(重命名)”的简写: 命令:REN [Drive:][path] <old filename> <new filename> 解释: ...
- 3.创建一个pod应用
创建一个应用:k8s增删查改: pod创建:kubectl run nginx-deploy --image=nginx:1.14-alpine --port=80 --replicas=1 [roo ...
- 小D课堂 - 新版本微服务springcloud+Docker教程_5-01分布式核心知识之熔断、降级
笔记: 第五章 互联网架构服务降级熔断 Hystrix 实战 1.分布式核心知识之熔断.降级讲解 简介:系统负载过高,突发流量或者网络等各种异常情况介绍,常用的解决方案 1.熔断: ...
- java设计模式中的动态代理
Java的三种代理模式 1.代理模式 代理(Proxy)是一种设计模式,提供了对目标对象另外的访问方式;即通过代理对象访问目标对象.这样做的好处是:可以在目标对象实现的基础上,增强额外的功能操作,即扩 ...