Git 版本控制系统


一、Git 介绍

Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。与常用的版本控制工具 CVS、Subversion 等不同,它采用了分布式版本库的方式,不必服务器端软件支持。接下来看看 Git 与 SVN 之间的区别及其工作流程。

Git官网

Git 官方中文手册

二、Git 与 SVN 的区别

  • GIT 是分布式的,SVN 不是:这是 GIT 和其它非分布式的版本控制系统最核心的区别。
  • GIT 把内容按元数据方式存储,而 SVN 是按文件(所有的资源控制系统都是把文件的元信息隐藏在一个类似**.svn,.cvs**等的文件夹里)
  • GIT 分支和 SVN 的分支不同:SVN 分支就是版本库中的另外的一个目录。
  • GIT 没有一个全局的版本号,而 SVN 有:目前为止这是跟SVN相比GIT缺少的最大的一个特征。
  • GIT 的内容完整性要优于 SVN:GIT的内容存储使用的是SHA-1哈希算法。这能确保代码内容的完整性,确保在遇到磁盘故障和网络问题时降低对版本库的破坏。

三、Git 工作流程

在这里插入图片描述

四、Git 基本概念

  • 工作区:
    就是你在电脑里能看到的目录。

  • 暂存区:
    英文叫stage, 或index。一般存放在"git目录"下的index文件(.git/index)中,所以我们把暂存区有时也叫作索引(index)。

  • 版本库:
    工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。

    为什么叫版本库呢?实际上不难理解,好比一个研发人员写完代码后,最终会将代码push到远程仓库上,那么对于研发人员来说,他push的这一次就好比他写的代码的第一个版本,并且将他的这个版本上传到了他自己的仓库中,也就是我们说的版本库(即.git目录)。

在这里插入图片描述

五、Git 基本操作

5.1 SSH Clone 远程仓库代码

[root@web ~]# git clone git@192.168.139.154:/home/git/sz2002.git
[root@web ~]# cd sz2002   # 进入克隆下来的工作目录
[root@web sz2002]# git pull origin master   # 拉取代码(de每次写代码的时候都会拉取代码)--保证数据的完整性,防止文件冲突
[root@web sz2002]# mkdir html   # 可在工作目录中创建相关不得目录

[root@web sz2002]# git add .           # 添加到暂存区
[root@web sz2002]# git status          # 查看缓存区都添加了哪些内容
[root@web html]# git checkout .        # 如果发现代码写错了,使用该命令踢出暂存区的内容再次修改相关文件内容后,再add即可

[root@web sz2002]# git commit -m 'HTML代码提交'   # 添加到本地仓库.git,如果想要对文件再次进行修改,可以不用再次执行git checkout . 命令,直接vim修改文件、正常提交即可。因为到这一步仅仅是将数据存到了我.git的本地私人仓库,并没有push到远程仓库。

[root@web sz2002]# git remote -v           # 看远程仓库信息,一般你从哪里clone的,就会显示哪个仓库信息

[root@web sz2002]# git push origin master  # 将写的代码推到Git平台上,给项目经理看,或方便其他开发人员pull代码

5.2 HTTP Clone 远程仓库代码

[root@web ~]# git clone http://192.168.139.154/home/git/sz2002.git
[root@web ~]# cd sz2002   # 进入克隆下来的工作目录
[root@web sz2002]# git pull origin master   # 拉取代码(de每次写代码的时候都会拉取代码)--保证数据的完整性,防止文件冲突
[root@web sz2002]# mkdir html   # 可在工作目录中创建相关不得目录

[root@web sz2002]# git add .           # 添加到暂存区
[root@web sz2002]# git status          # 查看缓存区都添加了哪些内容
[root@web html]# git checkout .        # 如果发现代码写错了,使用该命令踢出暂存区的内容再次修改相关文件内容后,再add即可

[root@web sz2002]# git commit -m 'HTML代码提交'   # 添加到本地仓库.git,如果想要对文件再次进行修改,可以不用再次执行git checkout . 命令,直接vim修改文件、正常提交即可。因为到这一步仅仅是将数据存到了我.git的本地私人仓库,并没有push到远程仓库。

[root@web sz2002]# git remote -v           # 看远程仓库信息,一般你从哪里clone的,就会显示哪个仓库信息

[root@web sz2002]# git push origin master  # 将写的代码推到Git平台上,给项目经理看,或方便其他开发人员pull代码

注:HTTP 操作和 SSH 一致,只是 clone 的方式不同,再就是 HTTP 方式的 clone 需要输入用户名及密码。

5.3 Git 常用命令

git init                      # 初始化 
git add main.cpp              # 将某一个文件添加到暂存区 
git add .                     # 将文件夹下的所有的文件添加到暂存区 
git commit -m ‘note‘          # 将暂存区中的文件保存成为某一个版本 
git log                       # 查看所有的版本日志 
git status                    # 查看现在暂存区的状况 
git diff                      # 查看现在文件与上一个提交-commit版本的区别 
git reset --hard HEAD^        # 回到上一个版本 
git reset --hard XXXXX        # XXX为版本编号,回到某一个版本 
git pull origin master        # 从主分支pull到本地 
git push -u origin master     # 从本地push到主分支 
git pull                      # pull默认主分支 
git push                      # push默认主分支 ...

Git 的用法还有很多,这里就不再一一例举,只不过是让大家初步了解一下什么是 Git、Git 的工作原理、基本操作命令以及 Git 和其他版本控制系统的区别。

<点击跳转至开头>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

云计算-Security

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值