一文带你读懂什么是Git版本管理
发布时间 - 2022-02-21 00:00:00 点击率:次本篇文章中给大家带来了关于git版本管理的相关知识,版本管理工具能够纪录每次的修改,只要提交到版本仓库,就可以找到之前任何时刻的状态,希望对大家有帮助。
Git是一个“分布式版本管理工具”。
版本管
理工具能够纪录每次的修改,只要提交到版本仓库,就可以找到之前任何时刻的状态。
我们在写东西的时候都用过撤消这个功能,但是撤消只能回撤有限步,通常关闭编辑软件后再重新打开,此时的撤销纪录都已被清空了。而“版本管理工具”则不同,它能记录每次的修改,只要提交到版本仓库,就可以找到之前任何时刻的状态。
创建仓库
安装git软件后,在任意目录下创建一个新文件夹,打开,然后执行git init来创建新的git仓库(该命令将创建一个名为.git的隐藏子目录)。
检出仓库
执行命令git clone + 远程项目地址,用来克隆远端服务器上的仓库。
Git状态
Git有三种状态,分别是已提交(committed)、已修改(modified)、已暂存(staged)。
- 已修改(modified):已修改表示修改了文件,但还没保存到数据库中。
- 已暂存(staged):表示对一个已修改文件的当前版本做了标记,使之包含在下次提交的快照中。
- 已提交(committed):数据已经安全的保存在本地数据库中。
Git的三种状态分别对应本地仓库的三个工作流,本低仓库是由git维护的三棵树组成。
- 第一个是工作目录,持有实际文件,增删文件和内容;
- 第二个是暂存区(Index),像个缓存区域,临时保存改动。输入git add+filename,此次改动就放到了暂存区。
- 第三个是HEAD,指向最后一次提交的结果。输入git commit命令,此次改动就放到了本地仓库。commit之后的可以称为一个版本。
git基本工作流程:
- 提出更改(添加到暂存区)
使用命令git add (针对特定文件)或git add *(针对所有文件)可以提出更改(把它们添加到暂存区)。 - 提交改动
使用命令git commit -m “代码提交信息” 来实际提交改动,执行完后改动就提交到了HEAD,但是还没到远端仓库。 - 推送改动
使用命令git push origin master 将改动提交到远端仓库master分支(通常不会直接提交到master分支,而是推送到自己的分支,核对无误后再进行merge)。
分支
前面提到了master分支,那么如何直观的了解分支呢?
分支是用来将特性开发绝缘开来的。在创建仓库的时候,master是“默认”分支。在其他分支上进行开发,完成后再将它们合并到主分支上。
| git branch test1 | 创建一个名字为test1的分支。 |
|---|---|
| git checkout test1 | 切换当前分支到test1 |
| git checkout -b test1 | 创建一个叫做“test1”的分支,并切换过去。 |
| git checkout master | 切换回主分支。 |
| git branch -d test1 | 把新建的分支删掉。 |
| git push origin | 将分支推送到远端仓库。 |
| git merge test | 合并分支。 |
更新与合并
使用命令git pull “远程分支名” 从远程获取代码并合并到本低的版本(在工作目录中获取(fetch)并合并(merge)远端的改动)
使用命令git merge “分支名” 把合并其他分支到当前分支。
前面的两种情况,git都会尝试去自动合并改动。但合并可能会出现冲突(conflicts),需要手动修改文件来合并这些冲突。改动后执行git add 将它们标记为合并成功。在合并改动之前,可以使用git diff
替换本地改动
如果操作失误,可以使用命令git checkout – 替换掉本地改动。该命令会使用 HEAD中的最新内容替换掉工作目录中的文件(已添加到暂存区的改动以及新文件都不会受到影响)
远程仓库的移除和重命名
将test重命名为test1:git remote rename test test1
移除远程仓库test1: git remote rm test1
撤销操作
取消暂存的文件:git reset filename
撤销对文件的修改:git checkout –filename
历史纪录
使用git log可以得到本地仓库的历史记录。
使用命令git log --author=bob来只看某个人的提交记录。添加一些参数来修改输出,从而得到自己想要的结果。
查看哪些文件改变了: git log --name-status
推荐学习:《Git教程》
# git
# 分布式
# 数据库
# 远端
# 创建一个
# 就可以
# 可以使用
# 数据库中
# 移除
# 自己的
# 是一个
# 并到
# 还没
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
如何用PHP快速搭建高效网站?分步指南
活动邀请函制作网站有哪些,活动邀请函文案?
Laravel模型关联查询教程_Laravel Eloquent一对多关联写法
再谈Python中的字符串与字符编码(推荐)
网站页面设计需要考虑到这些问题
如何选择PHP开源工具快速搭建网站?
佛山企业网站制作公司有哪些,沟通100网上服务官网?
Laravel定时任务怎么设置_Laravel Crontab调度器配置
Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区
制作企业网站建设方案,怎样建设一个公司网站?
Laravel如何配置和使用队列处理异步任务_Laravel队列驱动与任务分发实例
Thinkphp 中 distinct 的用法解析
Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
敲碗10年!Mac系列传将迎来「触控与联网」双革新
如何打造高效商业网站?建站目的决定转化率
免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?
javascript中数组(Array)对象和字符串(String)对象的常用方法总结
如何利用DOS批处理实现定时关机操作详解
专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?
香港服务器选型指南:免备案配置与高效建站方案解析
,怎么在广州志愿者网站注册?
微信小程序 require机制详解及实例代码
laravel服务容器和依赖注入怎么理解_laravel服务容器与依赖注入解析
开心动漫网站制作软件下载,十分开心动画为何停播?
nodejs redis 发布订阅机制封装实现方法及实例代码
零基础网站服务器架设实战:轻量应用与域名解析配置指南
Android仿QQ列表左滑删除操作
JS中对数组元素进行增删改移的方法总结
Android使用GridView实现日历的简单功能
Laravel如何使用Eloquent ORM进行数据库操作?(CRUD示例)
Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】
iOS UIView常见属性方法小结
Laravel如何使用Sanctum进行API认证?(SPA实战)
Laravel如何实现API资源集合?(Resource Collection教程)
香港服务器租用费用高吗?如何避免常见误区?
如何在IIS中新建站点并配置端口与IP地址?
大型企业网站制作流程,做网站需要注册公司吗?
Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】
如何用已有域名快速搭建网站?
Laravel如何编写单元测试和功能测试?(PHPUnit示例)
专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?
网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?
怎样使用JSON进行数据交换_它有什么限制
浅谈Javascript中的Label语句
Laravel如何发送邮件_Laravel Mailables构建与发送邮件的简明教程
如何用好域名打造高点击率的自主建站?
米侠浏览器网页图片不显示怎么办 米侠图片加载修复

