zoukankan      html  css  js  c++  java
  • 如何利用 Git 与 GitHub 进行多人协作开发

    方法一:添加 Collaborators

      Collaborators 类似于Team模式。

      Repository的拥有者Owner 可以直接添加合作者到自己的仓库中, 让合作者拥有几乎等同拥有者的权限。

      操作方法如图所示: Repository的Owner在自己的repo中点Settings添加想要合作的User。

      添加成功后被邀请的合作者会收到GitHub发送的邀请邮件, 该邮件会发送到受邀人的github注册邮箱中。

      

      Collaborators模式可以描述为:

      1)Repository的拥有者A想要合作者B参与到该repo的团队开发中, 于是A邀请B并成功添加B到该repo合作中,这样B作为合作者便拥有了贡献代码到A仓库中的权利。

      2)作为 B 所需要做的是 先Clone A的仓库到本地,这样B在自己的本地就拥有了向A仓库中提交代码(commit/push/merge/branch)的权限,就好比B拥有A的repo一样, 但是B操作 A repo仓库的时候使用的是 B 自己的github账号和密码。

      3)同样此时B自己的github账号中并不会出现A的仓库Repo, 这也就完全不同于fork代码了(fork代码会把拥有者的代码复制一份到自己的github中)。

    方法二:Organization & Team 的方式

      如果你已经创建了一个组织,你可以在该组织中创建一个team进行合作开发。

      

      管理者A可以在创建完的team中 add repo. 设置其权限, 添加team成员, 这样team成员间就可以合作开发这些项目了。

    方法三:Fork & Pull request方式

      对于开源项目间的合作一般都会使用Fork & Pull request的合作方式。

      “Fork” 的名词是 “叉子” 的意思,不过这里取的是动词 “分叉,建一个分支” 的意思。

      A拥有一个开源Repository,B想参与该开源项目。作为B,先要fork A开源项目的 Repository 到自己账号的Repository中,这样B就拥有了A开源项目的镜像repo。

      这样B可以正常的修改自己账号下的 A的开源项目镜像(这里改的都是自己本地的),并不会影响A本身的开源repository, 如果哪天B觉得自己增加并完善了一个新功能, 或者fixed A repo的某个bug,就可以提一个pull request, 询问A是不是想要。

      步骤一:进入你想参与合作开发的仓库界面,点击右上角的 “Fork” 图标,如下图所示。此时你已经复制了一个副本在你的 GitHub 仓库中了,或者是说一个新的代码仓库被创建了,可以打开你的 GitHub 主页看一看。

      

                

      步骤二:在自己的Github中,将这个代码仓库 “Clone”(克隆)到你的本地。“Clone” 成功之后你就可以自主修改里面的内容。

      步骤三:然后将所做的修改提交(Add+Commit+push)到自己的代码仓库,接着到仓库页面,点击 New pull request 按钮。如下图所示:

        点进去之后,将你修改的内容和原本的内容作对比,并把不相同的地方显示出来。

       步骤四: 点击“Create pull request” 按钮,如下图所示:  

      填写你的请求信息,说明你做了些什么之类的。这个请求是发给该项目的拥有者的,完成之后点击 “Create pull request” 按钮即可。

      

       之后项目的拥有者会受到你的请求,只要他/她通过了你的请求,你所做的修改就会被整合到原项目的仓库里了。

       左边是你的本地仓库,中间是你在 GitHub 上 Fork 建立的仓库,右边是项目的原仓库。

       如何与原仓库保持一致?

      在自己做开发的过程中,难免会遇到你 “Fork” 的项目已经有了新的更新,这时当然是希望自己仓库中的代码也能同步进行更新。

      可是,你本地仓库所连接的远程仓库的是你自己的 GitHub 仓库,而不是原作者的仓库。

      需要为你的本地仓库再添加一个远程仓库源

      步骤一:查看当前项目所连接的远程仓库,打开终端,进入到项目的 Git 仓库所在目录,一般就是项目目录,输入如下代码:

    git remote -v

      可以看到目前只连接了我自己的远程仓库。

      步骤二:添加原作者的远程仓库连接,输入如下代码:

    git remote add upstream git@github.com:lexiaoyao1995/weixin.git

       注意替换链接。

      查看连接情况,如下图所示:

       现在已经成功添加原项目的远程仓库了。

      步骤三:输入如下代码,从原项目的远程仓库中更新代码。

    1)从原仓库获取最新版本到本地
    git fetch upstream master
    (2)保证当前位于 master 分支上
    git checkout master
    (3)将最新版本整合到本地 master 分支上
    git merge upstream/master
    (4)将更新发送到自己的 GitHub 仓库里
    git push origin master
    1)(2)(3)步可以用如下命令代替
    git pull upstream master
    但是这样不太安全,因为你 fetch(获取)之后可以通过
    gitlog--oneline --graph --decorate --all
    来查看更新的情况,再决定是否 merge(整合)到一起

      左边是你的本地仓库,中间是你在 GitHub 上 Fork 建立的仓库,右边是项目的原仓库。

  • 相关阅读:
    十大经典排序算法最强总结(含JAVA代码实现)
    Java相关官方链接
    强网杯2020(Funhash)
    强网杯2020(主动)
    强网杯2020(upload)
    (内存取证)46届世界技能大赛湖北省选拔赛
    (流量分析)46届世界技能大赛湖北省选拔赛
    CISCO ASA远程任意文件读取
    OOALV 分割屏幕
    Process Doppelgänging
  • 原文地址:https://www.cnblogs.com/gg-qq/p/10329501.html
Copyright © 2011-2022 走看看