51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 691|回复: 0
打印 上一主题 下一主题

[原创] 浅谈Git分布式版本控制系统

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2022-11-21 16:09:13 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 草帽路飞UU 于 2022-11-21 16:10 编辑

初识Git版本控制



  自动化测试代码反复执行,如果借用持续集成工具会提高测试效率,那么需要我们把自动化测试代码发布到正式环境中,这时候用Git版本控制工具高效、稳定、便捷。

  分布式版本控制


  Git可以把代码仓库完整地镜像下来,有完整的历史记录,它可以与远端代码库进行交互。

  简史


  Git诞生于2005年,速度快,极适合管理大项目。

  Git是什么


  其他版本控制系统如SVN,是随时间变化的差异性文件比较,在某时间段某些文件进行更新。

  Git是快照流,存储项目随时间改变的快照,几乎大部分操作都只需要访问本地文件和资源。保证完整性,用哈希Hash,一般只添加数据,不删除。


  Git三种状态:


  已修改:在工作区修改文件,但没保存到数据库


  已暂存: 在暂存区对已修改的文件做标记,使其包含在下次提交的快照中


  已提交:在Git目录安全地保存数据到本地数据库


  基本Git工作流程:


  ①工作区修改文件;


  ②暂存区将下次提交的更改选择性暂存,修改部分添加到暂存区;


  ③提交更新,找到暂存区的文件,将快照永久保存在Git目录。


  命令行


  所有人都有命令行工具,会命令行则应该会GUI。

  安装Git


  本次实践安装的最新版2.36.0,官网下载windows版本https://git-scm.com/download/win

  初次运行Git前的配置


  1)设置用户信息,以下命令:


git config --global user.name “”


git config --global user.email “”




  如果想给特定项目设置用户信息,则在该项目目录下运行无--global的命令。


  2)设置文本编辑器,如未配置,Git会使用操作系统自带的编辑器。


  设置notepad++为文本编辑器:


git config --global core.editor “’d:\dev\notepad++\notepad++.exe” -multiInst -notabbar -nosession -noPlugin”



  3)检查配置信息:


git config --list




可逐项检查,如:

git config username


获得帮助


  git help +Verb,例如git help config。如果不用全面只需快速参考,使用命令git +Verb -h,例如git add -h。

  Git基础

  获取Git仓库


  两种获得Git项目仓库的方式:

  ① 对尚未进行版本控制的本地目录转换为Git仓库;

  ② 从其他服务器克隆一个已存在的Git仓库。

  (1)对已存在目录中初始化仓库
  如果有一个尚未进行版本控制的项目目录,想要用Git控制它,那么需要进入该项目目录中。

  在Windows上:

cd c/user/my_project


  之后执行:

git init

  该命令将创建名为.git的子目录,这个子目录含有你做初始化的Git仓库中所有的必须文件,这些文件是Git仓库的骨干。这时,我们仅仅是做了一个初始化的操作,你的项目里的文件还没有被跟踪。

  如图所示:





如果在一个已存在文件的文件夹(非空文件夹)中进行版本控制,应该开始追踪这些文件并进行初始提交。

  可以通过git add命令指定所需的文件进行追踪,然后执行git commit:

git add *.c

git add LICENSE

git commit -m ‘initial project version’

  如图所示:



这样已经得到了一个存在被追踪文件与初始提交的Git仓库。

  (2)克隆现有的仓库
  如果想获得一份已经存在了的Git仓库的拷贝,比如说,想为某个开源项目贡献自己的一份力,这时就要用到git clone命令。

  如果对其他VCS系统(比如Subversion)很熟悉,请留心以下所使用的命令是“clone”而不是“checkout”。这是Git区别于其他版本控制系统的一个重要特性,Git克隆的是该Git仓库服务器上的几乎所

有数据,而不是仅仅复制完成你的工作所需要文件。

  当你执行git clone命令的时候,默认配置下远程Git仓库中的每一个文件的每个版本都将被拉取下来。实际上,如果服务器磁盘坏掉了,通常可以使用任何一个克隆下来的用户端来重建服务器上的仓库

(虽然可能会丢失某些服务器端的hook设置,但是所有版本的数据仍在)。

  克隆仓库的命令是git clone。比如,要克隆Git的自建项目HTMLTestRunner,可以用下面的命令:

  这会在当前目录下创建一个名为“HTMLTestRunner”的目录,并在这个目录下初始化一个.git文件夹,从远程仓库拉取下所有数据放入.git文件夹,然后从中读取最新版本的文件的拷贝。

  如果打开这个新建的HTMLTestRunner文件夹,会发现所有项目文件已经在里面了,准备就绪等待后续的开发和使用。

  如下图:




如果想在克隆远程仓库的时候,自定义本地仓库的名字,可以通过额外的参数指定新的目录名:

git clone https://github.com/mingming1205/HTMLTestRunner myhtmltestrunner

  这会执行与上一条命令相同的操作,但是目标目录名变成了myhtmltestrunner。

  如下图:





Git支持多种数据传输协议。以上的例子使用的是https://协议,不过也可以使用git://协议或者使用 SSH 传输协议,例如user@server:path/to/repo.git。

  至于所有这些协议在服务器端是如何配置使用,以及各种方式之间的利弊请查看“在服务器上搭建 Git”的介绍。

  记录每次更新到仓库

  执行命令:

git commit -m  “描述”




查看提交历史


  执行命令:

git log



如果附带一系列总结的文字,执行命令:

git log --stat


如果限制日志查看数量,执行命令git log -p -2,当退出log时,在冒号“:”后面敲q即可。



感谢大家的阅读,希望你们能从中有所收获!
















本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?(注-册)加入51Testing

x
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

本版积分规则

关闭

站长推荐上一条 /1 下一条

小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

GMT+8, 2024-11-23 13:36 , Processed in 0.066071 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

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