【Git 学习笔记】第二章 Git 的设置(下)

立山  金牌会员 | 2024-7-11 14:20:53 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 847|帖子 847|积分 2541

2.5 几个设置示例

2.5.1 变基(rebase)与归并(merge)设置

默认情况下,在实行 git pull 时,如果本地分支的汗青记录与远程分支的汗青差别,则会举行归并提交。修改默认方式可使用:
  1. # use rebase instead of merge: true / false
  2. $ git config pull.rebase true
复制代码
切换分支时,取消默认按归并(merge)的方式举行分支切换:
  1. # never(default) lacal remote always
  2. $ git config branch.autosetuprebase always
复制代码
设置详细某分支在实行 git pull 操作时按 git rebase 举行:
  1. # pattern: branch.<name>.rebase approach
  2. $ git config branch.feature/2.rebase true
复制代码
2.5.2 有效期设置

默认情况下,Git 将对未引用对象实行垃圾回收,并对为超过 90 天的 reflog 条目举行清算。一个 git 对象必须被其他对象引用,这个其他对象可以是一个 tree 树,一个 tag 标签,一个 branch 分支,大概其他 Git 内部簿记,如 stash 或 reflog。有三个设置项可对有效期举行设置:


  • gc.reflogexpire
  • gc.reflogexpireunreachable
  • gc.pruneexpire
  1. # To set a non-default expiry date on remote branches only
  2. $ git config gc./refs/remote/*.reflogexpire never
  3. # How long the reflog entries that are not a part of the current branch history should be available in the repository, 30d by default:
  4. $ git config gc./refs/remote/*.reflogexpireunreachable "2 months"
  5. # Set a date so git gc will prune objects sooner
  6. $ git config gc.pruneexpire 3.days.ago
复制代码
2.5.3 设置自动更正

出现笔误时 git 会自动提示:

可以设置自动更正的时间隔断,单元 厘秒(0.1秒):
  1. $ git config help.autocorrect 5
  2. $ git statis
  3. WARNING: You called a Git command named 'statis', which does not exist.
  4. Continuing under the assumption that you meant 'status'
  5. in 0.5 seconds automatically...
  6. # On branch master
  7. # Changes to be committed:
  8. #   (use "git reset HEAD <file>..." to unstage)
  9. #
  10. #       modified:   another-file.txt
  11. #
复制代码
实测效果:(设为 3 秒后自动更正)

2.6 设置 Git 别名

设置常见通用别名:
  1. $ git config --global alias.co checkout
  2. $ git config --global alias.br branch
  3. $ git config --global alias.ci commit
  4. $ git config --global alias.st status
复制代码
新增自定义别名:让某文件取消暂存
  1. # pattern: git unstage <FILE>...
  2. $ git config --global alias.unstage 'reset HEAD --'
  3. # Test
  4. $ echo "Something new" >> .\README.md
  5. $ git unstage .\README.md
  6. Unstaged changes after reset:
  7. M       README.md
  8. $ git unstage .\README.md
  9. Unstaged changes after reset:
  10. M       README.md
  11. $ git st
  12. On branch master
  13. Your branch is behind 'origin/master' by 5729 commits, and can be fast-forwarded.
  14.   (use "git pull" to update your local branch)
  15. Changes not staged for commit:
  16.   (use "git add <file>..." to update what will be committed)
  17.   (use "git restore <file>..." to discard changes in working directory)
  18.         modified:   README.md
  19. no changes added to commit (use "git add" and/or "git commit -a")
复制代码
实测截图:

更常见的是将自定义的 git 格式化后的日志形式存为一个别名:
  1. $ git config --global alias.ll "log --pretty=format:'%C(yellow)%h%Cred%d %Creset%s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --numstat"
复制代码
实测效果:

git 也可以为自定义的外部脚本设置别名,此时别名内容前必要加感叹号 !。示例如下:
  1. # add the line onto your ~/.gitconfig file
  2. editconflicted = "!f() {git ls-files --unmerged | cut -f2 | sort -u ; }; $EDITOR 'f'"
复制代码
这段脚本会打开预设的编辑器,此中包罗由于归并或变基而处于辩说状态的全部文件。 该操作可以快速修复辩说并继续归并/变基。
测试如下:
  1. $ git branch A 03f78fc
  2. $ git branch B 9891497
  3. $ git checkout A
  4. Switched to branch 'A'
  5. $ git merge B  
  6. # conflicts found, and a list of conlicted files print out
  7. # Resolve all these files and then run the script
  8. $ git editconflicted
  9. # Check the status
  10. $ git st
  11. # then commit to resolve merge
  12. $ git ci
复制代码
另一种创建 Git 别名的方法,是新建一个 shell 脚本,并使用名称 git-<your-alias-name> 生存。 设置文件权限为 可实行,并将其放在 $PATH 某一路径下,用命令行运行 git <your-alias-name> 看到相应结果。
查看当前定义的全部别名:
  1. # Linux
  2. $ git config --list | grep alias
  3. # Powershell
  4. > git config --list | where {$_ -match "alias"}
复制代码
2.7 refspec 举例

设置 git 时,很难第一时间就想到 refspec,由于它通常是在实行 git 命令时被隐式调用。当实行堆栈复制或添加远程分支时,.git/config 文件会有类似设置:
  1. [remote "origin"]
  2.   url = https://git.eclipse.org/r/jgit/jgit
  3.   fetch = +refs/heads/*:refs/remotes/origin/*
复制代码
此中 fetch 这行就包罗了该堆栈实行 fetch 时的 refspec。
本例将在本地创建一个 bare 堆栈(工作目录为空的堆栈),以便示例代码实行 push 操作(否则会覆盖目标堆栈的工作区(work area)和索引(index)。
  1. # Create bare repo from Eclipse remote repo
  2. $ git clone --bare https://git.eclipse.org/r/jgit/jgit jgit-bare.git
  3. # Init local repo for demo
  4. $ git init refspec-tests
  5. Initialized empty Git repository in /Users/john.doe/refspec-tests/.git/
  6. # Add remote origin for the local repo
  7. $ cd refspec-tests
  8. $ git remote add origin ../jgit-bare.git
  9. # Enter the bare repo and rename "stable-*" branches into "stable/*"
  10. $ cd ../jgit-bare.git && for br in $(git branch  -a | grep "stable-"); do new=$(echo $br| sed 's/-/\//'); git branch $new $br; done
复制代码
这里发现两处笔误:

  • Linux 情况下实行 sed 命令,更换为目标字符串的 / 必要转义,写作 \/,书中写为 /;
  • 远程分支的重命名,应该在 bare 堆栈中举行,原书中少了一句 cd ../jgit-bare.git。反馈给作者核实后,两处笔误均已更正。
  • 实测时由于与作者成书时的隔断已有三年多之久,这其间 jgit 库一直在更新;加上国内网络情况查,无法按照书中的命令在线同步 jgit 代码库。变通办法为:先同步 jgit 远程库到本地,然后重命名 stable 分支,再以此为根本创建 bare 堆栈。如果本地库不预先拉取 jgit 的全部远程分支,拷贝 bare 库时将丢失全部远程分支。切记!
关于离线版的预备工作,操作如下:
  1. # ... get local copy of jgit repo, named demo ... (by fortune)
  2. # Rename branches: e.g. stable-1.2 --> stable/1.2
  3. $ cd ./demo && for br in $(git branch  -a | grep "stable-"); do new=$(echo $br | sed 's/-/\//'); git branch $new $br; done
  4. # clone bare repo based on local 'demo' repo
  5. $ cd .. && git clone --bare ./demo jgit-bare.git
  6. # ... (same as mentioned above)
复制代码
  再次强调
  再次强调
  再次强调
  从本地堆栈新建 bare 库时,数据源堆栈的 全部本地分支 将作为 bare 库的远程跟踪分支(remote-tracking branch),被后续基于该 bare 库的其他衍生堆栈查询出来。因此第 2 步中必须先将示例要用到的全部门支(即全部带 stable- 前缀的分支)签出。
  
示例一:只同步拉取 master 分支

  1. # Edit .git/config file: heads/* --> heads/master; origin/* --> origin/master
  2. [remote "origin"]
  3.   url = ../jgit-bare.git
  4.   fetch = +refs/heads/master:refs/remotes/origin/master
复制代码
设置生效后,实行如下命令将只对 master 分支生效:


  • git fetch
  • git pull
  • git remote update origin
示例二:只同步带 stable 字样的分支

  1. [remote "origin"]
  2.   url = ../jgit-bare.git
  3.   fetch = +refs/heads/master:refs/remotes/origin/master
  4.   fetch = +refs/heads/stable/*:refs/remotes/origin/stable/*
复制代码
示例三:设置推送到远程堆栈的默认远程分支名称

添加默认推送名称:
  1. [remote "origin"]
  2.   url = ../jgit-bare.git
  3.   fetch = +refs/heads/master:refs/remotes/origin/master
  4.   fetch = +refs/heads/stable/*:refs/remotes/origin/stable/*
  5.   push = refs/heads/develop:refs/remotes/origin/integration/master
复制代码
创建本地分支并提交一个新版本:
  1. # Create local branch 'develop', then add one commit
  2. $ git checkout -b develop
  3. Switched to a new branch 'develop'
  4. $ echo "This is the developer setup, read carefully" > readme-dev.txt
  5. $ git add readme-dev.txt
  6. $ git commit -m "adds readme file for developers"
复制代码
推送到远程分支(确认是否默认推送至 integration/master 分支):
  1. $ git push
复制代码
实测结果:

几点说明:

  • integration/master 分支仅在本地存在,远程堆栈(bare 库)不存在。
  • refspec 的格式为:<source>:<destination>:

    • 对 fetch 操作:远程库为 source,本地库为 destination;
    • 对 push 操作:远程库为 destination,本地库为 source;
    • refspec 中的 + 号,是指详细的引用写法可以被修改,即便不是快进式修改(即按时间顺序举行的修改,原文为:… to indicate that the ref pattern can be updated even though it isn’t a fast-forward update)
    • refspec 不支持模糊匹配,因此不能写作:
      1. fetch = +refs/heads/stable*:refs/remotes/origin/stable*
      复制代码
      但 ref 的写法可以按命名空间设置,如:
      1. fetch = +refs/heads/stable/*:refs/remotes/origin/stable/*
      复制代码
      这也是为什么示例一开始就要重命名分支名称的根本缘故原由;同时也从另一个角度说明,分支的命名最好按命名空间的方式举行设计。


关于上面提到的笔误,当时还联系了出书社求证,并有幸得到了作者的反馈,确实是写错了。原文如下:
   Hi Anton,
  Hope you are doing well.
  This is what we have received from the author for the first query:
  "I have walked through the section, and the missing \ in the command is correct.
  Moreover, in order to archive what is described in the section, it is vital to mention that the renaming command (for br …) must be executed in the directory jgit-bare.git. If you follow the commands in the section strictly, you will be in the directory refspec-tests.
  By changing the “for br …” command to “(cd …/jgit-bare.git && for br …)”, it will work. The parenthesis at the beginning and at the end are important."
  (第二章完)

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

立山

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表