Git进阶笔记系列(01)Git焦点架构原理 | 常用命令实战集合 ...

打印 上一主题 下一主题

主题 905|帖子 905|积分 2715

读书笔记:杰出逼迫症+强大恐惧症,在亲子家庭、职场关系里尤其是纵向关系模型里,这两种状态很容易无缝衔接。尤其父母对子女、领导对部属,都有望子成龙、强将无弱兵的盼望,然而在你的面前,他们才是永世强大的那一个。当子女‘不听话’,部属‘不可控’,他们出现了强大恐惧症。两个抵牾体,让父母、领导开始不知所措,无法信赖对方,即使信赖也难以采取并非永世强大的自己。
  一、前言配景
二、Git是什么?
2.1 和其他版本管理工具差别是什么?
三、Git焦点架构
3.1 架构原理
3.1.1 远程仓库
3.1.2 本地仓库
3.2 git工作指南
四、git 配置管理
五、常用命令实战详解
5.1 新建本地仓库
5.2 分支管理
5.3 代码管理
5.4 stash管理
5.5 标签管理
5.6 版本回退
六、 命令集合

【公众号搜索:拉丁解牛说技术】欢迎一起交流讨论。
一、前言配景

Git是目前最流行的分布式代码版本管理平台,简朴好用、稳固可靠的特性,得到行业广泛认可应用。尤其在可视化管理工具遍及,以及集成到开发工具配景下,新手险些不必要专门学习Git,通过相识几个简朴按钮功能,就可以在工作当中轻松完成git管理代码提交、归并。
然而,随着研发履历的不停提拔、岗位工尴尬刁难自身也提出新的要求,新手小白,逐渐必要应对解决代码辩说、回滚、版本管理、仓库搭建运维等复杂工作。此时深入实践掌握Git焦点架构原理、git常用功能命令、Git仓库管理配置等技能,显得尤为重要。
二、Git是什么?

Git是一个分布式版本管理系统,它允许开发者跟踪代码的更改,协作开发,以及在不同版本之间切换。Git 的主要特点包罗:分布式架构设计、简朴易用、本地离线修改提交、灵活的版本控制。
2.1 和其他版本管理工具差别是什么?

Git接纳分布式的版本管理架构:每个开发者都有一个完备的代码库副本,允许离线使用和分支管理,即使远程git库挂了,数据丢了也不消过于担心。由于分布在各地的开发者本地有副本,代码不会丢失。而传统版本控制系统好比SVN是会合式管理,开发者必须毗连到中心服务器才可以管理追踪代码,中心库假如出故障,开发者无法管理使用代码。
Git仅存储版本快照:开发者每次提交,Git仅保存修改文件最新内容快照,通过版本链来管理内容版本。而传统SVN、CVS是记录具体内容比力修改记录。Git在宏观上,是对代码文件整体变革的关注,只要文件有修改,不过内容多少,统一是一次版本更新,记录到文件系统。而SVN、CSV会具体记录着每个版本相关文件修改差别,关注的是细节。
险些是纯本地管理:Git由于本地仓库和本地副本的存在,开发者即使没有网络,也可以先在本地完成代码修改提交,并且随时可以查看历史版本差别和历史修改记录。当有网络的时候,直接push本地最新版本到远程即可。离线的使用,非常轻量和高效。
三、Git焦点架构原理

Git的焦点架构由远程仓库(remote)和本地仓库(repository)两部分组成。


3.1 架构原理

3.1.1 远程仓库

远程服务器的仓库,常用的有github、gitlab、bitbucket、gitee等平台仓库。大部分企业选择在公司内部搭建git远程仓库管理内部项目系统源码,制止公司代码资产流失到外部互联网上。
企业内部运维管理人员通过在远程仓库实当代码版本管理、用户管理、项目授权、devops集成、用户ssh公钥管理等焦点功能。
3.1.2 本地仓库

开发者通过git clone复制保存大概git add remote origin 关联远程仓库到本地,初始化本地仓库。假如不想让代码共享到远程仓库,也不必要和其他人协作。本地仓库也是一个功能完善的git仓库,在本地也可以举行灵活的版本管理。
本地git版本库,又细分为:工作区目次workspace、暂存区index、本地库.git。
好比我在本地电脑:新建一个目次细分工作区目次ladingjieniu-proj001,通过git init 初始化并新建一个本地版本库,库地址是当前目次下的.git文件夹。
里面新增一个lading.txt文件。
.git目次下,会自动新增暂存区index目次。


