1.Git仓库管理

  现在本地已经创建了git仓库,又在gitlab上创建了一个git仓库,并且让这两个仓库进行远程同步,这样gitlab仓库既可以备份也可以与他人协作管理远程仓库以及根据需要推送或拉取数据。 
  管理远程仓库包括了如何添加远程仓库、移除无用远程仓库、查看远程仓库、修改远程仓库等。

1.1部署开源仓库

GitLab 是一个用于仓库管理系统的开源项目。

1.安装配置gitlab依赖项 
如想使用Postfix来发送邮件,在安装期间请选择'Internet Site'. 您也可以用sendmai或者 配置SMTP服务并使用SMTP发送邮件.在 Centos7系统上, 下面的命令将在系统防火墙里面开放HTTP和SSH端口.

  1. [root@git-node1 ~]# yum install curl openssh-server postfix
  2. [root@git-node1 ~]# systemctl enable sshd postfix
  3. [root@git-node1 ~]# systemctl start sshd postfix
  4. [root@git-node1 ~]# firewall-cmd --permanent --add-service=http
  5. [root@git-node1 ~]# systemctl reload firewalld

2.添加GitLab仓库,并安装到服务器

  1. [root@git-node1 ~]# curl -sS http://packages.gitlab.cc/install/gitlab-ce/script.rpm.sh | sudo bash
  2. [root@git-node1 ~]# yum install gitlab-ce

3.启动GitLab

   1.gitlab-ctl reconfigure

2.浏览到主机名和登录Browse to the hostname and login 
       3.首次访问GitLab,系统会让你重新设置管理员的密码,设置成功后会返回登录界面. 
       4.默认的管理员账号是root,如果你想更改默认管理员账号,请输入上面设置的新密码登录系统后修改帐号名.

5.创建key

  1. [root@git-node1 demo]# ssh-keygen #一路回车
  2. Generating public/private rsa key pair.
  3. Enter file in which to save the key (/root/.ssh/id_rsa):
  4. Created directory '/root/.ssh'.
  5. Enter passphrase (empty for no passphrase):
  6. Enter same passphrase again:
  7. Your identification has been saved in /root/.ssh/id_rsa.
  8. Your public key has been saved in /root/.ssh/id_rsa.pub.
  9. The key fingerprint is:
  10. ::9a::cd:0f:f3::c6:dc:3c::0a:bb:: root@git-node1
  11. The key's randomart image is:
  12. +--[ RSA ]----+
  13. | .+ o + |
  14. | .= = . * + |
  15. | =.= * o . . |
  16. | o.E.o o . |
  17. | .oS . |
  18. | . . |
  19. | . |
  20. | |
  21. | |

  6.复制id_rsa.pub公钥

  1. [root@git-node1 demo]# cat ~/.ssh/id_rsa.pub
  2. ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEAyVSAhs+ZBTEwv5nMwyoordV4VBy+DoCyGBJcjqkcfagRyyGUZvS57T4rhgSpz2csMTtxBXAyo0vJltxPr8McsZmcDZ8+t5qr22h9wHULFs5uB5/uZ6CDomm
    /rVtJjiT2l1Uzh14De1CJDbNRPTCbxvcD5Mi7Ko29epymdt8agYqV2+ROynYaSjqcKxuo6pXD/cGskO7JTOkek2wxmTFOxFQR/Ec1LtVk8ilcesENzMdeU4Nwr2lec6Lr++qKXQuO7a3vB4958Hfhh1JlRI
    ShDuHBOsFChG+vJim6tl123k7jjePHxJhUORhVMpmD4pMNwN+NYv1ta3J3ZSW6v5uWxw== root@git-node1

  7.添加公钥至gitlab,如图1-6-1

图1-6-1添加服务器公钥

1.2添加远程仓库

1.gitlab创建仓库,进行远程同步,如图1-6-2 

图1-6-2gitlab创建远程仓库

2.使用git remote 添加远程仓库地址,选择SSH方式克隆。

  1. [root@git-node1 ~]# cd demo/ //必须是git init 初始化仓库目录
  2. [root@git-node1 demo]# git remote add origin git@git-node1:root/git_demo.gitxxx

1.3修改远程仓库

由于刚开始添加的远程仓库写错了url,现在通过如下命令进行url修改

  1. [root@git-node1 demo]# git remote set-url origin git@git-node1:root/git_demo.git

1.4查看远程仓库

如果已经配置了远程仓库服务器,可以运行 git remote命令。它会列出你指定每一个远程服务器的简写。

  1. [root@git-node1 demo]# git remote
  2. origin

也可以指定-v选项,会显示需要读写远程仓库git保存简写名称以及对应的URL地址。

  1. [root@git-node1 demo]# git remote -v
  2. origin git@git-node1:root/git_demo.git (fetch)
  3. origin git@git-node1:root/git_demo.git (push)

1.5推送远程仓库

将本地库更新内容推送至远程,用git push命令,实际上是将当前分支推送至远程仓库。 
由于远程库是新建立空的,我们在第一次推送时候,git默认是不会把本地master关联至远端的master,所以我们需要加上-u参数,这样git不但会把本地的master分支内容推送至远程仓库的master分支,并且还会将本地的master分支和远程master分支关联起来。在以后推送或者拉取时就可以简化命令。

  1. [root@git-node1 demo]# git push -u origin master
  2. Counting objects: 5, done.
  3. Compressing objects: 100% (2/2), done.
  4. Writing objects: 100% (5/5), 432 bytes | 0 bytes/s, done.
  5. Total 5 (delta 0), reused 0 (delta 0)
  6. To git@git-node1:root/git_demo.git
  7. * [new branch] master -> master
  8. 分支 master 设置为跟踪来自 origin 的远程分支 master。

如果推送冲突可以选择--force强行推送

  1. [root@git-node1 xuliangwei]# git push origin --force
  2. 如果一次都没有推送数据,可以选择—all一次全部推送至远程服务器
  3. [root@git-node1 xuliangwei]# git push origin --all
 

1.6克隆远程仓库

如果现在仓库已经有开发好的项目,需要加入进来开发,可以先clone整个项目。

  1. [root@git-node1 tmp]# git clone git@git-node1:root/git_demo.git
  2. 正克隆到 'git_demo'...
  3. remote: Counting objects: 5, done.
  4. remote: Compressing objects: 100% (2/2), done.
  5. remote: Total 5 (delta 0), reused 0 (delta 0)
  6. 接收对象中: 100% (5/5), done.

1.7拉取远程仓库

简单的说,这个命令会访问远程仓库,从中取出你还没有的数据,或者git pull之后还是没有的数据。 
此前在添加的远程仓库的时候指定了仓库名origin,命令会自动将其添加为远程仓库并默认以origin为简写。 
所以,git fetch origin相当于从远程获取最新版本到本地,然后比较本地master分支和远程master分支差别最后进行合并。

  1. [root@git-node1 demo]# git fetch origin //拉取主分支最新版本(可以拉取其他分支)
  2. [root@git-node1 demo]# git fetch origin dev //获取dev分支最新数据

拉取数据,在生产环境中见到比较多的还是git pull相当于是从远程获取最新版本并merge到本地

  1. [root@git-node1 xuliangwei]# git pull origin master #拉取主分支最新版本(可以拉取其他分支)
  2. [root@git-node1 xuliangwei]# git pull origin dev //获取dev分支最新数据

上述命令其实相当于git fetch 和 git merge在实际使用中,git fetch更安全一些,因为在merge前,我们可以查看更新情况,然后再决定是否合并 
1.6.8更改远程仓库

