git 命令

本地仓库操作

1. git config 配置

git config命令的–global参数,用了这个参数,表示你这台机器上所有的Git仓库都会使用这个配置。

//使用方法:
$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"
2. git init 创建版本库

创建一个版本库,里面的所有文件都可以被git管理起来,每个文件的修改、删除,git都能跟踪,以便任何时刻都可以追踪历史,或者将来某个时刻“还原”。

//使用方法:
$ mkdir learngit	//创建一个目录
$ cd learngit	//进入到该目录
$ pwd	//显示当前目录
/Users/blue/zhangmeng
$ git init	//创建一个git仓库(目录下多了一个 .git 目录,用来跟踪管理版本库,默认隐藏)
$ ls -ah	//查看当前目录下文件和文件夹(包括隐藏文件和文件夹)
3.git add 添加文件到暂存区(stage)

git add < file/files >
添加文件到暂存区(stage),可反复多次使用,添加多个文件。

$ git add file1.txt
$ git add file2.txt file3.txt

git add命令实际上就是把要提交的所有修改放到暂存区(Stage)。

如果错误的添加到了暂存区,可以通过 git checkout --file 可以将暂存区文件删除并放回到工作区。

4.git commit 提交文件到git仓库

git commit
展示所有提交的文件(展开后命令行输入 i 后,填写附带的提交信息,输入完毕后 esc 并在命令行输入 :wq 保存并退出)。

git commit -m < message >
提交文件并附带信息。

$ git commit  //展示所有提交的文件
$ git commit -m < message >

执行git commit就可以一次性把暂存区的所有修改提交到分支。
如果不用git add到暂存区,那就不会加入到commit中。

5.git status 仓库当前状态

git status
展示仓库当前状态,可以查看是否有未提交的文件。

// add 前 git status 会展示修改过尚未 add 的文件
$ git status

On branch master
Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git restore <file>..." to discard changes in working directory)
  
	modified:   readme.txt	//未提交文件

no changes added to commit (use "git add" and/or "git commit -a")

// add 后 commit 前 git status 会展示 add 过尚未 commit 的文件
$ git status

On branch master
Changes to be committed:
  (use "git reset HEAD <file>..." to unstage)

	modified:   readme.txt

// commit 后 git status 会展示没有修改过的文件待提交
$ git status

On branch master
nothing to commit, working tree clean
6.git diff 查看difference

git diff < file >
查看文件具体做了哪些修改。

git diff HEAD --< file >
查看该文件在工作区和版本库里面最新版本的区别。

$ git diff readme.txt

diff --git a/readme.txt b/readme.txt
index 46d49bf..9247db6 100644
--- a/readme.txt
+++ b/readme.txt
@@ -1,2 +1,2 @@
-Git is a version control system.
+Git is a distributed version control system.
 Git is free software.
7.git log 查看提交历史

git log
查看最近到最远的提交日志。
git log --pretty=oneline
查看最近到最远的提交日志的简写版。

8.git reset 设置/回退版本

git reset HEAD < file >
把暂存区的修改撤销掉(unstage),重新放回工作区。

适用场景:改乱了工作区某个文件的内容,还添加到了暂存区,想丢弃修改。

git reset --hard HEAD^
回退到上一个版本。

适用场景:已经提交了不合适的版本,想要撤销提交回退上一版本。

git reset --hard < commit_id >
回退到指定 commit_id 版本。

适用场景:选择指定的版本号跳转。

注意:在git中,HEAD表示当前版本,上个版本就是HEAD^ ,上上个版本是 HEAD ^^,上100个版本 HEAD~100。

9.git reflog 查看命令历史

git reflog
记录每一次命令。当出现回退版本之后想回到回退之前的版本但又查不到 commit_id 时,可以使用这个命令,会展示出每一次命令并携带版本号。

$ git reflog

e475afc HEAD@{1}: reset: moving to HEAD^
1094adb (HEAD -> master) HEAD@{2}: commit: append GPL
e475afc HEAD@{3}: commit: add distributed
eaadf4e HEAD@{4}: commit (initial): wrote a readme file
10.git rm 删除文件

git rm < file >
将删除文件的操作添加到暂存区(stage)。

适用场景: 当手动或使用命令行 rm 文件之后,需要将本次删除操作添加到暂存区。

git rm 与 git add 作用类似,只是为删除操作,故也可以使用 git checkout --file 来将误删的文件放回到工作区。

$ git rm test.txt

rm 'test.txt'

注意:命令git rm用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。

git rm -r --cached .
这个命令将移除当前文件夹下所有文件/文件夹的 Git 缓存版本。运行这个命令后,会看到所有文件中都显示在 git changes中。

git add --all .
重新添加所有文件,仅显示有更改的文件

以上两个命令解决windows不区分大小写问题,rename生效。

远程仓库操作

1.创建 ssh key
$ ssh-keygen -t rsa -C "youremail@example.com"

将 id_rsa.pub文件里的内容添加到远程仓库平台 ssh key 中,该电脑就可以操作远程仓库了。

2.git clone 克隆远程仓库到本地

git clone … .git
克隆远程仓库到本地。

Git支持多种协议,包括https,但通过ssh支持的原生git协议速度最快。

$ git clone git@github.com:Samsara/gitskills.git

Cloning into 'gitskills'...
remote: Counting objects: 3, done.
remote: Total 3 (delta 0), reused 0 (delta 0), pack-reused 3
Receiving objects: 100% (3/3), done.
3.git remote 远程仓库操作

