Git Tips
一些使用技巧和笔记笔记,记录一些 git 常用和一些记不住的命令,这个笔记原本是基于 颜海镜的文章增加的,后面慢慢增加了许多内容,独立一个仓库维护,方便查询和使用。
目录
- 入门备忘清单
- 安装卸载
- 配置管理
- 不常见的使用场景
- 忽略文件的权限变化
- 设置大小写敏感
- 配置自动换行
- 创建SSH密钥
- 多账号ssh配置
- 免密码登录远程服务器
- https协议下提交代码免密码
- 文件推向3个git库
- 修改远程仓库地址
- 撤销远程记录
- 放弃本地的文件修改
- 最简单放弃本地修改内容
- 回退到某一个版本
- 搜索 commit 历史记录
- 回滚到某个commit提交
- 去掉某个commit
- 把 A 分支的某一个 commit,放到 B 分支上
- 获取最近一次提交的 commit id
- 两个 git 仓库合并
- 合并多个commit
- 修改远程Commit记录
- 利用commit关闭一个issue
- 新建一个空分支
- 添加忽略文件
- 忽略某个文件的改动
- 同步fork的上游仓库
- 手动合并冲突的 Pull Request
- 修改作者名
- 批量修改历史commit中的名字和邮箱
- 查看两个星期内的改动
- 查看某个文件历史
- 查看git仓库中最近修改的分支
- 更新所有本地分支
- 打造自己的git命令
- 删除已经合并到 master 的分支
- 中文乱码的解决方案
- 提交一个空文件夹
- 新建仓库
- clone
- 本地
- 分支branch
- 远端
- submodule
- 删除文件
- remote
- 标签tag
- 日志log
- 重写历史
- 其它
- 报错问题解决
- 参考资料
安装卸载
官方教程,在 Linux/Unix 系统中,通过工具在中安装 git
,这种方式比较简单,便于升级卸载工具。
下面介绍在 CentOS 系统中,通过 yum 来安装 git
Red Hat Enterprise Linux, Oracle Linux, CentOS, Scientific Linux, et al. RHEL and derivatives typically ship older versions of git. You can download a tarball and build from source, or use a 3rd-party repository such as the IUS Community Project to obtain a more recent version of git.
官方文档说 git 在 RHEL
和衍生产品通常都会发布旧版本的 git
,我们需要源码编译安装,或者使用第三方存储库(如IUS社区项目)。
现在我们通过,IUS社区下载 ius-release.rpm 文件进行安装
# 注意下载不同的版本,本机 CentOS 7
wget https://centos7.iuscommunity.org/ius-release.rpm
# 安装rpm文件
rpm -ivh ius-release.rpm
查看可安装的git安装包
repoquery --whatprovides git
# git-0:1.8.3.1-13.el7.x86_64
# git2u-0:2.16.5-1.ius.centos7.x86_64
# git2u-0:2.16.2-1.ius.centos7.x86_64
# git2u-0:2.16.4-1.ius.centos7.x86_64
# git-0:1.8.3.1-14.el7_5.x86_64
yum 卸载 git 安装新版本
卸载 1.8.3
的 git
,安装 2.16.5
的 git
# 卸载老的版本
yum remove git
# 安装新的版本
yum install git2u
配置管理
首先是配置帐号信息 ssh -T git@github.com
测试。
git help config # 获取帮助信息,查看修改个人信息的参数
git config --list # 查看配置的信息
git config --global user.name "小弟调调" # 修改全局名字
git config --global user.email "wowohoo@qq.com" # 修改全局邮箱
git config --global --unset <entry-name> # 删除全局设置
不常见的使用场景
忽略文件的权限变化
不再将文件的权限变化视作改动
git config core.fileMode false
设置大小写敏感
git config --get core.ignorecase # 查看git 的设置
git config core.ignorecase false # 设置大小写敏感
git rm -r --cached <目录/文件> # 远程有俩相同目录,通过这种方式清除掉,然后提交记录
配置自动换行
自动转换坑太大,提交到git是自动将换行符转换为lf
git config --global core.autocrlf input
创建SSH密钥
这个密钥用来跟 github 通信,在本地终端里生成然后上传到 github
ssh-keygen -t rsa -C 'wowohoo@qq.com' # 生成密钥
ssh-keygen -t rsa -C "wowohoo@qq.com" -f ~/.ssh/ww_rsa # 指定生成目录文件名字
ssh -T git@github.com # 测试是否成功
多账号ssh配置
1.生成指定名字的密钥
ssh-keygen -t rsa -C "邮箱地址" -f ~/.ssh/jslite_rsa
会生成 jslite_rsa
和 jslite_rsa.pub
这两个文件
2.密钥复制到托管平台上
vim ~/.ssh/jslite_rsa.pub
打开公钥文件 jslite_rsa.pub
,并把内容复制至代码托管平台上
3.修改config文件
vim ~/.ssh/config
#修改config文件,如果没有创建 config
Host jslite.github.com
HostName github.com
User git
IdentityFile ~/.ssh/jslite_rsa
Host work.github.com
HostName github.com
# Port 服务器open-ssh端口(默认:22,默认时一般不写此行)
# PreferredAuthentications 配置登录时用什么权限认证
# publickey|password publickey|keyboard-interactive等
User git
IdentityFile ~/.ssh/work_rsa
Host
这里是个别名可以随便命名HostName
一般是网站如:git@ss.github.com:username/repo.git
填写github.com
User
通常填写git
IdentityFile
使用的公钥文件地址
4.测试
ssh -T git@jslite.github.com # `@`后面跟上定义的Host
ssh -T work.github.com # 通过别名测试
ssh -i ~/公钥文件地址 Host别名 # 如 ssh -i ~/.ssh/work_rsa work.github.com
5.使用
# 原来的写法
git clone git@github.com:<jslite的用户名>/learngit.git
# 现在的写法
git clone git@jslite.github.com:<jslite的用户名>/learngit.git
git clone git@work.github.com:<work的用户名>/learngit.git
5.注意
如果你修改了id_rsa的名字,你需要将ssh key添加到SSH agent中,如:
ssh-add ~/.ssh/jslite_rsa
ssh-add -l # 查看所有的key
ssh-add -D # 删除所有的key
ssh-add -d ~/.ssh/jslite_rsa # 删除指定的key
免密码登录远程服务器
$ ssh-keygen -t rsa -P '' -f ~/.ssh/aliyunserver.key
$ ssh-copy-id -i ~/.ssh/aliyunserver.key.pub root@192.168.182.112 # 这里需要输入密码一次
编辑 ~/.ssh/config
Host aliyun1
HostName 192.168.182.112
User root
PreferredAuthentications publickey
IdentityFile ~/.ssh/aliyunserver.key
上面配置完了,可以通过命令登录,不需要输入IP地址和密码 ssh aliyun1
https协议下提交代码免密码
git clone https://github.com/username/rep.git
通过上面方式克隆可能需要密码,解决办法:进入当前克隆的项目 vi rep/.git/config
编辑 config
, 按照下面方式修改,你就可以提交代码不用输入密码了。
[core]
repositoryformatversion = 0
filemode = true
bare = false
logallrefupdates = true
ignorecase = true
precomposeunicode = true
[remote "origin"]
- url = https://github.com/username/rep.git
+ url = https://用户名:密码@github.com/username/rep.git
fetch = +refs/heads/*:refs/remotes/origin/*
[branch "master"]
remote = origin
merge = refs/heads/master
文件推向3个git库
1. 增加3个远程库地址
git remote add origin https://github.com/JSLite/JSLite.git
git remote set-url --add origin https://gitlab.com/wang/JSLite.js.git
git remote set-url --add origin https://oschina.net/wang/JSLite.js.git
2. 删除其中一个 set-url 地址
usage: git remote set-url [--push] <name> <newurl> [<oldurl>]
or: git remote set-url --add <name> <newurl>
or: git remote set-url --delete <name> <url>
git remote set-url --delete origin https://oschina.net/wang/JSLite.js.git
3.推送代码
git push origin master
git push -f origin master # 强制推送
4.拉代码
只能拉取 origin
里的一个url地址,这个fetch-url
默认为你添加的到 origin
的第一个地址
git pull origin master
git pull --all # 获取远程所有内容包括tag
git pull origin next:master # 取回origin主机的next分支,与本地的master分支合并
git pull origin next # 远程分支是与当前分支合并
# 上面一条命令等同于下面两条命令
git fetch origin
git merge origin/next
如果远程主机删除了某个分支,默认情况下,git pull 不会在拉取远程分支的时候,删除对应的本地分支。这是为了防止,由于其他人操作了远程主机,导致git pull不知不觉删除了本地分支。
但是,你可以改变这个行为,加上参数 -p 就会在本地删除远程已经删除的分支。
$ git pull -p
#