Git版本控制工具--关于命令

Git版本控制工具

学习前言

在项目开发中,总是需要多个人同时对一个项目进行修改,如何高效快速地进行修改,且控制各自修改的版本不会和他人的进行重叠,这就需要用到Git分布式版本控制器了

作用

解决了一致性,并发性,安全性,实现了如

  • 代码还原
  • 并行开发
  • 统计工作量
  • 版本控制

这些功能,目前为主流版本控制器,除此之外,还有SVN,CVS,VSS,TF等工具来实现版本的控制

分布式版本控制的好处

每个人都可以从同一个远程仓库中将所需修改的文件,push到自己的本地仓库中,再调到工作区进行修改,而且本地仓库中也有一个完整的项目程序,++避免了如果服务器崩溃或者远程仓库出故障而导致项目代码全部丢失++,也可以高效地进行版本控制。

缺点

会增加本地存储的占用

Git的历史

Linux内核开源项目有许多参与者,但维护Linux需要进行大量的补丁以及保存归档的操作,因此项目组启用了一个其他公司所设计的分布式版本控制系统BitKeeper,但后来该公司收回了Linux内核开源项目免费使用该系统的权力,导致linux项目组需要另找一个分布式版本控制系统

因此,Linux的缔造者,Linus Torvalds花费了几周时间,做出了属于自己的版本系统,也就是Git

Git安装

Git Bash 推荐

Git CMD Windows风格的命令行

Git GUI图形界面,不建议初学者使用,而且该GUI也并不好用,不美观

Git如何使用

Git的粗略工作流程

图解:

linux常见命令

命令 作用
ls/ll 查看当前目录
cat 查看文件内容
touch 创建文件
tail n 1 以顺序或者倒序的方式查看文件中的某一行内容
yy 复制当行
dd 剪切当行
p 粘贴
vim 编辑文件(若没有该文件则创建)进入后默认为命令模式
i 进入输入模式
命令 作用
Esc 退出输入模式
:wq 在命令模式下保存修改并退出文件

Git-命令

  • git config --global user.name/email 用户名/邮箱 ==> 设置用户签名

    在刚开始安装git时需要进行设置,以后通过同样的命令可以进行修改

  • git init ==> 初始化本地仓库

  • git status ==> 查看本地仓库状态

  • git add 文件 ==> 添加到暂存区

  • git rm-cached 文件 ==> 将某文件从暂存区中删除

    只是删除了在暂存区中的数据,工作区中的文件没有被删除

  • git commit -m "日志信息" 文件 ==> 将暂存区文件提交到本地仓库

  • git reflog ==> 刷新并查看日志信息

  • git log ==> 查看详细的日志信息


[!IMPORTANT]

在进行Git命令操作中,我创建了两个.txt文件

初始化本地库

获得目录的管理权限,后续可以进行Git命令操作

查看本地库状态

第一行:目前处于哪个分支

第二行:是否提交过文件到本地仓库中

第三行:是否有东西可以提交(包含被追踪或未被追踪的文件)

----被追踪标识文件被放到了暂存区

添加文件到暂存区中

警告内容为当文件被再次创建及修改时,换行命令LF会改为CRLF

由于是在Windows环境中使用git,因此换行命令会改为windows中用的命令

将暂存区文件提交到本地仓库中

hello.txt被push到本地仓库后,没有被修改的工作区的源文件显示无需提交到本地仓库中,因为已经有了一个保存的版本在本地仓库中了

git log显示了详细的关于本地仓库文件的日志信息,包括上传时的msg,设置的用户签名以及上传的时间

区别

上下两个黄色字样的字体分别为++完整的版本号++ 和++精简的版本号++

当有提交到了本地仓库的文件,且后续被修改了,若没有存到暂存区中,则会出现红色字样的modiffied: hello.txt

存到暂存区后,则会显示出绿色字样

当再次上传到本地仓库,就会把之前同名的文件给更改,并替换对应的日志信息

[!IMPORTANT]

HEAD -> master指针永远指向最新的版本文件

版本穿梭

git reset --hard 版本号 --可以先通过git reflog查看想要回复到的版本的版本号

【HEAD->master会指向新的版本】

相关推荐
网安kk10 分钟前
2024年三个月网络安全(黑客技术)入门教程
网络·安全·web安全
lfsun66628 分钟前
【60天备战2024年11月软考高级系统架构设计师——第36天:系统安全设计——数据加密】
安全·系统安全
拉格朗日(Lagrange)4 小时前
前置机、跳板机、堡垒机:安全运维领域的“黄金三角”
运维·安全
leeezp4 小时前
安全运营 -- GPO审计
安全
网络研究院4 小时前
实施威胁暴露管理、降低网络风险暴露的最佳实践
网络·安全·漏洞·管理·风险·威胁·实践
Robbie丨Yang7 小时前
bash 脚本获取当前 git 所有本地分支
开发语言·git·bash
刀客1239 小时前
版本控制-git
git
AAA 建材批发王哥(天道酬勤)9 小时前
SSH(安全外壳协议)可以基于多种加密算法
运维·安全·ssh