Git和GitHub的使用

2019-12-25  本文已影响0人  爱吃油果子

一、简介

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


Git架构

二、环境准备(略过)

整体思路:

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

三、常用命令行

A、新建命令:

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

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
git remote add origin https://github.com/storyxiao/annotation-project.git 
# 一般会要求先拉取远程仓库代码才可以提交
# git pull origin master 或 git pull 
git push -u origin master

方法一:备份本地代码,重新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、操作命令:

对于复杂操作如:合并、删除、对比等,个人觉得命令行始终不方便,
在IDE工具中操作比较好,或下载客户端

# 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
# 常用-将当前目录所有修改添加到暂存区(不包括忽略文件):
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
 # 提交所有改动并写提交日志:
 git commit -m "<改动日志说明>"
# 取回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
# 工作分支的切换
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 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

上一篇下一篇

猜你喜欢

热点阅读