Jenkins+git+gitlab实现持续自动集成部署
1 实验环境
三台服务器
gitlab 192.168.7.139
Jenkins 192.168.7.140
java 192.168.7.141
[root@jenkins ~]# cat /etc/redhat-release
CentOS Linux release 7.3.1611 (Core)
[root@jenkins ~]# uname -a
Linux jenkins 3.10.0-862.6.3.el7.x86_64 #1 SMP Tue Jun 26 16:32:21 UTC 2018 x86_64 x86_64 x86_64 GNU/Linux
2 centos7 搭建gitlab服务器
安装gitlab的依赖包
yum install curl openssh-server openssh-clients postfix cronie policycoreutils-python -y
yum install -y patch
gitlab下载地址
https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7
下载安装包
wget https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7/gitlab-ce-10.0.3-ce.0.el7.x86_64.rpm
RPM安装
rpm -ivh gitlab-ce-10.0.3-ce.0.el7.x86_64.rpm
出现以下界面说明安装成功
修改gitlab的配置文件 /etc/gitlab/gitlab.rb
第13行 修改为自己搭建的gitlab的主机名称或者ip地址
原 external_url 'http://gitlab.example.com'
修改后 external_url 'http://192.168.7.139'
退出保存后需要重新加载配置文件 使之生效 需要等待几分钟
gitlab-ctl reconfigure
软件部分安装完毕 下面就是web页面配置部分
gitlab的默认端口是80
使用浏览器 访问一下地址 http://192.168.7.139
进入下面界面 用户在界面上填入新的密码 该密码是管理员的密码 (密码要求至少8位) 密码 123456 默认管理员是root
进入gitlab的界面
安装gitlab的汉化包
需要在主机上安装git
yum install git -y
查看git的版本
git --version
git version 1.8.3.1
下载gitlab的汉化包
git clone https://gitlab.com/xhang/gitlab.git
当前下载的汉化包为10.0.4 但是安装的gitlab的版本是10.0.3
停止gitlab服务
gitlab-ctl stop
切换到刚才从gitlab上download的汉化包目录
cd /home/soft/gitlab
找出安装的 10.0.3 版本和 汉化版本10.0.4 中的不同点
git diff v10.0.3 v10.0.4-zh > ../10.0.3-zh.diff
进入到上一级目录
将 10.0.3-zh.diff 的补丁添加到 gitlab 中
patch -d /opt/gitlab/embedded/service/gitlab-rails -p1 < 10.0.3-zh.diff
执行完命令后 按回车 再按y
重新加载配置文件
gitlab-ctl reconfigure
重新启动gitlab服务
gitlab-ctl start
出现下面的界面 说明启动成功
[root@gitlab softwares]# gitlab-ctl restart
ok: run: gitaly: (pid 17834) 1s
ok: run: gitlab-monitor: (pid 17849) 0s
ok: run: gitlab-workhorse: (pid 17853) 1s
ok: run: logrotate: (pid 17895) 0s
ok: run: nginx: (pid 17902) 1s
ok: run: node-exporter: (pid 17908) 0s
ok: run: postgres-exporter: (pid 17918) 0s
ok: run: postgresql: (pid 17925) 0s
ok: run: prometheus: (pid 17935) 1s
ok: run: redis: (pid 17944) 0s
ok: run: redis-exporter: (pid 17948) 1s
ok: run: sidekiq: (pid 17959) 1s
ok: run: unicorn: (pid 17968) 0s
配置gitlab 用户注册时的邮箱通知信息
修改 /etc/gitlab/gitlab.rb 配置文件,该邮箱地址是未来gitlab 向用户发送邮件时的推送邮箱
425 gitlab_rails['smtp_enable'] = true
426 gitlab_rails['smtp_address'] = "smtp.qq.com" # 用户输入自己的smtp服务器地址,例如作者的时163 的企业服务地址
427 gitlab_rails['smtp_port'] = 25 # 用户smtp 的端口号
428 gitlab_rails['smtp_user_name'] = "***@qq.com" # 用户的邮箱地址
429 gitlab_rails['smtp_password'] = "PASSWORD" # 用户的邮箱密码
430 gitlab_rails['smtp_domain'] = "qq.com" # 用户邮箱的域名
431 gitlab_rails['smtp_authentication'] = "login"
432 gitlab_rails['smtp_enable_starttls_auto'] = true
433 gitlab_rails['smtp_tls'] = false
44 gitlab_rails['gitlab_email_from'] = '***@qq.com' # 用户的邮箱地址
566 user['git_user_email'] = "***@qq.com" # 用户的邮箱地址
重新加载gitlab配置文件
gitlab-ctl reconfigure
在重新加载后,可以通过以下命令查看刚才修改的内容是否生效
gitlab-ctl show-config | grep smtp_password
管理员还需要在web的管理页面上修改对应的配置,管理员的配置页面可以点击以下按钮
如果管理员需要手动添加新用户可以在如下界面操作
=======================================================
上传git客户端的公钥到gitlab服务器上
开始在gitlab上创建项目
在Git客户端上进行操作
git config --global user.name "root"
git config --global user.email "***@com.cn"
git clone http://192.168.7.140/root/xapi.git
cd xapi/
touch README.md
git add README.md
git commit -m "add README"
git push -u origin master
===========================================================
jenkins的安装部署使用
yum安装Jenkins
wget -O /etc/yum.repos.d/jenkins.repo https://pkg.jenkins.io/redhat/jenkins.repo
rpm --import https://pkg.jenkins.io/redhat/jenkins.io.key
yum install jenkins
systemctl status jenkins
systemctl enable jenkins
systemctl start jenkins
通过浏览器登录到Jenkins的管理界面 http://192.168.7.139:8080/
下面开始使用Jenkins
登录
Jenkins+git+gitlab实现持续自动集成部署的更多相关文章
- Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署动态网站(二)--技术流ken
项目前言 在上一篇博客<Jenkins+Git+Gitlab+Ansible实现持续化集成一键部署静态网站(一)--技术流ken>中已经详细讲解了如何使用这四个工具来持续集成自动化部署一个 ...
- Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署静态网站(一)--技术流ken
前言 在之前已经写了关于Git,Gitlab以及Ansible的两篇博客<Git+Gitlab+Ansible剧本实现一键部署Nginx--技术流ken>,<Git+Gitlab+A ...
- Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署静态网站(一)
在之前已经写了关于Git,Gitlab以及Ansible的两篇博客<Git+Gitlab+Ansible剧本实现一键部署Nginx--技术流ken>,<Git+Gitlab+Ansi ...
- Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署动态网站(7)
项目前言 在上一篇博客<Jenkins+Git+Gitlab+Ansible实现持续化集成一键部署静态网站(一)–技术流ken>中已经详细讲解了如何使用这四个工具来持续集成自动化部署一个静 ...
- Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署静态网站(6)
前言 在之前已经写了关于Git,Gitlab以及Ansible的两篇博客<Git+Gitlab+Ansible剧本实现一键部署Nginx–技术流ken>,<Git+Gitlab+An ...
- Docker+GitLab+Jenkins+kubernetes实现DevOps 持续化集成和持续化部署概念图
Docker+GitLab+Jenkins+kubernetes实现DevOps 持续化集成和持续化部署概念图 转载自:原创 IT综合 作者:百联达 时间:2017-05-09 15:48:08 41 ...
- Git+Gitlab+Ansible剧本实现一键部署动态网站(二)--技术流ken
项目前言 之前已经写了一篇关于git和ansible的博客<Git+Gitlab+Ansible剧本实现一键部署Nginx--技术流ken>.关于git,gitliab,ansible在我 ...
- Git+Gitlab+Ansible剧本实现一键部署动态网站(5)
项目前言 之前已经写了一篇关于git和ansible的博客<Git+Gitlab+Ansible剧本实现一键部署Nginx–技术流ken>.关于git,gitliab,ansible在我以 ...
- jenkins+git+gitlab+ansible实现持续集成自动化部署
一.环境配置 192.168.42.8部署gitlab,节点一 192.168.42.9部署git,Jenkins,ansible服务器 192.168.42.10节点二 二.操作演示 ①gitlab ...
随机推荐
- PL/SQL基础语法入门
先前安装了PL/SQL软件 PL/SQL全称为Procedural Language/SQL. PL/SQL也是一种程序语言,叫做过程化SQL语言,是Oracle数据库对SQL语句的扩展 打PL/SQ ...
- Django中的模板渲染是什么
首先建立一个页面 在views.py中增加一个方法 配置URL 如何实现的呢 这就是渲染,传递的数据不同显示的数据也不同.Django里的渲染引擎和Jinja的虽然不同但是语法基本通用.现在明白什么叫 ...
- Asp.Net SignalR Hub中的上下文对象
Hub中的 Context 使用了集线器后,会发现对比持久连接类少了OnConnectioned这样的事件,事实上是有的.需要我们去override .这下似乎发现了什么问题,记得持久连接类中有con ...
- 三种方法实现CSS三栏布局
本文由云+社区发表 作者:前端林子 本文会分别介绍三种CSS实现三栏布局的方法,可在浏览器中打开查看效果 1.方法一:自身浮动的方法 实现方法:需要左栏向左浮动,右栏向右浮动,中间设左右margin来 ...
- 权限管理系统之项目框架搭建并集成日志、mybatis和分页
前一篇博客中使用LayUI实现了列表页面和编辑页面的显示交互,但列表页面table渲染的数据是固定数据,本篇博客主要是将固定数据变成数据库数据. 一.项目框架 首先要解决的是项目框架问题,搭建什么样的 ...
- Linux 桌面双击运行脚本
创建桌面文件 touch myapp.desktop 编辑此文件写入一下内容 [Desktop Entry] Name = myapp Exec = /usr/bin/xxxx/xxx.sh Icon ...
- 如何用java控制你的电脑?
用java控制你的电脑 java,是一门强大的语言,强大的地方在于有很多类,我们可以直接的使用.而java.awt.Robot就很有意思了,顾名思义robot机器人,怎样一个机器法,如:控制鼠标方法: ...
- 廖雪峰老师博客学习《通过生成器generator生成列表式杨辉三角》
说明:这是我接触生成器概念后,自己对它的理解,可能比较表面,没深入理解,也可能有错误.后续校正错误认知,将有关generator作为一个tag了! 希望以后能活用. 先贴出自己写的triangles( ...
- iview-admin框架运行步骤
第一步: 前往github下载整个iview-admin框架的全部源码 github地址: https://github.com/iview/iview-admin 第二步: 点击Clone or d ...
- 页面内容不够高footer始终位于页面的最底部
相信很多前端工程师在开发页面时会遇到这个情况:当整个页面高度不足以占满显示屏一屏,页脚不是在页面最底部,用户视觉上会有点不好看,想让页脚始终在页面最底部,我们可能会想到用: 1.min-height来 ...