本地仓库(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. 【权限维持】window几种隐藏技术

    “真正”隐藏文件 使用Attrib +s +a +h +r命令就是把原本的文件夹增加了系统文件属性.存档文件属性.只读文件属性和隐藏文件属性. attrib +s +a +h +r c:\test 这 ...

  2. iOS开发-- 设置UIButton的文字显示位置、字体的大小、字体的颜色

    btn.frame = CGRectMake(x, y, width, height); [btn setTitle: @"search" forState: UIControlS ...

  3. SaltStack 批量执行脚本

    这里演示如何使用 salt-master 对多台 salt-minion 批量执行脚本,步骤如下: [root@localhost ~]$ cat /srv/salt/top.sls # 先定义入口配 ...

  4. AngularJS的表达式、指令的学习(2)

    最近没有那么忙,就来系统学习一下AngularJS吧,昨天简单的认识了一下,今天就从表达式入手吧,嘿嘿. 一.AngularJS 表达式 AngularJS表达式写在双大括号内:{{expressio ...

  5. 批处理--批量打开程序&批量关闭程序

    批量打开程序 start D:\work\RunSvr01\IceFire88.01.exe start D:\work\RunSvr02\IceFire88.02.exe start D:\work ...

  6. JS-过滤敏感词【RegExp】

    来自腾讯课堂笔记:https://ke.qq.com/webcourse/index.html#course_id=152997&term_id=100174752&taid=8010 ...

  7. <转>Python: and、or以及and-or

    转自 http://www.cnblogs.com/BeginMan/p/3197123.html 一.and: 在Python 中,and 和 or 执行布尔逻辑演算,如你所期待的一样,但是它们并不 ...

  8. 【线程】Thread中的join介绍

    因为sleep.wait.join等阻塞,可以使用interrupted exception异常唤醒. 一.作用 Thread类中的join方法的主要作用就是同步,它可以使得线程之间的并行执行变为串行 ...

  9. 【规范】alibaba编码规范阅读

    一.编程规范 (一)命名规范 1.代码中的命名均不能以下划线或美元符号开始,也不能以下划线或美元符号结束 2.代码中的命名严禁使用评语与英文混合的方式,更不允许直接使用中文的方式 3.类名使用Uppe ...

  10. Android 编译时:m、mm、mmm、mma、mmma的区别

    m:编译整个安卓系统 makes from the top of the tree mm:编译当前目录下的模块,当前目录下需要有Android.mk这个makefile文件,否则就往上找最近的Andr ...