热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

双十一在家学用Git

对于所有的开发者来说,掌握一门代码版本控制系统都是必须的,无论是自己做项目,团队合作,工作中的合作,都离不开版

对于所有的开发者来说,掌握一门代码版本控制系统都是必须的,无论是自己做项目,团队合作,工作中的合作,都离不开版本控制系统的帮助。然而目前大多数初学的开发者还不了解或者还停留在几个常用的指令,那么毫无疑问是不够的。详细的了解 Git 和如何高效的使用 Git 是这篇文章要说的。

两种主要的版本控制系统

版本控制系统主要分为两个类型:集中式和分布式。相信现在还有不少的公司或团队选择的版本控制系统是 svn ,svn就是一个典型的集中事版本控制系统。而 Git 则是一个分布式版本控制系统。

什么是集中式版本控制系统

集中式版本控制系统需要一台服务器作为中央服务器,这个服务器充当我们的完整版本库,我们的其他开发者必须联网才能使用版本控制系统向我们的中央服务器提交代码和下载代码,所有开发者都是对同一个 完整版本库 进行操作。

什么是分布式版本控制系统

在分布式版本控制系统中,每一个开发者的电脑都可以作为一个完整版本库,无论是否联网开发者都可以向代码库进行提交修改等操作,通常情况下需要借助一台服务器以方便大家交换代码,所有开发者将自己的完整代码库与服务器进行同步来进行代码的交换。

gitsvn

分布式版本控制系统的优势

分布式版本控制系统的优势在于开发者无论是否联网,都可以进行工作,将修改提交到自己的完整版本库中。同时每个开发者都拥有这个完整版本库,所以也不必担心因中央服务器出问题而导致所以人都无法工作。而且git的分支切换等操作是基于指针位置的移动,所以性能高。

Git 代码库的分区

在本地文件夹下初始化一个git仓库后,这个仓库存在三个分区:工作区,索引区和数据库。

gitArea

  1. 工作区: 是我们实际操作的区域,也就是说,我们开发时,看到的都是工作区的代码,任何的修改都是对工作区的直接修改。
  2. 数据库: 则是我们的完整版本库,它保存我们对代码的最终修改,也是代码最终的结果。
  3. 索引区:工作区和数据库之间存在着一个索引区,它是为了向数据库提交作准备的区域。

基本的操作

初始化仓库:

git init

将工作区的修改添加到索引区:

git add

将修改的文件添加到索引区,可以通过通配符 “*” ,或“.”来进行批量的操作:

git add file1 file2 file3 // 将指定的多个修改文件添加到索引区
git add *.txt // 将所有txt文件添加到索引区
git add . // 将所有的文件添加到索引区

将索引区中的内容添加到数据库

git commit -m "本次提交的信息"

这样我们就完成了一次完整的修改和提交。

status 和 log

$ git status
On branch master
Your branch is up to date with 'origin/master'.nothing to commit, working tree clean

可以查看当前的状态,比如处于哪一个分支,是否有修改未提交,哪些文件被修改了等等的信息。

git log

可以查看到目前为止的所有的提交记录,它会显示每一个提交的用户、时间、提交信息。

分支(branches)

在 Git 中分支的本质其实是一个指向最新提交的指针,创建不同的分支实际就是创建了多个指针。每一个分支互不影响,可以平行的进行开发,负责不同的任务。

branch

创建新分支,比如新建名为test的分支:

git branch test

切换分支,进入test分支:

git checkout test

合并分支,在master分支中将test分支的修改合并进来:

// 在master分支中
git merge test

删除分支test

git branch -d test

远程仓库

克隆与关联

前面提到了所有开发者将自己的完整代码库与远程仓库进行同步来进行团队合作开发,
通过以下命令克隆或者说下载远程仓库到自己的电脑:

git clone [repository url]

克隆后可以得到一个与远程仓库关联的本地仓库。也可以通过以下命令来直接关联远程仓库:

// 将指定地址的远程数据库关联,并命名为origin
git remote add origin [repository url]

显示远端数据库列表,如:

$ git remote
origin

推送内容与分支修改

向远程仓库推送修改,比如将本地master分支代码推送到远程仓库的master分支:

git push -u origin master

第一次提交的时候通常带上参数 -u ,它的作用是记录这次操作的远程仓库地址等信息。那么我们使用例如 git pull 等命令时后面就不需要再加上对于的分支地址了。不是第一次提交的话可以省略 -u

删除本地某分支后,同步远程数据库,删除远程数据库上的此分支:

git push origin --delete <分支名称>

