git 笔记

Posted by YuCong on July 9, 2020

[TOC]

git笔记

Created 2020.07.09 by William Yu; Last modified: 2021.07.03-V1.3.e

Contact: windmillyucong@163.com

Copyleft! 2021 William Yu. Some rights reserved.


References

  • https://blog.csdn.net/zyw0713/article/details/80083431?utm_medium=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.nonecase&depth_1-utm_source=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.nonecase
  • https://blog.csdn.net/qq_43461877/article/details/106826294
  • https://my.oschina.net/nyankosama/blog/270546
  • https://segmentfault.com/a/1190000008209343

ch1. 基本使用

git 基本流程

1
2
3
4
5
6
7
8
9
10
11
git clone
git checkout develop
git checkout -b Feature/***

# 开发
git add .
git commit -m ""
git push <远程主机名> <本地分支名>:<远程分支名>
git push origin Feature/***:Feature/***
# 开发完之后去github提pull request
# 等 approve 然后 merge

git 添加公钥

  • https://www.jianshu.com/p/52c834781e85
  • https://blog.csdn.net/lk142500/article/details/80358941

git config

git 配置文件

1
2
3
4
cd .git/
cat config
可以修改各项配置
比如commit的创建人名与邮箱等
1
git config --local -l

git 密码保存 https://www.jianshu.com/p/3948a96cec54

1
2
3
4
5
6
7
8
9
10
11
12
13
14
1、设置记住密码(默认15分钟):
git config --global credential.helper cache

2、如果想自己设置时间,可以这样做:
git config credential.helper 'cache --timeout=3600'
这样就设置一个小时之后失效

3、长期存储密码:
git config --global credential.helper store
取消保存
git config --global credential.helper unstore

4、增加远程地址的时候带上密码也是可以的。(推荐)
http://yourname:password@git.oschina.net/name/project.git

git 清理工作空间

pull失败的时候需要清理:

1
2
3
git clean -d -f
git checkout .
git reset --hard HEAD

git lfs 大文件管理

安装

1
sudo apt-get install git-fls

使用

1
2
git fls fetch
git fls pull

git branch

创建branch
1
git branch <branch_name>

由某个commit创建branch

1
git checkout -b <branch_name>
查看所有branch
1
git branch
更改branch name branch重命名branch rename
  • https://www.jianshu.com/p/cc740394faf5
1
git branch -m <old_branch_name> <new_branch_name>
删除branch
1
git branch -d <branch_name>
删除远程分支

权限谨慎,不建议使用

1
git push --delete origin feature/auto_ota
从其它分支提取文件
1
2
git checkout [branch] -- [file name] 
# files_name可以使用相对路径

### git rebase

参数

参数: pick:正常选中 reword:选中,并且修改提交信息; edit:选中,rebase时会暂停,允许你修改这个commit(参考这里) squash:选中,会将当前commit与上一个commit合并 fixup:与squash相同,但不会保存当前commit的提交信息 exec:执行其他shell命令

合并多个commit到一个commit
  • https://www.jianshu.com/p/964de879904a
1
2
3
4
5
6
7
8
9
10
11
12
git log   查看commit id 历史

找到会被操作的(要合并,以及合并进的)commit的前一个commit的id
git rebase -i <id>

"注意":
此时 commit-id的排序是最久的在最上面

然后将要合并的commit pick改为 squash
合并进的commit pick保持不变
然后保存
然后修改commit info,保留一个即可,另外一个注释掉
合并不相邻的commit到一个commit
  • http://www.d2p.top/2019/12/23/git-rebase-i/
  1. 对于部分commit 1,2,3,4,如果要合并 不相临的commit 2和4

    img

  2. git rebase -i commit1 的hash

  3. 然后将 第2个commit 改为 squash, 并且将顺序调整到最后面,即调整到 commit4的下面。保存退出

  4. over

git rebase 的回退
  1. 如果git rebase 尚未成功,如何回退:
1
git rebase不成功可以git rebase --abort取消,
  1. git rebase 已经成功,如何回退:
1
git reflog
1
2
3
4
5
6
1f5e1d0 HEAD@{0}: rebase finished: returning to refs/heads/Feature/monitor_lucy
1f5e1d0 HEAD@{2}: rebase: frame rotate after undistort
52d0e2b HEAD@{3}: rebase: checkout develop
fd241e1 HEAD@{4}: reset: moving to fd241e1
6f045f9 HEAD@{5}: checkout: moving from 1cf2218506db4a0a7c5824f2a9020a84f84c8944 to Feature/monitor_lucy
查看rebase之前的ID为fd241e1,reset回去即可
1
git reset --hard fd241e1

git merge

merge 其他branch

一般情况下是直接将feature_dev merge到feature,

1
2
git checkout feature
git merge feature_dev
只merge文件改动到暂存区域

上述方法会将dev当中的所有commit复制到feature,如果只希望merge改动,而不commit,可以使用squash

相当于添加了所有的改动到暂存区,需要手动commit

1
2
git merge --squash feature_dev
然后编辑之后再commit即可
回退merge
1
2
git relog 查看merge前的版本号
git reset --hard [merge前的版本号]  版本号是前面7个字符就可以了
merge 一部分 commit

如果只希望merge其他branch的一部分commit,使用 cherry-pick

1
2
3
4
先去要被merge的branch,查看commit id
git log
然后checkout到要merge进的branch,
git cherry-pick [commit-id] 即可

git stash

  • https://zhuanlan.zhihu.com/p/33435204
1
2
3
4
5
6
7
8
git stash save
git stash list
git stash apply
git stash pop
git stash show
git stash branch <name>
git stash clear 清空所有stash
git stash drop
1
2
3
4
git stash list 
git stash
git stash pop 弹出最上面的stash
git stash pop stash@\{1\} 选择特定的stash弹出

git push

如果本地新建了一个分支 branch_name,但是在远程没有。

这时候 push 和 pull 指令就无法确定该跟踪谁,一般来说我们都会使其跟踪远程同名分支,所以可以利用 git push –set-upstream origin branch_name ,这样就可以自动在远程创建一个 branch_name 分支,然后本地分支会 track 该分支。后面再对该分支使用 push 和 pull 就自动同步。

1
git push --set-upstream origin branch_name

git pull

git pull 从远端拉去最新的代码

当远端的代码与本地的有冲突时,可以强制覆盖:

1
2
3
拉取远端的代码并
git fetch --all
git reset --hard origin/master <master 替换为 branch_name>

git commit

删除commit 回退版本

1
git reset --hard commit-id

将HEAD所在分支回退到之前版本

更改历史 commit

git 更改历史commit的注释
  • https://segmentfault.com/a/1190000022926064
1. 更改最近的一次commit信息
1
git commit --amend
2. 更改之前的历史commit历史信息
1
git rebase -i HEAD~n

​ 将pick改成edit,保存,更改信息

1
git rebase --continue

合并commit

  • 参考前面的rebase

git log

Git查看历史commit记录

git diff

查看差异

1
git diff [branch]或者[commit-id]

git ignore

对于已经添加追踪的文件,想要取消追踪

文件夹:

1
2
git rm -r --cached . #不删除本地文件
git rm -r --f .      #删除本地文件

对某个文件取消跟踪

1
2
git rm --cached readme1.txt    #删除readme1.txt的跟踪,并保留在本地。
git rm --f readme1.txt    #删除readme1.txt的跟踪,并且删除本地文件。

然后git commit 即可。

对于没有添加追踪的新文件,想忽略的话,添加gitignore文件即可

gitignore规则:todo(congyu)

git 远程工作

由远程仓库创建一个本地仓库

1
git checkout -b feature/multiple_maps_save_load origin/feature/improve_map_management

本地工作commit之后push(在此之前应该先fetch然后解决分歧)

1
git push origin HEAD:feature/improve_map_management 
git 查看远程仓库地址
1
git remote -v
git 设置远程仓库地址
1
git remote set-url origin <url>

ch2. git 项目开发流程

basic concept

branch

  • git项目主要包括两个分支:master和develop。其他分支比如release,fixbug、feature之类

  • master (or main)
    • 一个
    • 经过多次测试与bugfix,最稳定的branch
  • develop
    • 一个
    • 日常开发
  • release
    • 多个
    • 每次定版时,由develop抻一个release branch,然后在release branch基础上修bug,稳定后合并到master,并合回develop
  • feature/…
    • 多个
    • 日常开发,由develop抻出,开发完成后,再合回develop
  • bugfix/…
    • 多个
    • 日常修bug
  • improve/…
    • 对之前已经merge的feature的优化与更新
  • hotfix/…
    • 多个
    • 由master抻出来,修bug,然后合并到master和develop
  • others 多个
    • unit_test/
      • unit test开发
    • demo/
      • 用于demo的临时branch

Process

  • 确定开发新的feature之后 从develop branch checkout -b 一个新的分支出来,然后开发
  • 完成后push到同名远程仓库
  • 然后去github提交pr,申请review
  • 对于review批阅需要更改的地方,在本地修改,然后commit,push
  • 再次review,被approve之后,在github点merge即可
1
2
3
4
5
6
git pull
git checkout -b feature
git commit -m "msg"
git push

然后在github提pr

ch3. git submodule

  • refitem: https://git-scm.com/book/en/v2/Git-Tools-Submodules
  • refitem: https://git-scm.com/book/zh/v2/Git-%E5%B7%A5%E5%85%B7-%E5%AD%90%E6%A8%A1%E5%9D%97
添加submodule
1
git add submodule add url

在 .gitmodules 文件中会找到submodule记录

初始化

在别的地方pull完父仓库之后,进入子仓库,发现子仓库是空的,可以使用

1
2
git submodule init
git submodule update
删除submodule

有时子模块的项目维护地址发生了变化,或者需要替换子模块,就需要删除原有的子模块。

删除子模块较复杂,步骤如下:

  1. rm -rf 子模块目录 删除子模块目录及源码
  2. vi .gitmodules 删除项目目录下.gitmodules文件中子模块相关条目
  3. vi .git/config 删除配置项中子模块相关条目
  4. rm .git/module/* 删除模块下的子模块目录,每个子模块对应一个目录,注意只删除对应的子模块目录即可
  5. 执行完成后,再执行添加子模块命令即可,如果仍然报错,执行如下:
  6. git rm –cached -r 子模块名称

完成删除后,提交到仓库即可。

其他

可视化Tool
  • GitKraken: git GUI tool
github访问网速慢:用代理
  • https://blog.csdn.net/yh0503/article/details/90233216?utm_medium=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.nonecase&depth_1-utm_source=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.nonecase

  • 在命令行中使用代理:

    复制http代理设置

    然后在命令行中粘贴即可

    1
    
    export https_proxy=http://127.0.0.1:2340;export http_proxy=http://127.0.0.1:2340;export all_proxy=socks5://127.0.0.1:1080