前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >CentOS 7.4下部署GitLab+Jenkins持续集成环境

CentOS 7.4下部署GitLab+Jenkins持续集成环境

作者头像
星哥玩云
发布2022-07-14 09:31:56
2920
发布2022-07-14 09:31:56
举报
文章被收录于专栏:开源部署开源部署

GitLab介绍 GitLab 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的web服务。

系统环境准备

建议:内存4G以上不然带不动 [root@linuxidc-jenkins ~]# cat /etc/RedHat-release CentOS Linux release 7.4.1708 (Core) [root@linuxidc-jenkins ~]# uname -r 3.10.0-693.el7.x86_64

#关闭firewalld和NetWorkManager

[root@linuxidc-jenkins ~]# systemctl stop firewalld [root@linuxidc-jenkins ~]# systemctl stop NetWorkManager

#永久关闭 [root@linuxidc-jenkins ~]# systemctl disable firewalld [root@linuxidc-jenkins ~]# systemctl disable NetWorkManager

#关闭selinux [root@linuxidc-jenkins ~]# sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config [root@linuxidc-jenkins ~]# setenforce 0

#更换源和下载epel源 [root@linuxidc-jenkins ~]#mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup [root@linuxidc-jenkins ~]#wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo [root@linuxidc-jenkins ~]#wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo

#yum源更新,重启系统

[root@linuxidc-jenkins ~]# yum update && reboot

#安装相应工具 [root@linuxidc-jenkins ~]yum install curl policycoreutils openssh-server openssh-clients postfix -y [root@linuxidc-jenkins ~]systemctl start postfix

#新建GitLab源 [root@linuxidc-jenkins ~]# vim /etc/yum.repos.d/gitlab-ce.repo [gitlab-ce] name=gitlab-ce baseurl=http://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7 repo_gpgcheck=0 gpgcheck=0 enabled=1 gpgkey=https://packages.gitlab.com/gpg.key [root@linuxidc-jenkins ~]# yum makecache [root@linuxidc-jenkins ~]# yum install -y gitlab-ce

#安装git工具 [root@linuxidc-jenkins ~]# yum install git -y

#加载配置文件并启动,时间稍长 [root@linuxidc-jenkins ~]# gitlab-ctl reconfigure

#gitlab-ctl其他命令 启动:gitlib-ctl start 关闭:gitlab-ctl stop 重启:gitlab-ctl restart 重载配置:gitlab-ctl reconfigure 查看状态:gitlab-ctl status

#查看端口保证80端口不被占用 [root@linuxidc-jenkins ~]# lsof -i:80 COMMAND PID      USER  FD  TYPE DEVICE SIZE/OFF NODE NAME nginx  700      root    7u  IPv4  16903      0t0  TCP *:http (LISTEN) nginx  804 gitlab-www    7u  IPv4  16903      0t0  TCP *:http (LISTEN)

#gitlab配置文件路径 /etc/gitlab/gitlab.rb 

浏览器登录gitlab,输入http://ip进入下图:

入下图:

先输入密码,然后Register填写账户信息进入新建项目

填写ssh认证

]

测试拉取代码

[root@linuxidc-jenkins ~]# git clone git@linuxidc-jenkins:web/web-demo.git Cloning into 'web-demo'... remote: Counting objects: 6, done. remote: Compressing objects: 100% (3/3), done. remote: Total 6 (delta 0), reused 0 (delta 0) Receiving objects: 100% (6/6), done. [root@linuxidc-jenkins ~]# ls anaconda-ks.cfg  epel-release-latest-7.noarch.rpm  web-demo [root@linuxidc-jenkins ~]# ls web-demo/ index.html  README.md

上传代码

[root@linuxidc-jenkins web-demo]# echo "test" >>test.txt [root@linuxidc-jenkins web-demo]# git config --global user.email "you@example.com" [root@linuxidc-jenkins web-demo]# git config --global user.name "Your Name" [root@linuxidc-jenkins web-demo]# git add * [root@linuxidc-jenkins web-demo]# git commit -m "add test.txt" [master 5df66f7] add test.txt  1 file changed, 1 insertion(+)  create mode 100644 test.txt [root@linuxidc-jenkins web-demo]# git push warning: push.default is unset; its implicit value is changing in Git 2.0 from 'matching' to 'simple'. To squelch this message and maintain the current behavior after the default changes, use:   git config --global push.default matching To squelch this message and adopt the new behavior now, use:   git config --global push.default simple See 'git help config' and search for 'push.default' for further information. (the 'simple' mode was introduced in Git 1.7.11. Use the similar mode 'current' instead of 'simple' if you sometimes use older versions of Git) Counting objects: 4, done. Delta compression using up to 2 threads. Compressing objects: 100% (2/2), done. Writing objects: 100% (3/3), 314 bytes | 0 bytes/s, done. Total 3 (delta 0), reused 0 (delta 0) To git@linuxidc-jenkins:web/web-demo.git   18a57cf..5df66f7  master -> master

GitLab上查看:

#安装JenKins

[root@linuxidc-jenkins web-demo]# sudo wget -O /etc/yum.repos.d/jenkins.repo https://pkg.jenkins.io/redhat-stable/jenkins.repo [root@linuxidc-jenkins web-demo]# sudo rpm --import https://pkg.jenkins.io/redhat-stable/jenkins.io.key [root@linuxidc-jenkins web-demo]# yum install Java jenkins –y #JenKins默认端口为8080,因为gitlab已经占用我们需要更改。 [root@linuxidc-jenkins web-demo]# vim /etc/sysconfig/jenkins JENKINS_PORT="8080"  ---> JENKINS_PORT="8081"

#启动JenKins

[root@linuxidc-jenkins web-demo]# /etc/init.d/jenkins start Starting jenkins (via systemctl):                          [  OK  ]

#浏览器登录JenKins,地址:http://192.168.247.135:8081/

正在启动;

正在启动;

进入有个密码路径,系统上查看这个文件并把密码复制粘贴才能登录;

选择推荐安装;

创建一个管理员

开始使用jenkins

下面实现持续集成

进入主页--创建一个新任务

输入项目名称---构建一个自由风格的软件项目---确认

General--填写项目描述

源码管理--安装git插件--授权认证

ssh私钥认证我们在系统上查看粘贴进去即可。

Credentials—选择root

查看gitlab版本

[root@linuxidc-jenkins ~]# rpm -aq|grep gitlab

gitlab-ce-10.6.0-ce.0.el7.x86_64

点击立即构建

点击控制台输出查看

控制台输出,SUCCESS则构建成功

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
持续集成
CODING 持续集成(CODING Continuous Integration,CODING-CI)全面兼容 Jenkins 的持续集成服务,支持 Java、Python、NodeJS 等所有主流语言,并且支持 Docker 镜像的构建。图形化编排,高配集群多 Job 并行构建全面提速您的构建任务。支持主流的 Git 代码仓库,包括 CODING 代码托管、GitHub、GitLab 等。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档