We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
查看我们设置的一些命令
cat .bashrc
编辑
vi .bashrc
配置一些别名
alias ga="git add"
重新reload一下会生效
source .bash_profile
查看配置了哪些别名
alias
open source version control software
cd ~ la cat .gitconfig
或者
git config --list
git config --global user.name "fang.yang" git config --global user.email [email protected]
git config user.name git config user.email
当前目录使用git来进行管理,在当前文件夹下执行
git init
查看
cd .git la
git mv <from_file> <to_file>
data:image/s3,"s3://crabby-images/3e778/3e7783ecd67d6893d4334bee77400b97ec8d2ffb" alt=""
与以下3条命令效果一样:
mv README.md README git rm README.md git add README
data:image/s3,"s3://crabby-images/e7aad/e7aad1fe73ce2534abe6f58dc73e6393f03397a5" alt=""
// 查看所有记录信息 git log // 添加数字查看最近 n 条 git log -2 // 添加 --stat 查看被修改过的文件情况 git log --stat -2 // 查看某个人的提交 git log --author=** // 其余可配置,但是不常用的 git log --[since, after, until, before, ...]=**
data:image/s3,"s3://crabby-images/ce7c4/ce7c4b4b2e24aaa3727ad9f7c3890cfbf2d86ed6" alt=""
// 文件add以后,执行reset可以取消暂存,只会影响暂存区 git reset HEAD <filename> // commit之后发现msg错误或者忘记提交有些文件,使用合并提交 git commit --amend // 危险命令:修改了文件,确定不想要了,使用 checkout 恢复为上一次提交的文件状态 git checkout -- <file>
// 查看远程仓库简写 git remote // clone一个仓库,会自动添加 origin 为remote-name的简写 // 参数 -v 显示远程仓库的 url git remote -v // 添加 git remote add <remote-name> <url> // 同步远程仓库 git fetch <remote-name> // 从远程分支更新代码 git pull [remote-name] [branch-name] // 为远程分支推送代码 git push [remote-name] [branch-name]
data:image/s3,"s3://crabby-images/90b2a/90b2ac070a6eb7de7b7b497d32d96f7a17c38424" alt=""
这块的origin与master分支一样,都是git默认生成的,与其他分支或者名称一样,没有什么特殊意义。
origin
master
git
// 显示所有的tag git tag // 新建一个tag git tag -a <tag-name> -m "tag info" // 显示某个tag信息 git show <tag-name> // 将当前tag推送到远程 git push origin <tag-name> // 删除本地的tag git tag -d <tag-name> // 危险:删除远程tag git push origin :refs/tags/<tag-name>
// 查看本地所有branch git branch // 查看所有分支和它的最后一次提交 git branch -v // 新建分支 git branch <branch-name> // 切换到新建的分支 git checkout <branch-name> // 新建分支、并且切换到当前分支 git checkout -b <branch-name> // 推送到远程 git push origin <branch-name> // 强制删除本地分支 git branch -D <branch-name> // 删除远程分支 git push origin --delete <branch-name> // 查看更多的分支信息 git branch -vv // behind 2 落后于远程分支2条commit // ahead 3 本地有2条commit没有push到远程上 // test 未跟踪任何远程分支 // feature/form 代表和远程一样
git branch -vv截图
data:image/s3,"s3://crabby-images/3182d/3182de1d23e701866fe168cfa6de05ff62596ea9" alt=""
git 删除远程分支截图
data:image/s3,"s3://crabby-images/3a948/3a94895650b51a15be3fb95dc14cb68e369e9395" alt=""
临时存储一些代码,正在开发的功能做了一半,需要切换分支,有的代码还在报错,没有通过eslint校验,因此commit是不能解决这个问题的,当然在这种情况下commit 代码是非常不合理的做法,因此可以使用git stash。
eslint
commit
git stash
// 查看状态 git status // 使用stash命令 git stash git stash save // 查看存储的代码 git stash list // 重新应用stash的某一个,如果不添加stash-name,默认是最近的一条 git stash apply <stash-name> // 应用完以后从栈上删除 git stash drop <stash-name> // 直接应用并且删除它 git stash pop
将两个分支最新的提交与二者最近的共同的祖先进行三方合并,合并的结果生成一个新的记录并且提交。
找到这两个分支最近的共同祖先,然后对比当前分支相对于祖先的历次提交,提取相应的修改存为临时文件,将当前分支的目标基底指向最新的提交,然后将存储的临时文件的修改依次应用,这块产生的是新的commit,而不是原来的。
如果其余小伙伴需要更新代码,一定要使用git pull --rebase 而不是git pull。
效果都是一致的,将代码更新到最新,合并所有的提交。
rebase是将一系列提交按照原有次序依次应用到另一分支上,而合并是把最终结果合在一起。
rebase
之前发现有的同学并不会使用或者不知道有stash这个命令的存在,因此不断在自己的分支上面commit代码,这样造成最后的最后一个小小的功能产生非常多的commit记录,也有可能commit到最后都不知道填写什么message信息,因此出现非常多的又没有什么意义的commit记录,不便于后期问题的追踪与记录。
stash
message
在内部项目中这么做其实也没什么关系,如果去开源社区提交一个pr,作者如果看到你这样的commit信息会觉得你非常不专业,可能都不会去看你的代码。
pr
提交历史更加整洁,有时候merge产生的commit记录对于我来说是毫无意义的。虽然实际上我们的开发是异步的,但是历史提交记 录看起来是一条直线,没有分叉,看起来像同步的效果一样。强迫症患者推荐使用此种方式 🙈🙈🙈
merge
// clone git clone // 更新代码 git pull origin // status git status git status -s // 添加文件到 staging area git add // 添加msg信息 git commit -m "commit message" // 更新repo git push origin // 同步远程仓库信息 git fetch --all
git fetch 只是从远程拉取本地没有的代码,不会修改工作目录中的内容。
git fetch
git pull会拉取最新的数据,并且合并到当前分支。相当于git fetch命令执行完紧接着执行了一条git merge命令。
git pull
git merge
The text was updated successfully, but these errors were encountered:
No branches or pull requests
说在前面:设置一些常用的别名
查看我们设置的一些命令
编辑
配置一些别名
重新reload一下会生效
source .bash_profile
查看配置了哪些别名
alias
git 与 github 什么关系?
git
github
配置信息
查看自己当前全局的配置
或者
常用设置name和email
查看当前设置是否生效
git基础
当前目录使用git来进行管理,在当前文件夹下执行
查看
data:image/s3,"s3://crabby-images/3092f/3092f7d515e86c27990feb302f42bf7f05d9168c" alt=""
重命名文件 mv
data:image/s3,"s3://crabby-images/3e778/3e7783ecd67d6893d4334bee77400b97ec8d2ffb" alt=""
与以下3条命令效果一样:
data:image/s3,"s3://crabby-images/e7aad/e7aad1fe73ce2534abe6f58dc73e6393f03397a5" alt=""
查看记录日志 log
data:image/s3,"s3://crabby-images/ce7c4/ce7c4b4b2e24aaa3727ad9f7c3890cfbf2d86ed6" alt=""
撤销操作
远程仓库的使用
data:image/s3,"s3://crabby-images/90b2a/90b2ac070a6eb7de7b7b497d32d96f7a17c38424" alt=""
标签管理 tag
分支管理 branch
git branch -vv截图
data:image/s3,"s3://crabby-images/3182d/3182de1d23e701866fe168cfa6de05ff62596ea9" alt=""
git 删除远程分支截图
data:image/s3,"s3://crabby-images/3a948/3a94895650b51a15be3fb95dc14cb68e369e9395" alt=""
暂存文件 stash
临时存储一些代码,正在开发的功能做了一半,需要切换分支,有的代码还在报错,没有通过
eslint
校验,因此commit
是不能解决这个问题的,当然在这种情况下commit
代码是非常不合理的做法,因此可以使用git stash
。merge 与 rebase
merge
将两个分支最新的提交与二者最近的共同的祖先进行三方合并,合并的结果生成一个新的记录并且提交。
rebase
找到这两个分支最近的共同祖先,然后对比当前分支相对于祖先的历次提交,提取相应的修改存为临时文件,将当前分支的目标基底指向最新的提交,然后将存储的临时文件的修改依次应用,这块产生的是新的
commit
,而不是原来的。如果其余小伙伴需要更新代码,一定要使用git pull --rebase 而不是git pull。
相同
效果都是一致的,将代码更新到最新,合并所有的提交。
不同
rebase
是将一系列提交按照原有次序依次应用到另一分支上,而合并是把最终结果合在一起。为什么 使用
rebase
?之前发现有的同学并不会使用或者不知道有
stash
这个命令的存在,因此不断在自己的分支上面commit
代码,这样造成最后的最后一个小小的功能产生非常多的commit
记录,也有可能commit
到最后都不知道填写什么message
信息,因此出现非常多的又没有什么意义的commit记录,不便于后期问题的追踪与记录。在内部项目中这么做其实也没什么关系,如果去开源社区提交一个
pr
,作者如果看到你这样的commit
信息会觉得你非常不专业,可能都不会去看你的代码。我偏爱rebase的原因
提交历史更加整洁,有时候
merge
产生的commit
记录对于我来说是毫无意义的。虽然实际上我们的开发是异步的,但是历史提交记 录看起来是一条直线,没有分叉,看起来像同步的效果一样。强迫症患者推荐使用此种方式 🙈🙈🙈常用的 git 命令
git pull 与 git fetch 区别
git fetch
只是从远程拉取本地没有的代码,不会修改工作目录中的内容。git pull
会拉取最新的数据,并且合并到当前分支。相当于git fetch
命令执行完紧接着执行了一条git merge
命令。The text was updated successfully, but these errors were encountered: