使用gitlab, jenkins搭建CI(持续集成)系统(1) -- 准备环境
1. 环境设计
搭建一个从开发到测试知道发布上线可以自动换完成的CI系统。这个系统中包含4个环境。
开发(dev)环境: 码农使用。
测试(test)环境: 测试人员使用。
预发布(prepublish)环境: 预发布环境,用于上线前的最后验证。
正式(realpublish)环境: 正式上线运行环境
我期望的效果是这样的:
代码推送到master分支,自动构建、部署到dev
代码推送到test分支, 自动构建、部署到test
test上测试通过后,在jenkins中手动触发relase分支构建, jenkins自动将test分支代码合并到release上, 然后构建、部署到prepublish
prepublish验证通过后,在jenkins中手动触发publish构建,使用release分支代码, 构建、部署到publish
以上步骤中,在不同的环境中自动使用不同的配置。
2. 环境准备
操作系统:centos7
用虚拟机虚拟出5个主机:
192.168.1.35: gitlab
192.168.1.36: jenkins
192.168.1.41: dev环境
192.168.1.42: test环境
192.168.1.43, 192.168.1.44 prepublish 环境
192.168.1.45,192.168.1.46 realpublish环境
2.1 安装gitlab, 创建实验用的project
在192.168.1.35上安装gitlab, 这个主机需要配置至少4G内存,否则gitlab会很慢。
具体安装过程参考:https://about.gitlab.com/installation/#centos-7
第一步:
curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.rpm.sh | sudo bash
第二步:
sudo EXTERNAL_URL="http://192.168.1.35" yum install -y gitlab-ce
完成之后gitlab将会在192.168.1.35 提供服务
打开浏览器输入: http://1192.168.1.35
第一次进入初始化root账号
创建一个用于创建project的账号
至此,gitlab环境就准备好了。
2.2 安装配置jenkins
在192.168.1.36上运行jenkins
安装jdk8
下载jenkins: http://mirrors.jenkins.io/war-stable/latest/jenkins.war
将jenkins.war放在 /root/jenkins中
启动jenkins
cd /root/jenkins
./java -jar jenkins.war --httpPort=80
打开浏览器输入192.168.1.36登录jenkins。第一次进入会要求安装默认的plugin, 安装完成之后, 创建一个管理员账号,然后用这个管理账号重新登录。
系统管理 - 管理插件 - 可选插件 选择gitlab相关插件进行安装:
GitLab Plugin
Gitlab Hook Plugin
创建一个用于实验的project: example-springbootmvc。 我在github上有这个用于实验的project: https://github.com/brandonlyg/examples-springbootmvc.git。可以clone下来,导入到gitlab中。使这个project在gitlab中个url是 git@192.168.1.35:examples/example-springbootmvc.git
2.4 让jenkins所在的主机可以免密码登录到其他的主机上
生成ssh key
ssh-keygen
将公钥copy目标主机上,然后ssh登录异常
ssh-copy-id root@192.168.1.41
ssh root@192.168.1.41
重复这两个步骤,配置好42, 43, 44, 45, 46这几个主机。
使用gitlab, jenkins搭建CI(持续集成)系统(1) -- 准备环境的更多相关文章
- Jenkins的CI持续集成
Jenkins的CI持续集成 全局配置 系统管理->全局工具配置,配置Git,JDK和Maven 1)解压maven到当前目录 tar zxf apache-maven-3.5.4-bin.ta ...
- 基于jenkins搭建一个持续集成服务器
1 引言 1.1 编写目的 指导质量管理部,业务测试组同事进行Jenkins环境部署,通过Jenkins解决测试环境不可控,开发测试环境不一致等问题. 1.2 使用对象 质量管理部.基础研发部,集成部 ...
- docker + gitlab + jenkins 搭建 CI/CD 系统
gitlab+jenkins+docker 计算机网络大全
- 使用gitlab, jenkins搭建CI(持续集成)系统(3) -- 根据不同触发条件执行不同的构建任务
前面在jenkins中安装的gitlab hook支持不同的参数,具体可以参考gitlab hook文档https://github.com/jenkinsci/gitlab-hook-plugin# ...
- 使用gitlab, jenkins搭建CI(持续集成)系统(2) -- 配置webhook触发构建
1. 在gitlab上配置192.168.1.30的ssh秘钥,使jenkins可以操作gitlab上的project 进入gitlab,点击右上角 点击 Settings -> SSH key ...
- 使用gitlab, jenkins搭建CI(持续集成)系统(4) 灰度发布publish
publish环境是正式环境,和dev, test, prepublish环境不同的是,正式环境一般要更加谨慎一些,发布的时候需要有一个灰度过程,即:分多次部署,每次部署几个服务器节点,验证没有问题以 ...
- [原创]CI持续集成系统环境---部署gerrit环境完整记录
开发同事提议在线上部署一套gerrit代码审核环境,不用多说,下面就是自己部署gerrit的操作记录. 提前安装好java环境,mysql环境,nginx环境 测试系统:centos6.5 下载下面三 ...
- [原创]CI持续集成系统环境--Gitlab+Gerrit+Jenkins完整对接
近年来,由于开源项目.社区的活跃热度大增,进而引来持续集成(CI)系统的诞生,也越发的听到更多的人在说协同开发.敏捷开发.迭代开发.持续集成和单元测试这些拉风的术语.然而,大都是仅仅听到在说而已,国内 ...
- CI持续集成系统环境--Gitlab+Gerrit+Jenkins完整对接
原文地址https://www.cnblogs.com/kevingrace/p/5651447.html 近年来,由于开源项目.社区的活跃热度大增,进而引来持续集成(CI)系统的诞生,也越发的听到更 ...
随机推荐
- 蚂蚁男孩.缓存组件(Framework.Mayiboy.Caching)
它能做什么? 主要是用来方便使用缓存而诞生,该组件封装了RunTimeCache.Memcached.Redis的使用,通过简单配置就能高效快速使用起来. 使用说明 一. 下载源码,自己手动编译 ...
- C#线程运用基础
ThreadStart ts=new ThreadStart(a.f);//ThreadStart 是一个委托,用以关联a.f方法Thread th=new Thread (ts);//Thread是 ...
- JavaScript正则表达式匹配中英文以及常用标点符号白名单写法
我们在编程中经常会遇到特殊字符过滤的问题,今天我们提供一种白名单方式过滤 直接上代码 function RegEXP(s) { var rs = ""; for (var i = ...
- Office - Outlook
将邮件存到本地 服务器容量有限,避免丢失和经常提示容量不足 步骤 在File->Account Settings->Account Settings下面 在Data Files标签页新建一 ...
- 【cocos2d-x 手游研发----地图活起来了】
谈到地图不少人都说要做地图编辑器了,但是我暂时绕过这一步,如果不用寻路地图就不能移动?寻路就是会绕过障碍物的算法. 我做了一个简单的地图的思想,就是地图分层3层:背景层.可行区域层.遮罩层,但是地图就 ...
- Java中的split和join
Javascript中的用于字符串和数组之间转换的split和join函数使用起来非常方便,在Java中也有这两个函数,只不过join是在apache commons的lang库里实现的. impor ...
- ovs-vsctl 命令详解
Open vSwitch中有多个命令,分别有不同的作用,大致如下: ovs-vsctl用于控制ovs db ovs-ofctl用于管理OpenFlow switch 的 flow ovs-dpctl用 ...
- Django(出版社功能)
day62 day62 2018-05-02 1. 内容回顾 Django 1. 安装 1. Django版本 1.11.xx ...
- hdoj1045 Fire Net(二分图最大匹配)
题意:给出一个图,其中有 . 和 X 两种,. 为通路,X表示墙,在其中放炸弹,然后炸弹不能穿过墙,问你最多在图中可以放多少个炸弹? 这个题建图有点复杂orz. 建图,首先把每一行中的可以放一个炸弹的 ...
- 为什么子元素设置margin-top会作用在父元素上?
原因在于:CSS 外边距合并 复现: <!DOCTYPE html> <html lang="en"> <head> <meta char ...