本地仓库(local repository)

创建一个本地仓库的流程:

  1. 为本地仓库创建一个目录
  2. 在目录中执行 git init

对本地仓库所做的改变(例如添加、删除文件等)首先加入到本地仓库的 Index(stage)中,之后通过 commit 命令将这些改变提交到本地仓库。

创建某个仓库的拷贝

  1. git clone /path/to/repository

这里的 /path/to/repository 可以是一个本地路径,也可以是一个 URL。范例:

  1. git clone https://github.com/name5566/merry.git

针对本地仓库的常见操作

  1. 文件添加操作
    1. 将文件加入到 Index 中去(文件被修改也需要加入到 Index 后才能提交)
    2. git add filename
    3. 将所有新增的文件加入到 Index 中去
    4. git add *
  2. 文件(或目录)的移动(或重命名)操作
    1. git mv file1 file2
  3. 文件的删除操作
    1. 将文件从当前目录和 Index 中移除
    2. git rm filename
  4. 提交改变到本地仓库
    1. 提交改变到本地仓库
    2. git commit -m "message"
    3. 根据当前文件被修改和删除的情况更新 Index 并提交这些改变到本地仓库(未告知 git 的新文件除外)
    4. git commit -a -m "message"
  5. 显示当前尚未提交的改变
    1. git status

将本地仓库的改变推送到远程仓库

我们使用 commit 命令将改变提交到本地仓库,之后可以将这些改变推送到远程仓库中:

  1. 这里 master 表示分支,你可以根据实际需要推送的分支来进行修改
  2. git push origin master

分支

  1. 分支间相互切换
    1. git checkout master
    2. git checkout feature_x
  2. 创建新分支并切换过去
    1. git checkout -b feature_x
  3. 删除特定分支
    1. git branch -d feature_x
  4. 删除远程子分支

      1. git push origin -d feature_x

  5. 合并分支
    1. git merge feature_x

分支创建之后,可以推送到远程仓库:

  1. git push origin feature_x

更新本地仓库

  1. git pull

日志

  1. 显示日志
  2. git log
  3. 显示 bob 的日志
  4. git log --author=bob

替换本地修改

有时候,我们希望还原所做的修改:

  1. 放弃当前对 filename 文件的修改,获取本地仓库中最后一次提交的结果
  2. git checkout -- filename
  3. 放弃本地所有改变和提交,直接从远程仓库获取
  4. git fetch origin
  5. git reset --hard origin/master

从github上clone子分支

正常情况下,我们在github上看到一个clone地址,git clone xxxxxxx.git后,默认clone进入的是master分支,如果想切换到某一个子分支,可以使用

git checkout -b child_repos origin/child_repos

其中,child_repos指的是目标子分支名,

这时,使用git branch可以看到自己已经在子分支上,正常

git pull origin child_repos

git push origin child_repos

即可。

Git 怎样保证fork出来的project和原project(上游项目)同步更新

步骤:

1.  在 Fork 的代码库中添加上游代码库的 remote 源,该操作只需操作一次即可。

如: 其中# upstream 表示上游代码库名, 可以任意。

git remote add upstream https://github.scm.corp.ebay.com/montage/frontend-ui-workspace

2. 将本地的修改提交 commit

3. 在每次 Pull Request 前做如下操作,即可实现和上游版本库的同步。

3.1 : git remote update upstream

3.2 : git rebase upstream/{branch name}

需要注意的是在操作3.2之前,一定要将checkout到{branch name}所指定的branch,

如: git checkout develop

4. Push 代码到 Github

git push

如果项目中有引用其他项目作为子项目 clone时使用

`git clone` 的时候加上 `--recursive`

可以clone整个项目,包含子项目

