东南融通网站建设嘉兴公司注册
- 作者: 五速梦信息网
- 时间: 2026年03月21日 11:21
当前位置: 首页 > news >正文
东南融通网站建设,嘉兴公司注册,宁波网站推广人,安徽网站开发与维护专业Git 学习笔记 Git 简介 Git 是一个 开源的分布式版本控制系统。 什么是版本控制#xff1f; 版本控制是一种记录一个或若干文件内容变化#xff0c;以便将来查阅特定版本修订情况的系统。 什么是分布式版本控制系统#xff1f; 介绍分布式版本控制系统前#xff0c;有…Git 学习笔记 Git 简介 Git 是一个 开源的分布式版本控制系统。 什么是版本控制 版本控制是一种记录一个或若干文件内容变化以便将来查阅特定版本修订情况的系统。 什么是分布式版本控制系统 介绍分布式版本控制系统前有必要先了解一下 传统的集中式版本控制系统。 集中化的版本控制系统 诸如 CVSSubversion 等都有一个 单一的集中管理的服务器 保存所有文件的修订版本而协同工作的人们都通过客户端连到这台服务器 取出最新的文件或者提交更新。 这么做最 显而易见的缺点是中央服务器的单点故障。 如果宕机一小时那么在这一小时内谁都无法提交更新也就无法协同工作。要是中央服务器的磁盘发生故障碰巧没做备份或者备份不够及时就会有丢失数据的风险。最坏的情况是彻底丢失整个项目的所有历史更改记录。 分布式版本控制系统的客户端并不只提取最新版本的文件快照而是把代码仓库完整地镜像下来。 这么一来任何一处协同工作用的服务器发生故障事后都可以用任何一个镜像出来的本地仓库恢复。因为每一次的提取操作实际上都是一次对代码仓库的完整备份。 可参考 Git 从入门到精通 Git vs SVN Git 和 SVN 孰优孰好每个人有不同的体验。 Git是分布式的SVN是集中式的 这是 Git 和 SVN 最大的区别。若能掌握这个概念两者区别基本搞懂大半。因为 Git 是分布式的所以 Git 支持离线工作在本地可以进行很多操作包括接下来将要重磅推出的分支功能。而 SVN 必须联网才能正常工作。 Git复杂概念多SVN简单易上手 所有同时掌握 Git 和 SVN 的开发者都必须承认Git 的命令实在太多了日常工作需要掌握add,commit,status,fetch,push,rebase等若要熟练掌握还必须掌握rebase和merge的区别fetch和pull的区别等除此之外还有cherry-picksubmodulestash等功能仅是这些名词听着都很绕。 在易用性这方面SVN对于新手来说会更有好一些。但是从另外一方面看Git 命令多意味着功能多若我们能掌握大部分 Git 的功能体会到其中的奥妙会发现再也回不去 SVN 的时代了。 Git分支廉价SVN分支昂贵 在版本管理里分支是很常使用的功能。在发布版本前需要发布分支进行大需求开发需要 feature 分支大团队还会有开发分支稳定分支等。在大团队开发过程中常常存在创建分支切换分支的求。 Git 分支是指针指向某次提交而 SVN 分支是拷贝的目录。这个特性使 Git 的分支切换非常迅速并且创建成本非常低。 而且 Git 有本地分支SVN 无本地分支。在实际开发过程中经常会遇到有些代码没写完但是需紧急处理其他问题若我们使用 Git便可以创建本地分支存储没写完的代码待问题处理完后再回到本地分支继续完成代码。 更多关注Git与Svn的比较请参阅 通俗易懂用好Git 和 SVN ,轻松驾驭版本管理 Git 工作原理 文字不好理解请看 图文详解 Git 工作原理 Git 安装 Debian/Ubuntu 环境安装 如果你使用的系统是 Debian/Ubuntu 安装命令为 \( apt-get install libcurl4-gnutls-dev libexpat1-dev gettext \libz-dev libssl-dev \) apt-get install git-core \( git --version git version 1.8.1.2Centos/RedHat 环境安装 如果你使用的系统是 Centos/RedHat 安装命令为 \) yum install curl-devel expat-devel gettext-devel \openssl-devel zlib-devel \( yum -y install git-core \) git –version git version 1.7.1Windows 环境安装 在 Git 官方下载地址下载 exe 安装包。按照安装向导安装即可。 建议安装 Git Bash 这个 git 的命令行工具。 Mac 环境安装 在 Git 官方下载地址下载 mac 安装包。按照安装向导安装即可。 Git配置 Git 自带一个 git config 的工具来帮助设置控制 Git 外观和行为的配置变量。这些变量存储在三个不同的位置 /etc/gitconfig 文件: 包含系统上每一个用户及他们仓库的通用配置。如果使用带有 –system 选项的 git config 时它会从此文件读写配置变量。 ~/.gitconfig 或 ~/.config/git/config 文件只针对当前用户。可以传递 –global 选项让 Git 读写此文件。 当前使用仓库的 Git 目录中的 config 文件就是 .git/config针对该仓库。 每一个级别覆盖上一级别的配置所以 .git/config 的配置变量会覆盖 /etc/gitconfig 中的配置变量。 在 Windows 系统中Git 会查找 \(HOME 目录下一般情况下是 C:\Users\)USER的 .gitconfig 文件。Git 同样也会寻找 /etc/gitconfig 文件但只限于 MSys 的根目录下即安装 Git 时所选的目标位置。 Git 基本概念 版本库 当你一个项目到本地或创建一个 git 项目 项目目录下会有一个隐藏的 .git 子目录。这个目录是 git 用来跟踪管理版本库的 千万不要手动修改。 哈希值 Git 中所有数据在存储前都计算校验和然后以校验和来引用。这意味着不可能在 Git 不知情时更改任何文件内容或目录内容。这个功能建构在 Git 底层是构成 Git 哲学不可或缺的部分。若你在传送过程中丢失信息或损坏文件Git 就能发现。 Git 用以计算校验和的机制叫做 SHA-1 散列hash哈希 。这是一个由 40 个十六进制字符0-9 和 a-f组成字符串基于 Git 中文件的内容或目录结构计算出来。SHA-1 哈希看起来是这样 24b9da6552252987aa493b52f8696cd6d3b00373Git 中使用这种哈希值的情况很多你将经常看到这种哈希值。实际上 Git 数据库中保存的信息都是以文件内容的哈希值来索引而不是文件名。 文件状态 在 GIt 中你的文件可能会处于 三种状态 之一 已修改modified - 已修改表示修改了文件但还没保存到数据库中。已暂存staged - 已暂存表示对一个已修改文件的当前版本做了标记使之包含在下次提交的快照中。已提交committed - 已提交表示数据已经安全的保存在本地数据库中。 工作区域 与文件状态对应的 不同状态的文件在 Git 中处于不同的工作区域 。 工作区working - 当你 git clone 一个项目到本地相当于在本地克隆了项目的一个副本。工作区是对项目的某个版本独立提取出来的内容。这些从 Git 仓库的压缩数据库中提取出来的文件放在磁盘上供你使用或修改。暂存区staging- 暂存区是一个文件保存了下次将提交的文件列表信息一般在 Git 仓库目录中。有时候也被称作 ‘索引’不过一般说法还是叫暂存区。本地仓库local - 提交更新找到暂存区域的文件将快照永久性存储到 Git 本地仓库。远程仓库remote - 以上几个工作区都是在本地。为了让别人可以看到你的修改你需要将你的更新推送到远程仓库。同理如果你想同步别人的修改你需要从远程仓库拉取更新。 分支Branch 分支是为了将修改记录的整个流程分开存储让分开的分支不受其它分支的影响所以在同一个数据库里可以同时进行多个不同的修改 主分支Master前面提到过 master 是 Git 为我们自动创建的第一个分支也叫主分支其它分支开发完成后都要合并到 master 标签Tag 标签是用于标记特定的点或提交的历史通常会用来标记发布版本的名称或版本号如publish/0.0.1虽然标签看起来有点像分支但打上标签的提交是固定的不能随意的改动 HEAD HEAD 指向的就是当前分支的最新提交图片 以上概念了解的差不多那就可以继续往下看。 Git 命令 创建仓库 克隆一个已创建的仓库 通过 SSH \( git clone ssh://userdomain.com/repo.git通过 HTTP \) git clone http://domain.com/user/repo.git创建一个新的本地仓库 \( git init添加修改 添加修改到暂存区 把指定文件添加到暂存区 \) git add xxx把当前所有修改添加到暂存区 \( git add .把所有修改添加到暂存区 \) git add -A提交修改到本地仓库 提交本地的所有修改 \( git commit -a提交之前已标记的变化 \) git commit附加消息提交 $ git commit -m commit message储藏 有时我们需要在同一个项目的不同分支上工作。当需要切换分支时偏偏本地的工作还没有完成此时提交修改显得不严谨但是不提交代码又无法切换分支。这时 你可以使用 git stash 将本地的修改内容作为草稿储藏起来。 官方称之为 储藏 但我个人更喜欢称之为 存草稿 。
- 将修改作为当前分支的草稿保存 \( git stash2. 查看草稿列表 \) git stash list stash{0}: WIP on master: 6fae349 :memo: Writing docs.3.1 删除草稿 \( git stash drop stash{0}3.2 读取草稿 \) git stash apply stash{0}撤销修改 撤销本地修改 移除缓存区的所有文件i.e. 撤销上次git add \( git reset HEAD将HEAD重置到上一次提交的版本并将之后的修改标记为未添加到缓存区的修改 \) git reset commit将HEAD重置到上一次提交的版本并保留未提交的本地修改 \( git reset --keep commit放弃工作目录下的所有修改 \) git reset –hard HEAD将HEAD重置到指定的版本并抛弃该版本之后的所有修改 \( git reset --hard commit-hash用远端分支强制覆盖本地分支 \) git reset –hard remote/branch e.g., upstream/master, origin/my-feature放弃某个文件的所有本地修改 \( git checkout HEAD file删除添加.gitignore文件前错误提交的文件 \) git rm -r –cached . \( git add . \) git commit -m remove xyz file撤销远程修改创建一个新的提交并回滚到指定版本 \( git revert commit-hash彻底删除指定版本 执行下面命令后commit-hash 提交后的记录都会被彻底删除使用需谨慎 \) git reset –hard commit-hash \( git push -f更新与推送 更新 下载远程端版本但不合并到HEAD中 \) git fetch remote将远程端版本合并到本地版本中 \( git pull origin master以rebase方式将远端分支与本地合并 \) git pull –rebase remote branch推送 将本地版本推送到远程端 \( git push remote remote branch删除远程端分支 \) git push remote :branch (since Git v1.5.0) \( git push remote --delete branch (since Git v1.7.0)发布标签 \) git push –tags查看信息 显示工作路径下已修改的文件 \( git status显示与上次提交版本文件的不同 \) git diff显示提交历史 从最新提交开始显示所有的提交记录显示hash 作者信息提交的标题和时间 \( git log显示某个用户的所有提交 \) git log –authorusername显示某个文件的所有修改 \( git log -p file显示搜索内容 从当前目录的所有文件中查找文本内容 \) git grep Hello在某一版本中搜索文本 \( git grep Hello v2.5分支 增删查分支 列出所有的分支 \) git branch列出所有的远端分支 \( git branch -r基于当前分支创建新分支 \) git branch new-branch基于远程分支创建新的可追溯的分支 \( git branch --track new-branch remote-branch删除本地分支 \) git branch -d branch强制删除本地分支将会丢失未合并的修改 \( git branch -D branch切换分支 切换分支 \) git checkout branch创建并切换到新分支 \( git checkout -b branch标签 给当前版本打标签 \) git tag tag-name给当前版本打标签并附加消息 \( git tag -a tag-name合并与重置 merge 与 rebase 虽然是 git 常用功能但是强烈建议不要使用 git 命令来完成这项工作。 因为如果出现代码冲突在没有代码比对工具的情况下实在太艰难了。 你可以考虑使用各种 Git GUI 工具。 合并 将分支合并到当前HEAD中 \) git merge branch重置 将当前HEAD版本重置到分支中请勿重置已发布的提交 \( git rebase branch更多命令参考 三年 Git 使用心得 常见问题整理 Git 分支开发 Git 是目前最流行的源代码管理工具。 为规范开发保持代码提交记录以及 git 分支结构清晰方便后续维护以及规范 git 的相关操作。 分支命名 1、master 分支 master 为 主分支 也是用于部署 生产环境 的分支确保master分支稳定性 master 分支一般由develop以及hotfix分支合并任何时间都不能直接修改代码 2、develop 分支 develop 为 开发分支 始终保持最新完成以及bug修复后的代码 一般开发的新功能时feature分支都是基于develop分支下创建的。 feature 分支 开发 新功能 时以develop为基础创建feature分支。 分支命名: feature/ 开头的为特性分支 命名规则: feature/user_module、 feature/cart_module release 分支 release 为 预上线分支 发布提测阶段会release分支代码为基准提测。当有一组feature开发完成首先会合并到develop分支进入提测时会创建release分支。如果测试过程中若存在bug需要修复则直接由开发者在release分支修复并提交。当测试完成之后合并release分支到master和develop分支此时master为最新代码用作上线。 hotfix 分支 分支命名: hotfix/ 开头的为 修复分支 它的命名规则与feature分支类似。线上出现紧急问题时需要及时修复以master分支为基线创建hotfix分支修复完成后需要合并到master分支和develop分支 更多开发规范请参阅 全网最全的 Git 分支开发规范手册 | 掌握这10条规范轻松搞定Git 拓展Git这些高级用法喜欢就拿去用 Git 提交规范 为什么需要规范 无规矩不成方圆编程也一样。 如果你有一个项目从始至终都是自己写那么你想怎么写都可以没有人可以干预你。可是如果在团队协作中大家都张扬个性那么代码将会是一团糟好好的项目就被糟践了。不管是 开发还是日后维护 都将是灾难。 这时候有人提出了何不统一标准大家都按照这个标准来。于是 ESLintJSHint 等代码工具如雨后春笋般涌现成为了项目构建的必备良品。 Git Commit 规范 可能并没有那么夸张但如果你在版本回退的时候看到一大段糟心的 Commit恐怕会懊恼不已吧。所以严格遵守规范利人利己。 具体请参阅 你可能会忽略的 Git 提交规范 Git使用技巧 只有在遇到问题的时候才体会到技巧带来的好处 常见企业工作流程Git Workflow 当项目需要多人共同开发时规范工作流程就变得越来越重要。合适的工作流程能让多人协同开发更加顺利和高效。 目前主流的Git工作流程有三种 Git Flow版本发布GitHub Flow持续发布GitLab Flow持续发布、版本发布 拓展一文弄懂 Gitflow、Github flow、Gitlab flow 的工作流 Git Flow 主干分支 稳定分支 开发分支 补丁分支 修改分支 Github Flow 创建分支 添加提交 提交 PR 请求 讨论和评估代码 部署检测 合并代码 Gitlab Flow 带生产分支 带环境分支 带发布分支 日常使用最佳实践 总结日常工作中应该遵循的 Git 使用方式 和方法 使用命令行代替图形化界面 使用命令行来操作简洁且效率高 提交应该尽可能的表述提交修改内容 区分 subject 和 body 内容使用空行隔开subject 一般不超过 50 个字符body 每一行的长度控制在 72 个字符subject 结尾不需要使用句号或者点号结尾body 用来详细解释此次提交具体做了什么 使用 .gitignore 文件来排除无用文件 可使用模板文件然后根据项目实际进行修改 基于分支或 fork 的开发模式 不要直接在主干分支上面进行开发在新建的分支上进行功能的开发和问题的修复 使用 release 分支和 tag 标记进行版本管理 使用 release 分支发布代码和版本维护(release/1.32)使用 tag 来标记版本(A-大feature功能.B-小feature功能.C-只修bug) 常用命令汇总整理 日常使用只要记住 6 个命令 就可以了。 工作区 - 暂存区 \) git add file/dir暂存区 - 本地仓库 \( git commit -m some info本地仓库 - 远程仓库 \) git push origin master # 本地master分支推送到远程origin仓库 工作区 - 暂存区 \( git checkout -- file # 暂存区文件内容覆盖工作区文件内容暂存区 - 本地仓库 \) git reset HEAD file # 本地仓库文件内容覆盖暂存区文件内容本地仓库 - 远程仓库 \( git clone git_url # 克隆远程仓库 \) git fetch upstream master # 拉取远程代码到本地但不应用在当前分支 \( git pull upstream master # 拉取远程代码到本地但应用在当前分支 \) git pull –rebase upstream master # 如果平时使用rebase合并代码则加上工作区 - 本地仓库 \( git reset commit # 本地仓库覆盖到工作区(保存回退文件内容修改) \) git reset –mixed commit # 本地仓库覆盖到工作区(保存回退文件内容修改) \( git reset --soft commit # 本地仓库覆盖到工作区(保留修改并加到暂存区) \) git reset –hard commit # 本地仓库覆盖到工作区(不保留修改直接删除掉)更多关于Git的使用技巧介绍请查阅学会这 11 条你离 Git 大神就不远了
- 上一篇: 东明县网站建设wordpress 发布服务器
- 下一篇: 东拼西凑网站谁做的云奇网站建设
相关文章
-
东明县网站建设wordpress 发布服务器
东明县网站建设wordpress 发布服务器
- 技术栈
- 2026年03月21日
-
东盟建设集团有限公司网站邢台人才网
东盟建设集团有限公司网站邢台人才网
- 技术栈
- 2026年03月21日
-
东丽区网站建设公司网络创建公司网站
东丽区网站建设公司网络创建公司网站
- 技术栈
- 2026年03月21日
-
东拼西凑网站谁做的云奇网站建设
东拼西凑网站谁做的云奇网站建设
- 技术栈
- 2026年03月21日
-
东平网站制作哪家好黑龙江网上建设局报建网站
东平网站制作哪家好黑龙江网上建设局报建网站
- 技术栈
- 2026年03月21日
-
东圃做网站wordpress谷歌广告不显示不出来
东圃做网站wordpress谷歌广告不显示不出来
- 技术栈
- 2026年03月21日






