public:it:git

差别

这里会显示出您选择的修订版和当前版本之间的差别。

到此差别页面的链接

两侧同时换到之前的修订记录 前一修订版
后一修订版
前一修订版
public:it:git [2023/02/16 16:40] – [Tips] oakfirepublic:it:git [2024/09/02 11:41] (当前版本) – [Usage] oakfire
行 12: 行 12:
     * SVN 的分支是一个完整文件目录;而 git 只保持一份本地文件目录,切换分支直接改变该目录文件;      * SVN 的分支是一个完整文件目录;而 git 只保持一份本地文件目录,切换分支直接改变该目录文件; 
   * GIT 没有全局唯一版本号;SVN 有;   * GIT 没有全局唯一版本号;SVN 有;
-    * git 可以打 tag 来弥补;+    * git 可以打 tag 来弥补;但是 tag 只与 commit id对应,而 commit id 不能保证代码的唯一性(因为不同分支的同一 commit id 之前的提交历史可能不一样),所以要保证 tag 唯一性,可额外人为规定只有主分支打的tag是有效的。
  
 ===== 三、GIT 资料 ===== ===== 三、GIT 资料 =====
行 20: 行 20:
   * CentOS yum 默认只有1.7.1 版本, 但像github.com等网站需要高于此版本. 此时需要源码安装升级.   * CentOS yum 默认只有1.7.1 版本, 但像github.com等网站需要高于此版本. 此时需要源码安装升级.
   * 如果源码安装,[[http://github.com/git/git|github repo]], ''make'', ''make install prefix=/usr'', 如果不添加''prefix=/usr'', 默认会安装在当前home目录.   * 如果源码安装,[[http://github.com/git/git|github repo]], ''make'', ''make install prefix=/usr'', 如果不添加''prefix=/usr'', 默认会安装在当前home目录.
 +
 +==== Tools ====
 +  * 显示仓库信息[[https://github.com/o2sh/onefetch|onefetch]], 这个不错
  
 ==== Usage==== ==== Usage====
行 31: 行 34:
   * [[http://pcottle.github.io/learnGitBranching/|Learning git branching]]   * [[http://pcottle.github.io/learnGitBranching/|Learning git branching]]
   * [[https://nvie.com/posts/a-successful-git-branching-model/|git flow]],[[https://www.atlassian.com/git/tutorials/comparing-workflows/gitflow-workflow|gitflow-workflow]]   * [[https://nvie.com/posts/a-successful-git-branching-model/|git flow]],[[https://www.atlassian.com/git/tutorials/comparing-workflows/gitflow-workflow|gitflow-workflow]]
 +  * [[https://jvns.ca/blog/2024/01/26/inside-git/|Inside .git]], 介绍 .git 文件夹内容
  
 ==== Ignore ==== ==== Ignore ====
行 106: 行 110:
   * 删除远程仓库分支:<code bash>git push origin --delete branchname</code>   * 删除远程仓库分支:<code bash>git push origin --delete branchname</code>
   * 删除本地的远程分支追踪(比如在远程分支删除后本地''git branch -a''还有遗留remote分支)<code bash>git branch -r -d origin/your_branch_name</code>   * 删除本地的远程分支追踪(比如在远程分支删除后本地''git branch -a''还有遗留remote分支)<code bash>git branch -r -d origin/your_branch_name</code>
 +  * 同步本地的远程分支追踪<code bash>git remote prune origin</code>
   * 打tag最好用-a -m ,多一个obj,方便管理 <code bash>git tag -a tagname -m "message" [commit]</code>   * 打tag最好用-a -m ,多一个obj,方便管理 <code bash>git tag -a tagname -m "message" [commit]</code>
   * 删除远程仓库tag<code bash>   * 删除远程仓库tag<code bash>
行 128: 行 133:
   * 提交空commit: <code bash>git commit --allow-empty -m "Empty"</code>   * 提交空commit: <code bash>git commit --allow-empty -m "Empty"</code>
   * 修改上一次commit的message: <code bash>git commit --amend -m "new msg" </code>   * 修改上一次commit的message: <code bash>git commit --amend -m "new msg" </code>
 +  * 设置 vim 为默认编辑器:<code bash>git config --global core.editor "vim"</code>
 +  * 删除某文件的所有历史记录,[[https://blog.csdn.net/yxpandjay/article/details/111275665|参考]]:
 +    * 查找大文件:'' git rev-list --objects --all | grep "$(git verify-pack -v .git/objects/pack/*.idx | sort -k 3 -n | tail -5 | awk '{print$1}')" ''
 +    * 从历史记录删除:'' git filter-branch -f --index-filter 'git rm --cached --ignore-unmatch "your/big.file"' HEAD --all  ''
 +  * 显示差异时忽略行尾空格差异: <code bash>git diff --ignore-space-at-eol</code>
  
 ==== server: gitolite ==== ==== server: gitolite ====
  • public/it/git.1676536814.txt.gz
  • 最后更改: 2023/02/16 16:40
  • oakfire