想将标签也推送到远程数据库&#xff1a;

git push origin --tags

拉取内容与分支修改

将远程仓库分支的最新变化拉去下来&#xff0c;并合并到自己的代码中&#xff1a;

git pull origin <远程仓库分支名称>

默认情况下&#xff0c;git pull 不会同步远程数据库删除的分支&#xff0c;加上参数-p可以在本地删除远程数据库中已经删除的分支&#xff1a;

git pull -p

将远程的数据库的变化提取下来查看&#xff0c;但不合并到当前自己的代码中&#xff1a;

git fetch <远程数据库名称> <分支>

这样会将远端的变化提取到本地&#xff0c;在本地可以通过切换到"远程数据库/分支"来进行查看&#xff0c;比如查看远端master分支的修改&#xff1a;

git checkout origin/master

可以通过git branch指令与队友参数查看所有分支&#xff1a;

// 查看本地和远程所有分支
$ git branch -a
* masterremotes/origin/master// 查看远程所有分支
$ git branch -rorigin/master

标签操作

tag1

标签分为两种&#xff1a;

  1. 轻量标签
  2. 注解标签

轻量标签通常作为临时标签方便我们的开发&#xff0c;注解标签通常为上线的代码标记版本信息&#xff0c;可以通过以下指令创建一个轻量标签&#xff1a;

git tag <标签名称>

还可以给标签添加信息备注来创建一个注解标签

git tag -a <标签名称> -m "备注信息"
// 比如&#xff1a;
git tag -a v1.0 -m "first version"

可以通过以下指令查看已有标签&#xff1a;

$ git tag
v1.0

加上参数 -n 可以连备注一起查看&#xff1a;

$ git tag -n
v1.0 first version

删除分支&#xff1a;

git tag -d <分支名称>

实际开发中运用标签

我们想查看某个标签的内容&#xff1a;

git checkout <标签名称>

这样就可以进入到当前分支中的对应标签中&#xff0c;但是这只能查看标签的内容。
如果你想基于该标签继续进行开发&#xff0c;那么应该先基于该标签新建一个分支&#xff0c;在新分支上进行开发&#xff0c;然后再合并。

git branch <分支名称> <标签名称>

这样就可以基于某一版本并行的开发。

进阶操作

覆盖或修改最近的提交

有时候我们想要用当前的提交去覆盖上一次的提交&#xff0c;避免提交历史中存在多余的提交历史&#xff0c;我们可以使用 --amend参数&#xff1a;

git add <文件名>
git commit --amend -m "新的commit备注"

通过

git log

查看提交记录可以发现此次提交替代了上一次的提交。

取消上一次的提交&#xff08;版本回退&#xff09;

HEAD1

有时候我们需要取消上一次的提交&#xff0c;那么我们可以通过 reset 指令修改 HEAD 指向的位置来实现&#xff1a;

git reset --hard HEAD~
// ~的数量表示取消提交的数量&#xff0c;如果要取消强两次提交的话可以改为 HEAD~~

可以通过查看文件内容或查看git日志的方式来查看是否成功取消了修改。
这里的hard模式的意思是&#xff1a;索引区和工作去都会受到影响&#xff0c;回退到对应的内容。除此之外还有其他的模式&#xff1a;

  1. --soft&#xff1a;仅HEAD的指向退回到对应位置&#xff0c;索引区和工作区内容不变。
  2. --mixed&#xff1a;HEAD位置和索引区内容发送改变&#xff0c;工作区不变。
  3. --hard&#xff1a; HEAD位置和索引区和工作区内容都发送改变。

版本恢复

如果我们版本回退后后悔了想恢复到最新版本怎么办&#xff1f;可以通过commit id来进行移动。

git reset --hard <对应的 commit -id>

如果我们没有记住对应的 commit id 怎么办&#xff1f;可以通过 git reflog 指令来查看命令历史。

$ git reflog
9154108 (tag: v1.1, tag: v1.0, origin/master, master) HEAD&#64;{12}: pull: Fast-forward
1319463 HEAD&#64;{13}: checkout: moving from 9154108ced0df7f7c220bc5440af008aff330e92 to master
9154108 (tag: v1.1, tag: v1.0, origin/master, master) HEAD&#64;{14}: checkout: moving from master to origin/master
1319463 HEAD&#64;{15}: commit (initial): first commit

这样就可以看到每次提交操作对应的 id&#xff08;第一列&#xff09; 了&#xff0c;那么我们想移动到哪个版本都可以了。

参考资料

猴子都能懂得git教学

