我们不可能只在一台电脑上开发,白天在公司用公司电脑,晚上在家可以用自己电脑。但是这个代码怎么让两台电脑同步呢?总不能用U盘复制粘贴。太繁琐。

这里我们就可以找个代码托管的平台,帮我们做这件事。

Github介绍

GitHub是一个基于Git的远程文件托管平台(同GitCafe、BitBucket和GitLab等)。

Git本身完全可以做到版本控制,但其所有内容以及版本记录只能保存在本机,如果想要将文件内容以及版本记录同时保存在远程,则需要结合GitHub来使用。使用场景:

  • 无GitHub:在本地 .git 文件夹内维护历时文件
  • 有GitHub:在本地 .git 文件夹内维护历时文件,同时也将历时文件托管在远程仓库

其他:

集中式:远程服务器保存所有版本,用户客户端有某个版本
    分布式:远程服务器保存所有版本,用户客户端有所有版本

GitHub,一个基于Git实现的代码托管的平台,可以将内容以及版本记录在远程也保存一份,这样就不用U盘咯(类似于云盘)。PS: 类似GitHub的产品还有许多,如:GitLab、Bitbucket、码云等。

基于GitHub实现代码托管,需要一下步骤:

1、注册Github

2、创建仓库,创建仓库后会有一个URL代指该仓库,如:

3、git可以是用该URL进行向远程推送版本信息或获取版本信息

学会使用Git和GitHub之后,就可以基于GitHub进行代码远程托管。

在家里,开发完毕部分功能将代码推送到GitHub:

MacBook-Pro-4:pondo yaya$ git remote add origin https://github.com/yaya/pondo.git   # 为地址起一个别名origin
MacBook-Pro-4:pondo yaya$ git push origin master # 将本地master分支内容以及版本信息推送到GitHub
Username for 'https://github.com': # 输入GitHub用户名
Password for 'https://yaya@github.com': # 输入GitHub密码
Counting objects: 2, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (2/2), 270 bytes | 0 bytes/s, done.
Total 2 (delta 1), reused 0 (delta 0)
remote: Resolving deltas: 100% (1/1), completed with 1 local object.
To https://github.com/WuPeiqi/pondo.git
634aac4..274f1e4 master -> master
MacBook-Pro-4:pondo yaya$ git push origin dev # 将本地dev分支内容以及版本信息推送到GitHub
Counting objects: 3, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 261 bytes | 0 bytes/s, done.
Total 3 (delta 1), reused 0 (delta 0)
remote: Resolving deltas: 100% (1/1), completed with 1 local object.
To https://github.com/WuPeiqi/pondo.git
274f1e4..50e2169 dev -> dev

在公司,将代码从GitHub中获取并继续开发 

MacBook-Pro-4:github yaya$ git clone https://github.com/yaya/pondo.git    # 将项目从GitHub中获取
Cloning into 'pondo'...
remote: Counting objects: 31, done.
remote: Compressing objects: 100% (26/26), done.
remote: Total 31 (delta 2), reused 30 (delta 1), pack-reused 0
Unpacking objects: 100% (31/31), done.
MacBook-Pro-4:github yaya$ cd pondo/
MacBook-Pro-4:pondo yaya$ git Branch # 默认获取到得只有master分支
* master
MacBook-Pro-4:pondo yaya$ git branch dev origin/dev # 创建dev分支且和远程dev分支同步
Branch dev set up to track remote branch dev from origin.
MacBook-Pro-4:pondo wupeiqi$ git checkout dev # 切换到dev分支
Switched to branch 'dev' MacBook-Pro-4:pondo yaya$ vim app01/views.py # 继续开发新功能 MacBook-Pro-4:pondo yaya$ git add . # 添加文件到版本库的暂存状态
MacBook-Pro-4:pondo yaya$ git commit -m '公司开发功能1' # 提交新功能到版本库的分支
[dev 9281447] 公司开发功能1
1 file changed, 1 insertion(+), 1 deletion(-)
MacBook-Pro-4:pondo yaya$ git push origin dev # 提交dev分支内容到远程GitHub托管仓库的dev分支
Username for 'https://github.com': yaya
Password for 'https://yaya@github.com':
Counting objects: 4, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (4/4), done.
Writing objects: 100% (4/4), 427 bytes | 0 bytes/s, done.
Total 4 (delta 2), reused 0 (delta 0)
remote: Resolving deltas: 100% (2/2), completed with 2 local objects.
To https://github.com/yaya/pondo.git
50e2169..9281447 dev -> dev

