由于前面有篇文章是gitlab的源码编译,如果是讲究效率和简单的话可以rpm安装gitlab。下面就对我近期对gitlab使用做一下简单的记录。

要求:需要个干净的系统


一、安装必要的依赖


sudo yum install openssh-server


sudo yum install postfix


sudo yum install cronie


sudo service postfix start


sudo chkconfig postfix on


sudo lokkit -s http -s ssh(这句是做防火墙的,其实深的我也不懂。)


二、下载Omnibus package包并安装


(1)curl -O https://downloads-packages.s3.amazonaws.com/centos-6.6/gitlab-7.9.2_omnibus-1.el6.x86_64.rpm

sudo rpm -i gitlab-7.9.2_omnibus-1.el6.x86_64.rpm

然后执行:gitlab-ctl reconfig (重新编译)

其实到此你的gitlab就已经能够访问了。下面就是对于你的需求进行简单的修改配置而已。

username:root

password: 5iveL!fe


三、修改配置


当我在测试发送邮件时:echo “this is test email”|mail -s  “test email” xxxxxx@xx.com

发现来自于name@gitlab.example.com 这名字显然不是我们想要的。要不改成自己的域名,要不改成自己的IP。


根据我的配置:

想修改域名:vim /var/opt/gitlab/gitlab-rails/etc/gitlab.yml

 (1)host (2)email_from 两项

是先要停掉gitlab服务。

去修改配置文件保存后

再启动gitlab服务。

完活

你的配置就得到修改了。


有的人说修改/etc/gitlab/gitlab.rb,但是我没有试。

可以通过查看日志: tail -f /var/log/maillog 看邮件试发情况。


四、gitlab客户端使用


1、创建user


(1)名字

(2)username

(3)邮箱

(4)密码(如果你的邮箱没有问题的话,可以提示用户自己修改密码。如果你的邮件被阻拦的话。日志里会提示发送超时,原因大概是是因为你的postfix服务没有注册,不能一直发送邮件。可以点击用户后的exit(编辑)来给用户重置密码。)

其他的都是可以自己去摸索。以上的是创建用户必须去给赋值的。


2、验证登陆

。。。。。。。。此处省略。

3、安装客户端(windows)

(1)需要安装的有git和TortoiseGit

我选择的都是默认的。

安装完成后。

(2)用户登陆

首先就是要生成密钥:

在git-bash:

可以事先看下:git config --list

确定gitlab的本地用户

git config --global user.name "username"

git config --global user.email "your_email_address"


ssh-keygen -t rsa -C your_email_address


去你的本地用户目录下着.ssh目录 下应该会有两个文件(id_rsa id_rsa.pub)。

你需要打开公钥文件把该文件里的内容复制到 在网页登陆gitlab里ssh keys里的

点击Add ssh key

 标题可以随便。把上边都内容复制到下面即可。

 

 验证:ssh -T git@your_gitlabserver

 

如果出现:Welcom to Gitlab,yourname!

说明认证成功!

4、仓库使用

1)创建本地仓库

创建文件夹

git bash:

cd C:

mkdir -p www/testgit/

cd www/testgit


git init(初始化:通过命令 git init 把这个目录变成git可以管理的仓库,如下)

(2)把文件添加到版本库

vim test.txt

11111

 第一步:使用命令 git add test.txt添加到暂存区里面去。

  :git add  test.txt

 没有任何提示,说明已经添加成功了。


git add file

当出现:类似warning: LF will be replaced by CRLF

按照下面的步骤进行操作

首先:rm -rf  .git

git init

git config --global core.autocrlf false

再将文件加载到内存中即可。

  

第二步:用命令 git commit告诉Git,把文件提交到仓库。

 : git commit -m "提示"

如果显示“提示”就说明执行成功。

    第三步:现在我们已经提交了一个readme.txt文件了,我们下面可以通过命令git status来查看是否还有文件未提交,如下:

:git status

nothing to commit。。。
说明执行成功。。
剩下的就是你可以去你的本地文件夹内有个test.txt文件说明本地库创建成功、

理解工作区与暂存区的区别?
     工作区:就是你在电脑上看到的目录,比如目录下testgit里的文件(.git隐藏目录版本库除外)。或者以后需要再新建的目录文件等等都属于工作区范畴。
    版本库(Repository):工作区有一个隐藏目录.git,这个不属于工作区,这是版本库。其中版本库里面存了很多东西,其中最重要的就是stage(暂存区),还有Git为我们自动创建了第一个分支master,以及指向master的一个指针HEAD。
我们前面说过使用Git提交文件到版本库有两步:
  第一步:是使用 git add 把文件添加进去,实际上就是把文件添加到暂存区。
  第二步:使用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支上。

5、上传远程库

 现在的情景是:我们已经在本地创建了一个Git仓库后,又想在github创建一个Git仓库,并且希望这两个仓库进行远程同步,这样github的仓库可以作为备份,又可以其他人通过该仓库来协作。
 (1)首先登陆网页gitlab创建个项目:
 因为我们是通过ssh认证的所有选择ssh :
 例如:git@192.168.10.186Z:/username/test-git.git 作为远程目录。
 此处的test-git是你刚创建的目录名字。
 (2)
 于是在本地仓库执行:
 git remote add origin git@192.168.10.186Z:/username/test-git.git 
 此时就确定了你的远程目录以及以后默认就是传到该项目下。
 git push -u  origin master
 由于远程库是空的,我们第一次推送master分支时,加上了 –u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。推送成功后,可以立刻在github页面中看到远程库的内容已经和本地一模一样了

从现在起,只要本地作了提交,就可以通过如下命令:git push origin master你可以去网页版查看多和本地仓库的内容一样了。。。你可以在网页上创建个project(test2-git):git clone git@192.168.10.186:/username/test2-git.git稍等你本地仓库就会有你刚创建的项目了。。。有可能有很多不足之处。。希望大家多多指正。这仅仅是我自己做实验遇到的一些问题。参考文档:          安装gitlab:http://segmentfault.com/a/1190000002722631                    安装客户端:http://blog.jobbole.com/78960/