阮一峰git指令



推荐阅读
  • 本文深入探讨了 Git 与 SVN 的高效使用技巧,旨在帮助开发者轻松应对版本控制中的各种挑战。通过详细解析两种工具的核心功能与最佳实践,读者将能够更好地掌握版本管理的精髓,提高开发效率。 ... [详细]
  • 本文介绍了三种解决 Git Push 冲突的方法,包括创建新分支、手动解决冲突和强行推送。这些方法适用于不同的开发场景,如版本迭代、多人协作和个人开发。 ... [详细]
  • 本文介绍了SIP(Session Initiation Protocol,会话发起协议)的基本概念、功能、消息格式及其实现机制。SIP是一种在IP网络上用于建立、管理和终止多媒体通信会话的应用层协议。 ... [详细]
  • 使用 Git Rebase -i 合并多个提交
    在开发过程中,频繁的小改动往往会生成多个提交记录。为了保持代码仓库的整洁,我们可以使用 git rebase -i 命令将多个提交合并成一个。 ... [详细]
  • 在开发过程中,为了确保代码的实时保存,我们常常会对某个功能进行多次提交。然而,当功能趋于稳定时,将这些分散的提交记录合并为一次提交,可以提高代码仓库的整洁度和可维护性。本文将详细介绍如何使用 Git 巧妙地合并多次提交记录,帮助开发者简化历史记录管理。 ... [详细]
  • AppFog 是一个基于 CloudFoundry 的多语言 PaaS(平台即服务)提供商,允许用户在其平台上轻松构建和部署 Web 应用程序。本文将通过详细的图文步骤,指导读者如何在 AppFog 免费云平台上成功部署 WordPress,帮助用户快速搭建个人博客或网站。 ... [详细]
  • 分布式开源任务调度框架 TBSchedule 深度解析与应用实践
    本文深入解析了分布式开源任务调度框架 TBSchedule 的核心原理与应用场景,并通过实际案例详细介绍了其部署与使用方法。首先,从源码下载开始,详细阐述了 TBSchedule 的安装步骤和配置要点。接着,探讨了该框架在大规模分布式环境中的性能优化策略,以及如何通过灵活的任务调度机制提升系统效率。最后,结合具体实例,展示了 TBSchedule 在实际项目中的应用效果,为开发者提供了宝贵的实践经验。 ... [详细]
  • 最近,我在CentOS 5服务器上成功部署了GForge 5.7 Community Edition。与Advanced Server版本相比,虽然功能略有简化,但仍然能够满足大多数开源项目管理的需求。为了确保数据安全,我开发了一套全自动备份脚本,该脚本能够定期备份GForge的数据和配置文件,并将其存储在远程服务器上,以防止数据丢失。此外,该脚本还具备错误检测和日志记录功能,便于故障排查和维护。 ... [详细]
  • Windows环境下详细教程:如何搭建Git服务
    Windows环境下详细教程:如何搭建Git服务 ... [详细]
  • Mantis Bug Tracker:高效缺陷管理与跟踪系统
    缺陷管理平台Mantis,也做MantisBT,全称MantisBugTracker。Mantis是一个基于PHP技术的轻量级的开源缺陷跟踪系统,以Web操作的形式提供项目管理及缺 ... [详细]
  • 本文提供了一个关于AC自动机(Aho-Corasick Algorithm)的详细解析与实现方法,特别针对P3796题目进行了深入探讨。文章不仅涵盖了AC自动机的基本概念,还重点讲解了如何通过构建失败指针(fail pointer)来提高字符串匹配效率。 ... [详细]
  • 本文探讨了如何在PHP与MySQL环境中实现高效的分页查询,包括基本的分页实现、性能优化技巧以及高级的分页策略。 ... [详细]
  • 本文详细介绍了Oracle 11g中的创建表空间的方法,以及如何设置客户端和服务端的基本配置,包括用户管理、环境变量配置等。 ... [详细]
  • 软件测试行业深度解析:迈向高薪的必经之路
    本文深入探讨了软件测试行业的发展现状及未来趋势,旨在帮助有志于在该领域取得高薪的技术人员明确职业方向和发展路径。 ... [详细]
  • Vim 编辑器功能强大,但其默认的配色方案往往不尽如人意,尤其是注释颜色为蓝色时,对眼睛极为不友好。为了提升编程体验,自定义配色方案显得尤为重要。通过合理调整颜色,不仅可以减轻视觉疲劳,还能显著提高编码效率和兴趣。 ... [详细]
author-avatar
air12345
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有