Github常用命令【转】的更多相关文章

  1. Github 常用命令

    小记一些Github常用命令 : 在一个项目中... 假如要修补问题追踪系统上的 #53 问题.顺带说明下,Git 并不同任何特定的问题追踪系统打交道.这里为了说明要解决的问题,把新建的分支取名为 i ...

  2. Linux 使用 github 常用命令

    Linux 使用 github  常用命令 今天整理一下常用的 github 命令,自己只是一个编程小白,有些地方可能做的不是很好,仅仅用作自己的学习使用. 创建一个文件夹用于存放github仓库 m ...

  3. github常用命令

    全局配置 git config --global user.name "lewiscutey"git config --global user.email "lewisc ...

  4. git(github)常用命令

    安装git sudo apt-get install git 显示git版本 git version 显示system属性,对应为/etc/gitconfig文件的内容 git config --sy ...

  5. GitHub常用命令及使用

    GitHub使用介绍 摘要: 常用命令: git init 新建一个空的仓库git status 查看状态git add . 添加文件git commit -m '注释' 提交添加的文件并备注说明gi ...

  6. GIt/Github常用命令

    1)git init:初始化本地仓库 2)创建文件:touch read.txt 3)当操作本地的文件时,使用常用的命令,如(mv,ls..)就可以操作,当操作暂存区的文件时需要在命令前家git,并且 ...

  7. GitHub 常用命令使用介绍(新同学入门)

    经济在不断发展,社会在不断进步,以往的互联网在现在看来都可以称为传统互联网了,因为技术不断的在突破和革新. 本文主要介绍一下版本管理工具,我猜测很多人还是用SVN.CVS或者Resion,但是,今天我 ...

  8. github常用命令汇总

    创立版本库 mkdir Baiducd Baidugit init SSHssh-keygen -t -rsa -C "TaylorApril947939@gmail"(在gith ...

  9. Git与github常用命令

    Git项目与github建立联系 首先,需要在github上建立一个repository mkdir github-project cd github-project git init 此时githu ...

随机推荐

  1. iOS开发-- 使用VVDocumenter-Xcode添加代码注释

    在开发Java代码过程中,我们只需在Eclipse中敲/**即可生成字段.方法对应的文档,简单便捷. 在Xcode如果想添加文档注释,需要花费很多时间,有没有简单.快速的方法搞定这一切? 在网上搜索了 ...

  2. [Linux] 如何修改 Linux 主机名

    该方法适用于安装了 Linux 系统的Raspberry Pi & Cubieboard. 在终端执行: sudo vi /etc/hosts 你看到的 hosts 文件应该是这样的: 127 ...

  3. WP8.1学习系列(第二十六章)——控件模板

    在本文中 自定义控件模板示例 指定控件的可视结构. 指定控件的可视行为 使用工具轻松处理主题 控件和辅助功能 了解有关控件默认模板的详细信息 控件模板中的主题资源 相关主题 在 XAML 框架中,如果 ...

  4. Android程序对不同手机屏幕分辨率自适应的方法

    相信各位Android开发爱好者都知道,由于OEM之间的竞争,各种Android操作系统的手机简直就是琳琅满目,屏幕分辨率的差异可想而知.目前比较主流的有WVGA=800x480,HVGA=480x3 ...

  5. Xcode debug时如何查看内存中的数据

    对于IPhone开发/XCode的初学者,如何在调试时查看变量的值是很头痛的事情.因为Xcode的expression 经常无法正确显示变量的值.但是强大的GDB可以很方便的帮我们查看变量的值.   ...

  6. Ubuntu 最好用的CHM阅读器KchmViewer

    直接在“ubuntu软件中心”进行搜索安装 为什么说它是最好用?很简单!可同时显示目录和内容,中文没乱码!能实现这两点的竞争对手已经不多了,至少我是没发现.什么chmsee,gnochm,都有乱码.虽 ...

  7. 题目1162:I Wanna Go Home(最短路径问题进阶dijkstra算法))

    题目链接:http://ac.jobdu.com/problem.php?pid=1162 详解链接:https://github.com/zpfbuaa/JobduInCPlusPlus 参考代码: ...

  8. 题目1161:Repeater(规律输出图形)

    题目1161:Repeater 题目链接:http://ac.jobdu.com/problem.php?pid=1161 具体分析:https://github.com/zpfbuaa/JobduI ...

  9. Installed .NET Framework 4.5 Ajax POST IIS hang

    去年我已写过一篇关于安装.NET Framework 4.5后特定场景Ajax POST的挂起问题 => http://www.cnblogs.com/junchu25/archive/2012 ...

  10. JiraRemoteUserAuth

    配置Jira7.x版本使用REMOTE_USER的HTTP Header方式登录: 前提是已经安装好了JIRA,并且前端使用apache或者nginx拦截对应的地址进行认证,认证之后访问对应的应用的时 ...