git remote add origin … .git
关联一个远程仓库。

git remote add origin git@server-name:path/repo-name.git

git remote
查看远程仓库信息。

git remote -v
查看远程仓库更详细信息。

git remote show origin
查看远程仓库信息。

git remote update
查看远程仓库更新信息

git remote rm origin
移除当前关联的远程仓库

$ git remote

origin

$ git remote -v

origin  git@github.com:SamsaraBlue/zhangmeng.git (fetch)
origin  git@github.com:SamsaraBlue/zhangmeng.git(push)

显示了可以抓取和推送的origin的地址。如果没有推送权限,就看不到push的地址。

4.git pull 远程仓库下拉

git pull
将远程仓库的文件下拉到本地仓库中(如果有冲突,要先处理冲突)。

git pull origin master --allow-unrelated-histories
允许不相关历史提,强制合并

问题:本地仓库和Github上关联以后,发现git pull,git feach
提醒:fatal: refusing to merge unrelated histories

原因: 两个分支是两个不同的版本,具有不同的提交历史

5.git push 推送到远程仓库

git push -u origin master
第一次推送master分支的所有内容。

git push origin master
推送本地仓库最新修改。

git push origin < branch-name >
推送本地仓库到远程分支。

git push -f origin master
强制推送本地仓库到远程仓库(不建议使用)。

6.git fetch 远程仓库更新

git fetch
远程仓库更新了新的分支,本地需要更新一下远程仓库的信息。

分支

1.git branch 查看/创建分支

git branch
列出所有分支分支。当前分支前面会标一个*号。

git branch < name >
创建指定名称分支。

git branch -d < name >
删除指定分支。

git branch -D < name >
强行删除未合并分支。

git branch --set-upstream < branch-name > origin/< branch-name >
建立本地分支和远程分支的关联。

//列出所有分支
$ git branch

* dev
  master

//删除指定分支
$ git branch -d dev

Deleted branch dev (was b17d20e).
2.git checkout 切换/创建分支

git checkout < name >
切换到指定分支。

git checkout -b < name >
创建并且切换分支。

git checkout -b < branch-name > origin/< branch-name >
在本地创建和远程分支对应的分支(本地和远程分支的名称最好一致)。

git checkout --< file > (已废弃)
撤销修改,将加入暂存区的指定文件从暂存区移除,并且放回工作区(删除也可)。

git restore < file >
撤销修改,将加入暂存区的指定文件从暂存区移除,并且放回工作区(删除也可)。

$ git checkout -b dev

Switched to a new branch 'dev'

//等价于
$ git branch dev
$ git checkout dev

Switched to branch 'dev'
3.git switch 切换/创建分支(新版本)

git switch < name >
切换到指定分支。

git switch -c < name >
创建并且切换分支。

$ git switch -c dev

//等价于
$ git branch dev
$ git switch dev
4.git merge 合并分支

git merge < name >
合并指定分支到当前分支。

git merge --no-ff < name >
强制禁用Fast forward模式。Git会在merge时生成一个新的commit,从分支历史上就可以看出分支信息。

$ git merge dev

Updating d46f35e..b17d20e
Fast-forward
 readme.txt | 1 +
 1 file changed, 1 insertion(+)

$ git merge --no-ff -m "commit message" dev

Merge made by the 'recursive' strategy.
 readme.txt | 1 +
 1 file changed, 1 insertion(+)

Fast-forward信息:“快进模式”–直接把master指向dev的当前提交,合并速度快。

5.git stash 隐藏/恢复工作区

git stash
将当前工作区修改隐藏。

适用场景:手中工作未完成不想丢失工作进度且要穿插修改bug,可以先隐藏,拉分支修改bug,后再恢复。

git stash list
查看隐藏区域列表。

git stash apply
恢复先前工作场景,恢复后,stash 内容并不删除。

git stash drop
删除 stash 内容。

git stash pop
恢复先前工作场景,恢复后,stash 内容删除。

//隐藏当前工作区
$ git stash

Saved working directory and index state WIP on dev: f52c633 add merge

//展示隐藏的工作区列表
$ git stash list

stash@{0}: WIP on dev: f52c633 add merge

//恢复工作区同时删除 stash 内容
$ git stash pop
On branch dev
Changes to be committed:
  (use "git reset HEAD <file>..." to unstage)

	new file:   hello.py

Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git checkout -- <file>..." to discard changes in working directory)

	modified:   readme.txt

Dropped refs/stash@{0} (5d677e2ee266f39ea296182fb2354265b91b3b2a)

使用者可以选择在暂存之后拉分支修改bug 也可以选择在当前分支修改bug。

6.git cherry-pick 复制一个提交到当前分支

git cherry-pick < commit_id >
复制指定的提交版本号的提交内容到当前分支。

$ git cherry-pick 4c805e2

[master 1d4b803] fix bug 101
 1 file changed, 1 insertion(+), 1 deletion(-)
7.git rebase 把本地未push的分叉提交历史整理成直线

git rebase
把本地未push的分叉提交历史整理成直线。rebase的目的是使得我们在查看历史提交的变化时更容易,因为分叉的提交需要三方对比

git rebase 主分支名称
将自己的分支rebase到最新的主分支。

8.git tag 创建标签

git tag
查看所有标签。

git tag < tagname >
新建一个标签,默认为HEAD,也可以指定一个commit_id。

git tag -a < tagname > -m < message >
指定标签信息。

git show < tagname >
查看标签信息。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值