在家里,由于白天在公司已经开发一部分功能并提交到GitHub,家里电脑的代码还是昨晚的版本,所以需要从GitHub拉去最新代码,然后继续开发。  

MacBook-Pro-4:pondo yaya$ git checkout dev                                   # 切换到dev分支
Already on 'dev'
MacBook-Pro-4:pondo yaya$ git pull origin dev # 从远程GitHub仓库获取dev分支最新内容,并合并到本地
remote: Counting objects: 4, done.
remote: Compressing objects: 100% (2/2), done.
remote: Total 4 (delta 2), reused 4 (delta 2), pack-reused 0
Unpacking objects: 100% (4/4), done.
From https://github.com/yaya/pondo
* branch dev -> FETCH_HEAD
50e2169..9281447 dev -> origin/dev
Updating 50e2169..9281447
Fast-forward
app01/views.py | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
MacBook-Pro-4:pondo yaya$ vim app01/views.py # 继续开发新功能
MacBook-Pro-4:pondo yaya$ git add . # 添加文件到版本库的暂存状态
MacBook-Pro-4:pondo yaya$ git commit -m '家里开发功能1' # 提交新功能到版本库的分支

在公司,由于昨天晚上在家已经开发了一部分功能,在公司需要先把昨晚开发的功能从GitHub中拉取,并继续开发。 

MacBook-Pro-4:pondo yaya$ git checkout dev                                   # 切换到dev分支
MacBook-Pro-4:pondo yaya$ git fetch origin dev # 从GitHub仓库获取dev分支最新内容到版本库的分支
remote: Counting objects: 3, done.
remote: Compressing objects: 100% (1/1), done.
remote: Total 3 (delta 1), reused 3 (delta 1), pack-reused 0
Unpacking objects: 100% (3/3), done.
From https://github.com/yaya/pondo
* branch dev -> FETCH_HEAD
150d891..65b6604 dev -> origin/dev
MacBook-Pro-4:pondo yaya$ git merge origin/dev # 将版本库的分支内容合并到工作区
Updating 150d891..65b6604
Fast-forward
readme | 5 ++++-
1 file changed, 4 insertions(+), 1 deletion(-)
MacBook-Pro-4:pondo yaya$ vim app01/views.py # 继续开发新功能
MacBook-Pro-4:pondo yaya$ git add . # 添加文件到版本库的暂存状态
MacBook-Pro-4:pondo yaya$ git commit -m 'xxxxxxxxxxx' # 提交新功能到版本库的分支

长此以往,将Git和GitHub结合使用做到避免电脑损坏造成数据丢失以及多地开发的问题,上文执行过程中执行 【git pull origin 分支】命令等同于【git fetch origin 分支】+ 【git merge origin/分支】,并且在执行过程中可能会出现冲突,原因是由于本地代码和获取的最新代码有重合部分,那么就需要自己手动解决冲突然后再继续开发。  

 

