git服务器gitlab之搭建和使用--灰常好的git服务器【转】

转自:http://blog.csdn.net/zy416548283/article/details/38057925

git服务器比较有名的是gitosis和gitolite,这两个管理和使用起来稍微有些复杂,没有web页面,而gitlab则是类似于github的一个工具,github无法免费建立私有仓库,并且为了代码安全,于是在内网安装了一个自己实验室的一个git服务器,多方比较,选择了gitlab,gitlab有很多依赖,而bitnami制作了一键安装的包,下载链接:https://bitnami.com/redirect/to/37478/bitnami-gitlab-7.0.0-0-linux-installer.run ,使得安装如此简洁。

 

1.  安装的过程中,会设置一个管理员账户,这个可以用来登陆,并且,gitlab的成员不能自己随便申请,需要管理员进行邀请;

2.  设置ssh,参见help:

(1)查看自己之前是否生成过ssh密钥:

[plain] view plain copy

 
 

  1. cat ~/.ssh/id_rsa.pub  

如果出现一段ssh-rsa开头的,表示已经生成了,可以跳过此步骤;

 

(2)如果之前没有生成ssh密钥,使用命令:

[plain] view plain copy

 
 

  1. ssh-keygen -t rsa -C "zy901002@gmail.com"  

来生成密钥。其中生成的文件,id_rsa为自己电脑上的私钥,id_rsa.pub为放在服务器上验证的公钥。

 

(3)将ssh的公钥放到gitlab上面,页面如下所示:

点击添加ssh key即可;

3. 工作流程,还是看gitlab的帮助文档,如下所示:

翻译一下。。。

(1) 克隆管理员建立好的项目:

 

[plain] view plain copy

 
 

  1. git clone git@example.com:project-name.git  

 

(2)创建自己的本地分支(分支的命名采用小驼峰式命名法,使用自己的名字+功能,比如zyHighway,不要使用特殊字符):

 

[plain] view plain copy

 
 

  1. git checkout -b $feature_name  

(3)写代码,将写好的代码提交到本地分支中:

 

 

[plain] view plain copy

 
 

  1. git commit -am "My feature is ready"  

(4)把分支push到Gitlab服务器上:

 

 

[plain] view plain copy

 
 

  1. git push origin $feature_name  

(5)在Gitlab的提交页面,查看自己提交的代码;

 

(6)提交一个合并请求;

(7)管理员审核代码,决定是否合并代码到主分支上。

 

4. 分支模型

master分支中,保留足够稳定的代码,即已经发布或者即将发布的代码; develop分支,用于后续开发,一旦通过稳定性测试,就合并到master分支中;在develop分支的基础上,产生各个模块分支,模块功能实现之后,合并到develop分支上,测试稳定之后,再合并到master分支中。

 

5. 情景模拟

(1)管理员zhaoyu,新建一个项目vanet,并邀请huqiong加入,角色为开发者:

(2)成员zhaoyu克隆项目,写了一份代码,并将写好的代码上传至服务器的zhaoyuHighway分支上:

去提交页面,发现已经建立了一个新的分支,并且可以向管理员提交合并请求,管理员关联的邮箱会受到对应的邮件:

浏览一下提交的代码:

 

目前就到这里,后期还会继续更新。

 

附:

1. 服务器怎么关闭和启动gitlab服务器,并设为开机启动项:

在安装的目录下有个文件:ctlscript.sh,通过./ctlscript.sh start可以启动,具体在README文件中。

更改文件权限:chown git:git ctlscript.sh 

添加对应命令到启动文件:/etc/rc.local中:./opt/gitlab-7.0.0-0/ctlscript.sh start

2. 修改git@domain_name中的domain_name

在安装时,需要设定domain_name, 我这里设置成我的公网的ip,如果没有设置好的话,可以参考帖子:点击打开链接 ,修改文件:

 

[plain] view plain copy

 
 

  1. /home/git/gitlab/apps/gitlab/htdocs/config/gitlab.yml  

