Git和GitHub的使用

一、简介

对照下图细细品味Git中远程仓库、本地仓库、暂存区、工作区的关系:


Git架构

二、环境准备(略过)

整体思路:

1、mac安装Git
2、注册GitHub账号
3、本机创建SSH Key
4、和GitHub相连,打开公共id_rsa.pub
5、使用Git相关命令

三、常用命令行

A、新建命令:

首先在Github上去新建项目,然后将本地Git同它关联

  • 1、本地没有创建Git项目,创建并关联到GitHub
    …or create a new repository on the command line
git init 
git add . 
git commit -m "first commit"
git remote add origin https://github.com/storyxiao/annotation-project.git
git pull origin master
# 如果远程仓库已有文件,出现错误fatal: refusing to merge unrelated histories,先用以下命令pull
# git pull origin master --allow-unrelated-histories
git push -u origin master
  • 2、本地已经创建Git项目,关联到GitHub
    …or push an existing repository from the command line
git remote add origin https://github.com/storyxiao/annotation-project.git 
# 一般会要求先拉取远程仓库代码才可以提交
# git pull origin master 或 git pull 
git push -u origin master
  • 3、如果是线下接收的项目包没有.git文件或本地.git文件被误删,将失去与GitHub的关联。

方法一:备份本地代码,重新clone代码,接着用本机备份覆盖它,然后提交本地变更

git clone https://github.com/storyxiao/annotation-project.git
git add . 
git commit -m "recommit" 
git push -u origin master

方法二:重新生成本地仓.git文件,关联拉取GitHub后提交代码

git init
git remote add origin https://github.com/storyxiao/annotation-project.git
git pull origin master
git add . 
git commit -m "recommit" 
git push -u origin master

B、操作命令:

对于复杂操作如:合并、删除、对比等,个人觉得命令行始终不方便,
在Git客户端软件中操作比较好,如Sourcetree(mac系统)和TortoiseGit(windows系统)

  • 1、从远程库克隆项目:
    git clone [项目地址]
# ssh方式,clone时需要密码,提交时不需要密码,适合开发需要提交代码:
git clone git://git.kernel.org/pub/scm/git/git.git
# https方式,clone时不需要密码,提交时需要密码,适合只是下载下来看看不提交:
git clone http://www.kernel.org/pub/scm/git/git.git
  • 2、新增文件
    git add 文件到暂存区
# 常用-将当前目录所有修改添加到暂存区(不包括忽略文件):
git add .
# add文件到暂存区几种方式的区别:
git add -u:包括文件的修改、删除(update)
git add .:包括文件的修改、新建
git add -A:包括文件的修改、删除、新建(ALL)
# 将某个文件或文件夹添加到暂存区:
git add <file_name.txt>/<path>
# 一次add多个文件的方法,多个文件用空格隔开
git add file1 file2 file3
# 提交文件夹的方法
git add catalog_name
  • 3、提交分支
    git commit
 # 提交所有改动并写提交日志:
 git commit -m "<改动日志说明>"
  • 4、pull和push
    git pull <远程主机名> <远程分支名>:<本地分支名>
    git pull相当于git fetch + git merge FETCH_HEAD
# 取回origin主机的dev分支,并与本地的master分支合并
git pull origin dev:master
# 如果远程分支(dev)要与当前分支合并,则冒号后面的部分可以省略
git pull origin dev
# 默认进一步省略,按照git branch的默认跟踪的服务器和分支来拉取
git pull

git push <远程主机名> <本地分支名>:<远程分支名>
git push命令用于将本地分支的更新,推送到远程主机

# (1) 如果省略远程分支名,则表示将本地分支推送与之存在"追踪关系"的远程分支(通常两者同名),如果该远程分支不存在,则会被新建
git push origin master
# 如果当前分支与远程分支之间存在追踪关系,则本地分支和远程分支都可以省略
git push origin
# 如果当前分支只有一个追踪分支,那么主机名都可以省略
git push
# (2) 如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支
# 慎用!删除远程仓库的分支
git push origin :master
# 等同于
git push origin --delete master
# (3) 如果当前分支与多个主机存在追踪关系,则可以使用-u选项指定一个默认主机,这样后面就可以不加任何参数使用git push
git push -u origin master
# (4) 忽略自动测试
# If you don't want to run tests, please add `--no-verify` in command, such as:
git push --no-verify

Push报错:Push to origin/master was rejected 解决方法

# 依次输入以下命令解决
git pull
git pull origin master
git pull origin master --allow-unrelated-histories
  • 5、checkout
    (1)基础用法:分支切换
# 查看有哪些分支
git branch
# 工作分支切换
git checkout branchName
# 创建并切换分支
git checkout -b newBranch
该命令相当于执行下面两条命令
1. git branch newBranch 
2. git checkout newBranch

(2)深入用法:检出文件
未使用git add缓存代码时:

# 放弃单个文件修改(中间有"--")
git checkout -- readme.md
// 放弃所有的文件修改
git checkout .

已经使用了git add缓存了代码:

# 放弃指定文件的缓存
git reset HEAD readme.md
# 放弃所有的缓存
git reset HEAD .

已经用git commit提交了代码:

# 回退到上一次commit的状态
git reset --hard HEAD^
# 回退到任意版本
git reset --hard commitid # 使用git log可以查看提交id
  • 6、git fetch origin && git merge origin/next
  • 7、create patch && diff
  • 8、stash
    存储当前工作状态到git栈,在需要的时候再恢复
# git stash 这个命令可以多次使用,每次使用都会新加一个stash@{num},num是编号,最新一条的内容为stash@{0}
# 执行存储
git stash save "savemessage" # 也可以不写备注,直接git stash,但个人不推荐
# 查看所有的存储列表
git stash list
# 显示某个存储所做改动
git stash show # 默认显示最新一条的内容,即stash@{0}
git stash show stash@{1}
# 恢复某个存储,但不会把存储从存储列表中删除
git stash apply # 默认使用第一个存储,即stash@{0},建议在git栈中只有一条的时候使用,以免混乱
git stash apply stash@{1} # 恢复num为1的存储
# 恢复某个存储,并将缓存堆栈中的对应stash删除,并将对应修改应用到当前的工作目录下
git stash pop # 默认恢复stash@{0}
git stash pop stash@{1}
# 当我们执行git stash apply之后发现所有的文件都变成了未暂存的,如果想维持原来的样子,即暂存过的依旧是暂存状态,那么可以使用 git stash apply --index
# 删除指定存储
git stash drop # 默认删除stash@{0}
git stash drop stash@{1}
# 删除所有存储的进度
git stash clear

C、常用命令

# 查看代码版本
git remote -v
# 查看合并状态
git status
# 查看log
git log
# 显示当前的Git配置
git config --list
# 切换版本到1.9,Flink遇到过的坑,注意切换到分支而不是tag
git checkout release-1.9(不是1.9.0)
# 切换到master
git checkout master
# 合并单个commit
git cherry-pick 0437ad2fce8a064424522b4b01d3dcea55597033

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,165评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,503评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,295评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,589评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,439评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,342评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,749评论 3 387
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,397评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,700评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,740评论 2 313
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,523评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,364评论 3 314
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,755评论 3 300
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,024评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,297评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,721评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,918评论 2 336