Git 之 与Github交互的更多相关文章

  1. git远程库GitHub

    首先,注册一个GitHub(github.com)帐号,免费获得Git远程仓库 由于本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以,需要一点设置: 第1步:创建SSH Key.在用 ...

  2. ***Linux下使用git命令及github项目

    在linux下搭建git环境1.创建Github账号,https://github.com2.Linux创建SSH密钥: ssh-keygen  ##一直默认就可以了 3.将公钥加入到Github账户 ...

  3. myeclipse eclipse 使用git插件访问github 的解决方案

    具体的步骤很多帖子都有写,这里不再赘述,需要说明的一点,git插件的版本很重要,在官网上下载的最新版本在MyEclipse8.5,MyEclipse9.1,MyEclipse10上面都没有成功. 这里 ...

  4. 版本控制简介,git使用----使用GitHub托管代码

    关于版本控制: 很久以前,人们苦于对写过的代码进行版本的管理,经常过了一段时间想恢复原来写过的代码却又忘了不知道丢到哪儿去了,有的人用加上时间后缀来命名文件的方法,便于后期维护,但是这样做的麻烦也很大 ...

  5. 详细介绍如何在win7下首次实现通过Git bash向Github提交项目

    详细介绍如何在win7下首次实现通过Git bash向Github提交项目 引自:http://jingpin.jikexueyuan.com/article/35944.html 作者: wddoe ...

  6. Sublime Text 中使用Git插件连接GitHub

    sublime Text的另一个强大之处在于它提供了非常丰富的插件,可以帮助程序员来适合大多数语言的开发.这些插件通过它自己的Package Controll(包管理)组件来安装,非常方便.一般常用的 ...

  7. windows中使用Git工具连接GitHub(配置篇)

    Git在源码管理领域目前占很大的比重了,而且开源的项目很多都转到GitHub上面了.例如:jQuery, reddit, Sparkle, curl, Ruby on Rails, node.js,  ...

  8. git 提交到github时不用每次都输入用户名,密码

    Permanently authenticating with Git repositories, Run following command to enable credential caching ...

  9. git clone https://github.com/istester/ido.git ,确提示“Failed to connect to 192.168.1.22 port 8080: Connection refused” 的解决办法 。

    不知道是否有同学遇到如下的问题: p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo } span.s1 { } git clone ...

随机推荐

  1. mysql前缀索引的应用

    在mysql中有时需要索引的列很长,如果直接应用索引会造成索引过大的问题.因此我们可以取其中一部分字段来做索引,例: 添加索引:alter table * add key (field(3));   ...

  2. Java进阶知识点2:看不懂的代码 - 协变与逆变

    一.背景 要搞懂Java中的协办与逆变,不得不从继承说起,如果没有继承,协变与逆变也天然不存在了. 我们知道,在Java的世界中,存在继承机制.比如MochaCoffee类是Coffee类的派生类,那 ...

  3. [转]css讲解 font-weight:bold和bolder区别

    font-weight 字体浓淡(精细)属性 该CSS属性用来设定字体的浓淡程度. 值:normal | bold | bolder | lighter | 100 | 200 | 300 | 400 ...

  4. Excel合并计算

    office版本为2013,数据来源:我要自学网,曾贤志老师 计算之前,光标定在空白位置,不要定在数据源. 将汇总的类型居于首列(不可以跨区域选择,可以把不需要汇总的移动到其他列). 要有删除原来数据 ...

  5. BZOJ2648:SJY摆棋子

    浅谈\(K-D\) \(Tree\):https://www.cnblogs.com/AKMer/p/10387266.html 题目传送门:https://lydsy.com/JudgeOnline ...

  6. 2、Monkey简单使用

    1.使用Monkey测试,前提是有虚拟机或者真机设备,查看是否有设备存在:adb devices (需要先进入SDK的tool目录下才执行该操作) 2.查看设备上各个包名 adb shell pm l ...

  7. height clientHeight scrollHeight offsetHeight的大致区别

    这主要是针对火狐浏览器来讲的: height:就是div的高度,就是style中设置的高度:在chrome中clientHeight是包含padding的,offsetHeight和clientHei ...

  8. UIAlertController UIAlertView用法

    项目中很多地方会出现弹出框框,来做个判断 基本方法如下 UIAlertController *alertC = [UIAlertController alertControllerWithTitle: ...

  9. Gwt第三方组件、框架介绍

    介绍一下我接触过的Gwt第三方组件.框架及项目 1. Mygwt 曾经的大名鼎鼎的gwt第三方框架,在某些gwt框架的排名中排名第一.这个框架完全用gwt的方式实现了ext-js的功能,不依赖于ext ...

  10. JSF结合Spring 引入ViewScope

    当JSF项目的faceConfig中配置了Spring的配置代码 <application> <el-resolver>org.springframework.web.jsf. ...