1.创建文件夹
mkdir learngit
2.初始化learngit变为仓库
git init
3.把文件添加到仓库
git add reademe.txt 或者添加所有 git add .
4.提交到仓库
git commit -m "xxx"
5.配置用户名和e-mail地址(提交的时候要用到)
git config --global user.name "XXX"
git config --global user.email XXX
6.查看用户名和邮箱
git config user.name
git config user.email
7.修改用户名和邮箱
git config --global user.name "username"
git config --global user.email "email”
8.查看分支
git branch
9.创建分支
git branch 分支名字
10.切换分支
git checkout 分支名字
11.创建并切换分支
git checkout -b 分支名字
12.查看仓库状态
git status
13.把本地库和远程仓库进行关联
git remote add origin git@xxx.xxx.xxx.xxx:/home/git/gitserver.git
14.查看远程库
git remote -v
15.从远程git仓库拉下代码到本地(master分支)
git pull origin master
16.把本地内容推送到远程git仓库(推送到master分支)
git push origin master
17.回退到当前版本,HEAD指向当前版本
git reset --hard HEAD
说明:如果你修改了一些代码,想去除,就可以用git reset --hard HEAD一次性去除。
18.回退到上一个版本
git reset --hard HEAD^
19.回退到固定版本
git reset --hard commit_id
说明:commit_id是历史版本id
20.一键拉取本地上不存在的远程分支
1、获取远程分支列表
git fetch
2、查看所有分支
使用 git branch -a 命令查看所有的分支,包括本地和远程的分支。
git branch -a
你会看到类似以下的输出:
* main
remotes/origin/main
remotes/origin/feature-branch
3、创建并切换到远程分支
git checkout -b new_branch origin/new_branch
21.push到远程git不存在的分支,比如:dev分支
git branch dev
git push origin dev
22.删除本地分支
git branch -d 分支名称
23.删除远程分支
git push origin --delete 分支名称
24.从远程仓库克隆
git clone git@xxx.xxx.xxx.xxx:/home/git/gitserver.git
说明:
(1)xxx.xxx.xxx.xxx为你服务器地址。
(2)/home/git/gitserver.git为你的路径
25.从远程仓库克隆(指定分支)
git clone -b dev git@xxx.xxx.xxx.xxx:/home/git/gitserver.git
从远程的dev分支克隆。
26.push指定的commit内容
1.查看commit记录
git log
2.push指定的commit
比如我想push上面的第二条commit
git push origin 3c35d001c855b55fa7b7074266601dc99a9dc1b9:master
其中master指远程仓库的master分支。
27.回退到指定的版本
步骤
1、查看 reflog
使用 git reflog 查看最近的操作记录:
git reflog
你会看到类似下面的输出:
abcdef1 (HEAD -> main) HEAD@{0}: reset: moving to HEAD^
1234567 HEAD@{1}: commit: Add new feature
abcdef1 HEAD@{2}: commit: Fix bug
在这个例子中,1234567 是你之前的提交。
回到之前的版本
使用 git reset --hard 回到你想要的提交(1234567):
git reset --hard 1234567
28.git stash的应用
应用场景:
1 当正在dev分支上开发某个项目,这时项目中出现一个bug,需要紧急修复,但是正在开发的内容只是完成一半,还不想提交,这时可以用git stash命令将修改的内容保存至堆栈区,然后顺利切换到hotfix分支进行bug修复,修复完成后,再次切回到dev分支,从堆栈中恢复刚刚保存的内容。
2 由于疏忽,本应该在dev分支开发的内容,却在master上进行了开发,需要重新切回到dev分支上进行开发,可以用git stash将内容保存至堆栈中,切回到dev分支后,再次恢复内容即可。
总的来说,git stash命令的作用就是将目前还不想提交的但是已经修改的内容进行保存至堆栈中,后续可以在某个分支上恢复出堆栈中的内容。这也就是说,stash中的内容不仅仅可以恢复到原先开发的分支,也可以恢复到其他任意指定的分支上。git stash作用的范围包括工作区和暂存区中的内容,也就是说没有提交的内容都会保存至堆栈中。
命令详解:
(1)git stash
能够将所有未提交的修改(工作区和暂存区)保存至堆栈中,用于后续恢复当前工作目录。
(2) git stash save “xxx”
作用等同于git stash,区别是可以加一些注释,如下:
git stash的效果:
stash@{0}: WIP on master: b2f489c second
git stash save “test1”的效果:
stash@{0}: On master: test1
(3) git stash list
查看当前stash中的内容
(4) git stash pop
将当前stash中的内容弹出,并应用到当前分支对应的工作目录上。
注:该命令将堆栈中最近保存的内容删除(栈是先进后出)
顺序执行git stash save “test1”和git stash save “test2”命令,效果如下:
$ git stash list
stash@{0}: On master: test2
stash@{1}: On master: test1
$ git stash pop
On branch master
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: src/main/java/com/wy/StringTest.java
no changes added to commit (use "git add" and/or "git commit -a")
Dropped refs/stash@{0} (afc530377eacd4e80552d7ab1dad7234edf0145d)
$ git stash list
stash@{0}: On master: test1
可见,test2的stash是首先pop出来的。
如果从stash中恢复的内容和当前目录中的内容发生了冲突,也就是说,恢复的内容和当前目录修改了同一行的数据,那么会提示报错,需要解决冲突,可以通过创建新的分支来解决冲突。
(5) git stash apply
将堆栈中的内容应用到当前目录,不同于git stash pop,该命令不会将内容从堆栈中删除,也就说该命令能够将堆栈的内容多次应用到工作目录中,适应于多个分支的情况。
$ git stash apply
On branch master
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: src/main/java/com/wy/StringTest.java
no changes added to commit (use "git add" and/or "git commit -a")
$ git stash list
stash@{0}: On master: test2
stash@{1}: On master: test1
堆栈中的内容并没有删除。
可以使用git stash apply + stash名字(如stash@{1})指定恢复哪个stash到当前的工作目录。
(6) git stash drop + 名称
从堆栈中移除某个指定的stash
(7) git stash clear
清除堆栈中的所有 内容
(8) git stash branch
从最新的stash创建分支。
应用场景:当储藏了部分工作,暂时不去理会,继续在当前分支进行开发,后续想将stash中的内容恢复到当前工作目录时,如果是针对同一个文件的修改(即便不是同行数据),那么可能会发生冲突,恢复失败,这里通过创建新的分支来解决。可以用于解决stash中的内容和当前目录的内容发生冲突的情景。
发生冲突时,需手动解决冲突。
29.git merge 应用
比如我们在本地的dev分支进行代码开发,然后需要合并到master分支上:
1.git checkout dev
2.git pull origin dev
3.git checkout master
4.git merge dev
最后推送到远程的master分支上:git push origin master
30.git从主库同步到fork库
(1) 本地从fork库clone
git clone fork库地址
(2)添加主库地址
git remote add upstream 主库git地址
(3)更新主库
git fetch upstream
(4)切换fork库到指定分支,比如master
git checkout master
(5)将主库指定的分支合入到当前fork库分支,比如将主库master分支合入当前分支:
git merge upstream/master
注:
(1) "upstream"就是fork的远程库的名字,可以通过git remote -v 查看。
(2)要注意你当前git库是主库还是fork的库,比如要是主库,那git merge upstream/master 就是从主库的master同步fork库的master分支,但要是当前是fork库,那就是从fork库同步主库了,这个一定要分清楚,不要搞混了。