记录一下git常用操作
设置user的name和email
- 设置name:
$ git config --global user.name "YourUserName"
- 设置email:
git config --global user.email "YourUserName@email.com"
生成ssh秘钥
- 进入.ssh文件夹:
cd ~/.ssh
- 生成秘钥:
$ ssh-keygen -t rsa -C “YourUserName@email.com”
, 连按三个回车,密码这会设置为空 - 创建秘钥后会生成两个文件id_rsa和id_rsa.pub,将*.pub文件打开并且复制内容到github或者gitlab的ssh配置上
获取远程仓库源码
- 获取本机上的远程代码
- 指定文件:
git init
- 输出当前文件夹路径并复制在粘贴板:
pwd | pbcopy
(pbcopy是oxs系统命令) - 在此仓库外的文件夹克隆:
git clone repositoryUrl
- 指定文件:
- 获取github或gitlab上的代码:
git clone https://github.com/Zooc/androidzoo.git
各种常用操作
- 分支操作
- 浏览所有分支,包含线上的:
git branch -a
, 没有-a
这只浏览本地所有分支 - 从本地创建分支:
git branch kenny
- 创建远程分支,在kenny分支下,进行推送:
git push origin kenny
- 删除本地分支:
git branch -D kenny
- 删除远程分支:
git push origin :kenny
- 浏览所有分支,包含线上的:
- 切换操作
- 切换分支:
git checkout kenny
,如果该分支是本地没有,而线上有的话,那么本地分支和线上分支会有联系,例如如果本地比对应的远程分支多几个commit,使用git status
会有提示可以推送。 - 切换到某个tag,并建立新分支:
git checkout -b new_branch_name tag_name
。更多切换操作
- 切换分支:
- 添加操作
- 添加当前所有文件:
git add .
- 添加所有:
git addd -A
- 添加当前所有文件:
- 提交操作
- 向本地仓库提交:
git commit -m "commit info description"
- 修改commit信息:
git commit --amend
- 向本地仓库提交:
- 融合操作
- 融合开发分支:
git merge develop
- 融合开发分支:
- 推送操作
- 向对应的分支推送:
git push origin kenny
- 向对应的分支推送:
- 拉取操作
- 从对应的分支拉取:
git pull origin kenny
- 从对应的分支拉取:
- 回滚操作
- 回滚到commit-id(将commit-id之后提交的commit都去除):
git reset --hard commit-id
- 将最近n次的提交回滚:
git reset --hard HEAD~n
- 远程代码回滚:
- 拉取远程代码:
git checkout kenny
- 本地回滚:
git reset --hard theCommitId
- 删除远程分支:
git push origin :kenny
- 重新push本地分支:
git push origin kenny
- 拉取远程代码:
- 回滚到commit-id(将commit-id之后提交的commit都去除):
- 暂存操作:
- 暂存当前状态(不建议,最好加上命名):
git stash
- 暂存命名:
git stash save "kenny status"
- 查询暂存列表:
git stash list
- 弹出暂存列表最上面的一个状态:
git stash pop
- 清除暂存:
git stash clear
- 恢复指定角标的暂存,可以多次恢复:
git stash apply stash@{0}
-
查看缓存时间:
git stash list --date=relative
git stash list --date= short
git stash list --date= local
- 暂存当前状态(不建议,最好加上命名):
- 查询操作
- 查看log:
git log --graph --decorate --pretty=oneline --abbrev-commit
- 查看最近一次修改的内容:
git log -n 1 --stat
- 查看本地所有的提交记录:
git reflog
- 查看git别名:
git config --list | grep alias
- 取消别名:
git config --global --unset alias.br
- 查看log:
- 标签操作
- 打标签:
git tag -a V100 -m "Release version 1.0.0"
- 以某个commit id为标记打标签:
git tag -a V100 commit_id -m "Release version 1.0.0"
- 提交标签到远程服务器:
git push origin --tags
- 删除标签:
git tag -d V100
- 删除远端服务器的标签:
git push origin :refs/tags/V100
- 查看tag 及其注释:
git tag -l -n
- 打标签:
其他操作
- Github fork 项目后代码同步
- 首先将自己的fork的项目clone到本地:
git clone https://github.com/kenny/kgit.git
- 在自己的项目里面,添加一个远程连接到本地,命名为
kgit
:git remote add kgit https://github.com/kenny/kgit.git
- 从远程分支拉去代码到本地(master可以替换为其他分支名称,因为有些项目master是没有代码的):
git pull kgit master
- 推送到自己的库里面:
git push
- 首先将自己的fork的项目clone到本地:
- 清除掉已提交但是需要忽略的文件,对于文件夹,第一个命令还需要再文件夹前增加 -r 参数:
git rm --cached logs/xx.log
- 更新 .gitignore 忽略掉目标文件
git commit -m "We really don't want Git to track this anymore!"
- 查看远程仓库地址:
git remote -v
其他
- 全局设置
- 将crlf的提示信息关闭:
git config --global core.autocrlf false
- 将crlf的提示信息关闭:
- 设置别名
git config --global alias.cm commit
git config --global alias.br branch
git config --global alias.co checkout
git config --global alias.lg "log --pretty=oneline --abbrev-commit"
git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) &C(bold blue)<%an>%Creset' --abbrev-commit"
- 同时管理多个ssh私钥
常见问题
- 当出现
HEAD detached at ******
时,表明你已经不再任何一个分支上了,如果想要重回某个分支,需要再checkout一次,git checkout master
。Fix a Git detached head? - 切换错误分支了,而且是一个非常久的分支,并且在切换到一半的过程中撤销了,从而导致删除了部分jar,出现了以下错误(做任何其他操作时):
/.git/index.lock': File exists.
- 删除掉 index.lock文件,以便可以做其他操作:
rm -f ./.git/index.lock
- 恢复提交前的文件状态:
git checkout .
- 删除掉 index.lock文件,以便可以做其他操作:
- 修复Mac下命令行Git无法在vi中commit的错误-- here was a problem with the editor 'vi'.
- windows下的中文乱码问题解决办法:Windows下Git Bash中文乱码