如果想重新命名一个远程仓库名称。将test重命名为rainbow,可以通过git remote rename进行修改。 
注意:这同时会修改你的远程分支名字。之前引用test/master的现在会引用rainbow/master 
1.添加新远程分支,并赋予test为远程仓库名称

  1. [root@git-node1 git_demo]# git remote add test git@git-node1:root/git_demo.git
  2. [root@git-node1 git_demo]# git remote -v
  3. origin git@git-node1:root/git_demo.git (fetch)
  4. origin git@git-node1:root/git_demo.git (push)
  5. test git@git-node1:root/git_demo.git (fetch)
  6. test git@git-node1:root/git_demo.git (push)

2.修改test名称为rainbow名称

  1. [root@git-node1 git_demo]# git remote rename test rainbow
  2. [root@git-node1 git_demo]# git remote -v
  3. origin git@git-node1:root/git_demo.git (fetch)
  4. origin git@git-node1:root/git_demo.git (push)
  5. rainbow git@git-node1:root/git_demo.git (fetch)
  6. rainbow git@git-node1:root/git_demo.git (push)

1.9移除远程仓库

因为一些变动不再使用一些特定的镜像,可以通过git remote remove 远程仓库名称,移除远程仓库 
1.查看远程仓库

  1. [root@git-node1 git_demo]# git remote -v
  2. origin git@git-node1:root/git_demo.git (fetch)
  3. origin git@git-node1:root/git_demo.git (push)
  4. rainbow git@git-node1:root/git_demo.git (fetch)
  5. rainbow git@git-node1:root/git_demo.git (push)

2.移除不再使用的rainbow远程仓库

  1. [root@git-node1 git_demo]# git remote remove rainbow
  2. [root@git-node1 git_demo]# git remote -v
  3. origin git@git-node1:root/git_demo.git (fetch)
  4. origin git@git-node1:root/git_demo.git (push)
 

1.10Git远程仓库小结

  要添加一个仓库,首先必须知道仓库的地址,然后使用git remote add 命令添加远程仓库,也可使用git clone命令克隆。(Git支持多种协议,包括http、https,但通过ssh支持的原生git协议速度最佳。)

  要关联一个远程库,使用命令git remote add origin git@server-name:path/repo-name.git,关联后,使用命令git push -u origin master第一次推送master分支的所有内容,此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改

    1. # git remote add [remote] [url]#添加(关联)远程库
    2. # git remote set-url [remote] [url] #修改远程仓库
    3. # git clone [url] #克隆远程仓库项目
    4. # git remote #查看指定远程仓库命名简写
    5. # git remote –v #查看远程仓库详细信息以及名称对应URL
    6. # git push -u remote master #第一次推送master分支的所有内容
    7. # git fetch remote [branch/tag] #下载远程仓库的所有变动
    8. # git pull remote [branch/tag] #拉取主分支最新版本(可以拉取其他分支)
    9. # git push remote [branch/tag] --force #强行推送当前分支至远程分支,及时冲突
    10. # git push remote [branch/tag] --all #推送所有分支到远程仓库
    11. # git remote rename [oldname] [newname] #修改远程仓库名称
    12. # git remote remove [name] #删除远程仓库名称以及URL地址