将两处的host,修改成外网ip即可。

 

3. thinkserver安装红帽系统

采用thinkserver RD340来搭建服务器,支持的操作系统有红帽。 安装系统先用自带光盘引导/分区,再用系统光盘进行安装,安装好之后,重启会出现光标,注意这里仍然需要插入安装光盘,此时还没有完成安装。

在红帽上安装好系统之后,gitlab的访问速度非常慢,后来发现是网卡的问题,把网线重新插拔就好来。

时区设定,在地理位置那一栏一直找不到亚洲/上海,就把地理位置删除来,自己设定时间,这样在网页上显示的一些时间就不会出错来。

4. 数据迁移(ubuntu的7.1gitlab迁移到redhat的7.8)

待写

5. 关于7.8.1的自由注册

配置一下邮箱,就可以自动注册了,但是这样不便于团队的保密工作,还是采用邀请的方式来注册。

6. 将原来仓库的代码上传到新的服务器上,包括commit的记录等log:

 

[plain] view plain copy

 
 

  1. zy@zy:~/longmenshan/longmenshan$ git push -u origin master  
  2. @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@  
  3. @    WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!     @  
  4. @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@  
  5. IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING NASTY!  
  6. Someone could be eavesdropping on you right now (man-in-the-middle attack)!  
  7. It is also possible that a host key has just been changed.  
  8. The fingerprint for the RSA key sent by the remote host is  
  9. f9:46:83:46:cd:62:60:56:bb:df:19:c0:47:8d:b0:be.  
  10. Please contact your system administrator.  
  11. Add correct host key in /home/zy/.ssh/known_hosts to get rid of this message.  
  12. Offending ECDSA key in /home/zy/.ssh/known_hosts:2  
  13.   remove with: ssh-keygen -f "/home/zy/.ssh/known_hosts" -R 222.197.180.140  
  14. RSA host key for 222.197.180.140 has changed and you have requested strict checking.  
  15. Host key verification failed.  
  16. fatal: Could not read from remote repository.  

参考帖子:点击打开链接 将之前的known_hosts中的记录删掉即可。

 

 

参考:

1. gitlab多人协同工作:http://herry2013git.blog.163.com/blog/static/219568011201341111240751,原作者还制作了视频教程,是不错的参考资料;

2. 《pro Git中文版》,熟悉git常用操作和基本原理;

3.《Git 权威指南》,深入学习Git

时间: 2024-09-25 19:19:04

git服务器gitlab之搭建和使用--灰常好的git服务器【转】的相关文章

Git远程10:搭建私有GitLab

上一篇博文介绍了搭建私有的Git Server.此方式适合小型团队使用,而且项目最好比较单一.如果是人数较多的团队,工程比较多,日常的维护工作量会很大.GitHub和GitLab很好用,但GitHub只能提供Public机制的库.GitLab可以提供Private机制的库,但其速度实在是太慢了.最好的方法是在团队服务器上搭建类似的服务,安全性和服务均可保障,本文介绍如何搭建GitLab服务. 环境和准备工作 操作系统:CentOS6.6 IP地址:192.168.80.6 建立git用户. 12

docker中建立私有git服务器[gitlab]

现在使用git的很普遍,在开发内部如何建立个git服务器,本文以gitlab为例,让你分分钟就可以搭好一个环境[docker的威力非同一般] 首先在docker.com找到gitlab的下载源和信息,如下: https://registry.hub.docker.com/u/sameersbn/gitlab/ 根据页面说明,我们选择一键式的处理,如下: wget https://raw.githubusercontent.com/sameersbn/docker-gitlab/master/do

Git和Gitlab协同工作

