【Git】使用指南

上一篇文章补充了菜鸟教程搭建git服务器一章中不完善的地方,本文就已经搭建好的git服务器的使用做以简单介绍。文章不涉及git的工作原理,如要了解git的工作原理,请移步廖雪峰个人博客


使用git管理项目资源主要分为两种情况:

  • 管理一个已经存在的项目
  • 管理一个新建的项目

不论上面的那种情况,我们都要有一个远程仓库进行关联,所以第一步是创建一个远程仓库。

1.创建远程仓库

进入到我们服务器的git仓库目录,如:/home/repo/。创建一个test.git仓库,即:/home/repo/test.git
$ git init --bare test.git$ git init test.git

--bare 创建一个裸仓库。裸仓库只允许保存各种git历史提交信息,而不允许直接在上面进行各种git操作。强行操作会报‘This operation must be run in a work tree’错误。远程仓库推荐创建为裸仓库。

现在我们已经创建好了一个空的裸仓库。因为git仓库下的所有内容只有git用户组的成员才能访问,所以接下来修改仓库的所属用户,如果不修改则不能完成推送操作。这里假设我们有一个git用户,一个git组,git用户属于git组
$ chown -R git:git /home/repo/

2.管理项目

经过上面的操作,/home/repo/test.git远程仓库就创建好了。我们可以用它来管理一个已经存在的项目,或一个新的项目。下面就这两种情况分别介绍:

  • 已经存在的项目

    • 如果这个项目已经存在,并且已经有一个git仓库管理了,我们只需要进行第3步关联并推送即可。
    • 如果这个项目已经存在,但是没有被git管理,我们需要先将这个项目初始化为git管理的项目。进入到该项目目录,将该项目目录初始化为一个git仓库。假如我们的项目目录是/DeskTop/myProject/
      $ cd /DeskTop/myProject/
      $ git init
      $ git add .
      $ git commit -m 'first commit'
      现在我们的项目就被一个git仓库管理,直接进入第三步将它合并推送到远程test.git仓库。
  • 新建项目
    对于新建项目,同样有两种方式实现git管理项目:

    • 直接拉取test.git仓库到本地,把拉取得仓库目录当成我们的项目目录来建立一个新的项目工程,进行开发,然后推送到远端即可;
    • 新建一个工程项目,然后进入上面已经存在的项目第二步,按照其中步骤来即可。
3.推送并合并到远程仓库

当我们有了一个本地有效地git仓库后,我们就可以将它和远程仓库进行关联并推送到远程git库中。
将远程test.git仓库登记为origin主机
$ git remote add origin git@github.com:/home/repo/test.git
如果当前分支与多个主机存在追踪关系,则可以使用-u选项指定一个默认主机,这样后面就可以不加任何参数使用git push。
$ git push -u origin master

4.克隆仓库进行协助开发

当我们将项目使用了一个远程仓库进行管理后,我们就可以加入别的开发人员,进行协助开发。首先获取协助开发人员的PC公钥,导入到/home/git/.ssh/authorized_keys文件里,一行一个。然后协助开发人员在自己的PC上就可以克隆项目:
$ git clone git@0.0.0.0:/home/repo/test.git


更多git的相关操作请参考
git中文教程
git官方教程

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,950评论 19 139
  • [TOC] Git @(24.1 Git)[git] 工作原理 直接记录快照,而非差异比较Git 只关心文件数据的...
    浮x尘阅读 3,138评论 0 0
  • [TOC] 前言 刚刚开始使用Git的版本控制时,我根本不确定我付出那么多时间是不是会得到回报,Branch、St...
    木猫尾巴阅读 12,186评论 6 37
  • “大——冶——,李——大——冶!”细微的声音随风而至,捉摸不定,宛儿潜入了夜的寂静。 晚到的时间,将校园文化大道两...
    成蓦阅读 1,648评论 0 0
  • 1.样式有几种引入方式? link和 @import有什么区别? 在HTML中,引入CSS的方法主要有行内式、内嵌...
    饥人谷_螃蟹阅读 1,652评论 0 0

友情链接更多精彩内容