Git系列四之在本地服务器搭建gitlab仓库管理的更多相关文章

  1. Git系列四之在本地服务器搭建gitlab仓库管理(centeros环境下)

    1.Git仓库管理 现在本地已经创建了git仓库,又在gitlab上创建了一个git仓库,并且让这两个仓库进行远程同步,这样gitlab仓库既可以备份也可以与他人协作管理远程仓库以及根据需要推送或拉取 ...

  2. Git本地服务器搭建及使用详解

    Git本地服务器搭建及使用 Git是一款免费.开源的分布式版本控制系统.众所周知的Github便是基于Git的开源代码库以及版本控制系统,由于其远程托管服务仅对开源免费,所以搭建本地Git服务器也是个 ...

  3. GIT 基础 &本地服务器搭建

    Git是一款免费.开源的分布式版本控制系统.众所周知的Github便是基于Git的开源代码库以及版本控制系统,由于其远程托管服务仅对开源免费,所以搭建本地Git服务器也是个较好的选择,本文将对此进行详 ...

  4. Git本地服务器搭建

    安装编译环境,执行以下命令 [root@centos6 ~]# yum -y install curl curl-devel zlib-devel openssl-devel perl cpio ex ...

  5. Solr本地服务器搭建及查询

    0.安装solr之前,确保已安装好java8,  java -version 查看是否安装 1.新建本地目录solr1 并 解压两个压缩包文件 .tar.gz .tgz tomcat7 2.将CATA ...

  6. SVN本地服务器搭建及在Eclipse中的应用

    0.说明在程序开发的时候会有很多的版本,通过手动备份的方式不紧麻烦而且低效易出错.使用SVN来管理版本会方便很多,虽然有一些学习成本,但是学会使用之后会使得开发更加的高效.本文介绍如何在本地搭建svn ...

  7. Tomcat本地服务器搭建

    首先,下载jdk-8u111-windows-x64.exe,然后配置环境,以安装目录D:\jdk1.8.0_111为例: 新建一个变量: 然后打开path新建两个变量: 最后去控制台敲javac或者 ...

  8. 本地服务器搭建服务:mysql

    话不多少,mysql的优劣不再此讨论. 1.官网地址:https://dev.mysql.com/downloads/mysql/ 下载页面直接  No thanks,just start my do ...

  9. 本地服务器搭建服务:svn

    SVN(使用VisualSVN-server)可视化SVN 服务搭建,适合小白:简单又快捷,深入了解命令行方式等高手请移步官网看教程 1.官网 :http://subversion.apache.or ...

随机推荐

  1. Foreach与迭代器

    Foreach与迭代器 Foreach语句可以用于数组和集合的遍历.之所以能够工作,是因为Java SE5引入了新的被称为Iterable的接口,该接口中包含一个能够产生Iterator的iterat ...

  2. chain模块将两个列表合并

    示例代码 from itertools import chain v1 = [11,22,33] v2 = ['a','b','c'] for item in chain(v1,v2): print( ...

  3. redis之(五)redis的散列类型的命令

    [一]赋值与取值 -->命令:HSET key field value   -->往某个key的某个属性设置值 -->命令:HGET key field   --> 获取某个k ...

  4. Linux下几个命令的技巧

    Ctrl的组合键+a,移动到一行命令的首部+e,移动到一行命令的尾部+左右键,以单词为单位左右移动+u,删除光标之前的所有内容+k,删除光标之后的所有内容Alt+.为引用上一个命令的最后一个参数 还有 ...

  5. react native android 上传文件,Nodejs服务端获取上传的文件

    React Native端 使用react-native-image-picker 做出选择图片的操作,选择完成后,直接将图片Post至服务器,保存在服务器的某个地方(保存图片的路径需要公开显示),并 ...

  6. No module named '_Sqlite3' 解决方法

    今晚,在学习Python的时候,(学习链接:http://yidao620c.github.io/blog/20150420/simpleblog-01.html(搭载自己的博客案例)): 想为系统生 ...

  7. CodeVS1169 传纸条 [DP补完计划]

    题目传送门 题目描述 Description 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端, ...

  8. 洛谷——P2121 拆地毯

    P2121 拆地毯 题目背景 还记得 NOIP 2011 提高组 Day1 中的铺地毯吗?时光飞逝,光阴荏苒,三年过去了.组织者精心准备的颁奖典礼早已结束,留下的则是被人们踩过的地毯.请你来解决类似于 ...

  9. 洛谷——P2381 圆圆舞蹈

    P2381 圆圆舞蹈 题目描述 熊大妈的乃修在时针的带领下,围成了一个圆圈舞蹈,由于没有严格的教育,奶牛们之间的间隔不一致. 奶牛想知道两只最远的奶牛到底隔了多远.奶牛A到B的距离为A顺时针走和逆时针 ...

  10. Sqli-labs less 2

    Less-2 将'(单引号)添加到数字中. 我们又得到了一个Mysql返回的错误,提示我们语法错误. You have an error in your SQL syntax; check the m ...