1.概述 在写这篇博客之前,为了更好的描述整个流程,本人亲自尝试了:从搭建到使用,下面就围绕这个流程来阐述整个过程,目录结构如下所示: Git的安装搭建 Git的常规操作 Gitlab的搭建 Gitlab的使用 下面我们开始整个流程. 2.Git篇 其实,作为开发人员,Git的使用是必备的技能,也许我们都很熟悉如何使用Git,对Git的常用命令也了如指掌:但是对Git服务器的搭建也许我们并不太在意,因为这些事情自从我们进入公司,运维人员就已经帮我们做好来,我们只需要知道如何去使用(拉去代码,提交

Windows搭建ngrok服务器、Linux搭建ngrok服务器、支持用户管理

                           Windows搭建ngrok服务器.Linux搭建ngrok服务器.支持用户管理 阿里云双11领代金券啦 https://m.aliyun.com/act/activity2017h5?userCode=vc31fdqr&utm_source=vc31fdqr           微信公众号.支付宝支付等开发要求有公网(外网)服务器.每次调试时,上传代码到服务器很不方便.ngrok很好的解决了这一问题.网上的文章大多是讲实通过阿里怎么在Lin

Git学习-->GitLab如何修改时区?

一.背景 今天有同事在GitLab上查看时间的时候,发现GitLab上显示的时间和提交的时间不一致. 本地时间现在为:2017-11-28 11:43 查看本地代码提交的时间为:2017-11-28 11:23 本地时间现在为:2017-11-28 11:43,查看本地代码提交的时间为:2017-11-28 10:23,确实是一个小时之前,但是在GitLab平台上显示的世界为2017-11-28 02:23. 正好相差八个小时,因此我怀疑是GitLab服务器的时区我没有进行设置导致的.下面我就将

阿里云服务器LAMP环境搭建及Let’s Encrypt数字证书配置

阿里云服务器LAMP环境搭建及Let's Encrypt数字证书配置 云主机供应商:阿里云服务器ESC 云数据库供应商:阿里云RDS 服务器系统:Ubuntu 16.04 64位 服务器登录软件:WinSCP 服务器管理终端(SSH):Xshell 5(此工具可以复制.粘贴需要的代码) 因使用了阿里云便于管理数据的云数据库,本实例仅仅安装Apache.PHP. 1.通过SSH终端登录服务器并安装Apache $ sudo apt-get update(更新系统安装源) $ sudo apt-ge

开发一个类似与新浪微博的app服务器应该如何搭建?

问题描述 开发一个类似与新浪微博的app服务器应该如何搭建? 学生党开发一个类似于新浪微博的app,我不知道服务器应该用什么如何搭建(就是一个简单点的服务器),还望大神们指点迷津. 解决方案 如果说简单,就是写一个后台http服务,客户端通过http访问,你返回json 解决方案二: 你可以试试Bmob云存储,然后用JavaScript写云端代码就好了

Win2008下搭建php开发环境(IIS FastCGI版)_win服务器

注意所用到软件的版本,不同的版本会有不少差别,有可能最后会搭建不成功,而且各位童鞋也不用担心小狼所用版本会不会太老,因为这里所用的软件不是比较新的就是比较稳定的版本,完全可以满足大家的需要了,那就先看看要用到什么软件吧: 操作系统:Windows Server 2008(下文为了方便,用WS2008代替,经测试,此方法在win7下也有效) 服务器:IIS7.0或更新版本 1.mysql-essential-5.1.56-win32.msi:http://dev.mysql.com/downloa

RHE5服务器管理之搭建FTP服务器步骤分享[图]_FTP服务器

一.FTP工作原理    在一个FTP会话中,存在两个独立的网络连接:控制连接和数据连接.通常情况下,FTP服务器监听端口号21,等待控制连接建立请求.当FTP控制连接建立之后,即可开始传输文件,传输文件的连接称为FTP"FTP数据连接".FTP数据连接即FTP传输数据的过程,它有3种传输模式,即主动传输模式(PORT).被动传输模式(PASSIVE,简称PASV).单端口模式.     主动传输模式:当FTP控制连接建立,客户端提出目录列表及传输文件时,客户端发出PORT命令与服务器