一、简介
对照下图细细品味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