3.2 git工作指南

开启一个项目标git版本管理,一般都是2个模式。一个是直接从远程库clone项目到本地,然后开始开发迭代。另一个就是先在本地创建好本地库,然后通过git add remote origin 来关联远程库,随后开始迭代推送代码。
第一个模式比力常见,具体流程如下:
1、首先通过git clone拷贝远程代码库到本地库。后期远程库有其他人推送更新,通过git fetch \ pull命令拉取远程最新分支信息更新到本地。
2、本地仓库新增大概checkout到对应分支举行开发。
3、开发迭代完成后,通过git add命令,提交本地代码到暂存区index。
4、随后通过git commit -am 'message 分析'提交本次变更到本地库.git目次。
5、最后通过git push将本地库的全部更新推送到远程库。


四、git 配置管理

在我们本地仓库,git的配置文件有三种级别,分别是仓库级别、用户级别、系统级别。三者的优先级从高到底分别是:仓库local信息> 用户级别global信息> 系统system级别信息。我们主要用到的是仓库级别和用户级别。对应配置信息地址分别是:.git/config,~/.gitconfig。
4.1 查看git配置信息

查看ladingjieniu-proj001这个仓库的git配置信息,直接cat .git/config文件,大概git config --local -l命令查看:


查看当前系统用户ladingjieniu的git配置信息, cat ~/.gitconfig,大概git config --global -l:
(base) ladingjieniu $ cat ~/.gitconfig
[user]
name = ladingjieniu
email = ladingjieniu@xxx.com
4.2 新增修改git配置信息

通过命令git config --local [参数名] [参数值]设置。好比:git config --local project.develop 'ladingjieniu66'


而修改用户级别的配置信息,通过git config --global 命令来实现配置。
五、常用命令实战详解

5.1 新建本地仓库

首先,假如本地已经有相关项目代码,必要创建本地git库,直接cd到对应目次。
输入命令:git init 回车。当前项目目次就变成了git本地库,你会发现有个.git 目次出现。
其次,假如是新建全新项目,通过mkdir [project-name]新建目次,然后再输入命令:git init 回车,当前目次变成本地库完成,随后可以在该目次下迭代代码文件。
最后,假如必要下载一个远程项目到本地,输入命令:git clone [url],则远程项目就被下载到本地,且本地当前目次变成了该项目本地git库。这里一般是通过https方式,好比【git clone https://gitee.com/arthas/arthas.git】。假如是ssh方式,必要在远程仓库配置本地电脑公钥才可以通过ssh方式clone远程仓库。


5.2 分支管理

查看本地分支、远程分支:git branch \ git branch -r。


切换分支:git checkout [branch]。
新建本地分支,并切换到新分支:git checkout -b [branch]。


删除本地分支:先切换到其他分支,然后执行git branch -d [branch-name] 。
删除远程分支:git push origin --delete [branch-name]。
5.3 代码管理

当我们在本地test3分支做了修改,必要归并到本地的master分支。可以通过:git merge 来归并。


在实际工作中,假如master分支代码远程已经有其他人做了修改提交。此时归并代码到master后,举行push使用,会出当代码辩说。此时git要求本地做好辩说修改后,作为一次新的commit 和push。
5.4 stash管理

当我们在本地分支做了一些需改,可能是未完全实现的迭代,此时有紧急需求,必要切换到另一个分支去处理,但是又不希望当前修改提交到本地库。我们可以通过git stash 命令,将当前修改,提交到堆栈中。后续在任意分支,可以通过git stash pop命令取回之前缓存的修改内容。




5.5 标签管理

当版本正常发布后,必要对版本库举行打标签封存发布。可以通过git tag相关命令去处理。
新建tag:git tag [标签名]
删除标签:git tag -d [标签名]
远程标签删除:git push origin --delete tag [标签名]
查看标签: git tag


本地标签打好后,举行远程推送:git push origin [标签名]。然后在远程仓库就可以看到对应tag清单。


5.6 版本回退

在Git中回退到上一个版本,用HEAD表现当前版本,head^表现上一个版本,好比:
git reset --hard HEAD^。
假如必要回退到指定版本,先通过git log命令查看对应版本的sha1值,然后通过git reset --hard 【sha1值版本号,前几位就可以】举行回退。
六、 命令集合

  1. #######分支管理
  2. # 新建分支
  3. $ git branch [新分支名]
  4. # 切换到指定分支
  5. $ git checkout [分支名]
  6. # 新建分支,并切换新分支
  7. $ git checkout -b [新分支名]
  8. # 查看本地分支
  9. $ git branch
  10. # 查看远程分支
  11. $ git branch -r
  12. # 查看本地分支和远程分支
  13. $ git branch -a
  14. # 删除分支,需要先切换到其他分支,不能在本地分支删除本分支!
  15. $ git branch -d [分支名]
  16. # 删除远程分支
  17. $ git push origin --delete [分支名]
  18. $ git branch -dr [remote/branch]
  19. # 新建分支,并指向到指定commit
  20. $ git branch [branch] [commit]
  21. # 新建分支,并与的远程分支建立关联关系
  22. $ git branch --track [本地分支名] [远程分支名]
  23. # 将指定分支内容合并到当前分支
  24. $ git merge [指定分支名]
  25. #######配置管理
  26. # 查看Git配置
  27. $ git config --list
  28. # 编辑Git配置文件,--global是用户级别,--local是本地仓库级别。
  29. $ git config [--global] [--local]
  30. # 设置用户信息,设置用户级别就很方便。用户名+邮箱,这里不能用=号。需要空格双引号
  31. $ git config [--global] user.name "用户名xxx"
  32. $ git config [--global] user.email "邮箱地址xxx"
  33. #######代码提交推送
  34. # 添加相关修改文件或某个目录到暂存区index
  35. $ git add [file1] [file2] [dir]...
  36. # 添加当前目录的所有文件到暂存区
  37. $ git add *
  38. # 把之前add到暂存区修改内容,提交到本地仓库
  39. $ git commit -m [message]
  40. #  把指定暂存区文件,提交到本地仓库
  41. $ git commit [file1] [file2] ... -m [message]
  42. # 全部修改commit
  43. $ git commit -am [message]
  44. # 删除工作区workspace的文件,并且将这次删除放入暂存区index
  45. $ git rm [file1] [file2] ...
  46. # 提交修改到远程仓库
  47. $ git push origin master
  48. # 拉取远程更改到本地仓库默认自动合并,pull=fetch+merge命令。
  49. $ git pull origin master
  50. #######git标签管理
  51. # 查看全部tag
  52. $ git tag
  53. # 新建一个tag
  54. $ git tag [tag名称]
  55. # 删除本地tag
  56. $ git tag -d [tag]
  57. # 删除远程tag
  58. $ git push origin :refs/tags/[tag名称]
  59. # 查看tag信息
  60. $ git show [tag]
  61. # 提交指定tag
  62. $ git push [remote] [tag]
  63. # 提交所有tag
  64. $ git push [remote] --tags
  65. # 新建一个分支,指向某个tag
  66. $ git checkout -b [branch] [tag]
  67. #######git回退回滚管理
  68. # 回退到上一个版本
  69. $ git reset --hard HEAD^
  70. # 回退到指定版本,先通过git log查看对应commit sha1值
  71. $ git reset --hard [commit 的sha1]
  72. #######git stash暂存管理
  73. # 暂时将未提交的变化放到堆栈里
  74. $ git stash
  75. # 将堆栈里未提交内容恢复到当前分支
  76. $ git stash pop
  77. #######其他命令,提交日志、差异查看
  78. # 查看当前分支的历史提交记录
  79. $ git log
  80. # 查看commit历史,以及每次commit变更文件统计信息
  81. $ git log --stat
  82. # 查看过去3次提交
  83. $ git log -3 --pretty --oneline
  84. # 查看该项目用户提交信息统计,并排序
  85. $ git shortlog -sn
  86. # 查看指定文件历史差异提交情况
  87. $ git log -p [file]
  88. # 查看暂存区和工作区的差异
  89. $ git diff
  90. # 查看统计,当前用户写了多少代码
  91. $ git diff --shortstat "@{0 day ago}"
复制代码


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

使用道具 举报

0 个回复

倒序浏览

快速回复

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

本版积分规则

tsx81429

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

标签云

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