GIT是什么
GIT是一种分布式版本控制工具。GIT是通过快照的方式管理文件的版本,即GIT保存了文件的所有版本,进而用户可以返回到如何操作前的版本。比如你不小心将一些GIT中的重要文件(非GIT的配置文件)删除了,你可以使用GIT回滚到删除前,就和没有删除一样,但是GIT会进行记录。
GIT和SVN的区别
管理方式的不同
GIT是通过快照的方式来管理文件,而SVN是通过增量式来管理文件。增量式是一种记录用户对文件修改的那个部分,不会记录文件重复的那个部分。当调用程序时,SVN会将原文件会修改部分叠加起来,组成最终的程序。
权限管理的不同
SVN是不允许不是同一个组的开发者修改代码。GIT允许不是同一个组的开发者修改代码,但是需要程序的拥有者审核同意后才能真正修改程序的代码。
版本控制的不同
GIT是分布式控制工具,而SVN是集中式控制工具。其管理方式如图
data:image/s3,"s3://crabby-images/559c9/559c93bacf485e28c62a932ccff6afc1e4ba9262" alt=""
data:image/s3,"s3://crabby-images/19e70/19e7049b14e4916598f409af802dc047849403ae" alt=""
可以看的出来分布式的数据会比较安全,因为每个用户都有该项目的完整信息,如果有个用户的数据丢失了,可以利用别的用户来恢复。但是集中式需要确保服务器一直保持正常工作,不能出错,不然的话,数据就有可能丢失。
优势
大部分操作是在本地完成,不需要联网
保证上传信息的完整性
版本迭代通常采用增加版本,而不是删除或替代
分支操作流畅
兼容linux
GIT的结构
data:image/s3,"s3://crabby-images/fe024/fe024ef398694fae05308bc511853efecd92eb2c" alt=""
GIT基本命令
初始化
命令:
git init
data:image/s3,"s3://crabby-images/088da/088da072c884c2118588106e8a016f87ca600afc" alt=""
效果:
data:image/s3,"s3://crabby-images/9d8c1/9d8c162dd31b87d3e7b203a857a16611ae107c6a" alt=""
设置签名:
签名的作用:
只用于区分用户的身份,用户名和Email可以和GitHub上注册的不一样,Email可以是无效的.
项目级别/仓库级别:
仅在当前本地库范围内有效.
命令
git config user.name 用户名
git config user.email email
系统用户级别:
在整个操作系统范围内有效.
命令
git config --global user.name 用户名
git config --global user.email email
级别优先级
就近原则:当有两种签名时,优先使用项目级别
如果只有系统用户级别的签名,就以系统用户级别的签名为准
不存在两者都不存在
状态查看
命令
git status (查看工作区和暂存区的情况)
效果
data:image/s3,"s3://crabby-images/78b5c/78b5c6c6f33c75811c85ae6010197b68128bfb35" alt=""
添加
命令
git add 文件名
效果
data:image/s3,"s3://crabby-images/c27a6/c27a68e5c4e9c70305382f06f4eb12826ad4cf61" alt=""
提交
命令
git commit 文件名
效果
data:image/s3,"s3://crabby-images/ded76/ded76f8e2b64cc4bb694704fdaf245484d8e2ef3" alt=""
data:image/s3,"s3://crabby-images/78493/78493b47a31990a6abc7a31e0256a107f5520536" alt=""
查看历史记录
命令
git log 显示详细信息
data:image/s3,"s3://crabby-images/b84ed/b84edd66b1968b44f5a38257e820305f5246b79f" alt=""
git log --pretty=oneline
data:image/s3,"s3://crabby-images/294c3/294c35b4e281a05dc419759f5714b069f428f257" alt=""
git log --oneline
data:image/s3,"s3://crabby-images/cf5b9/cf5b93c153b97f0bb15038dc45feda0f0d95eb02" alt=""
git reflog
data:image/s3,"s3://crabby-images/d27dd/d27dd18cc4d5a5797aa3a421256dc76f78715e73" alt=""
显示版本所需移动的信息
版本的移动
本质
HEAD是一个指针,所以版本的移动本质是移动HEAD指针
命令
git reset --hard 局部索引值
git reset --hard HEAD^ (只能后退,有几个^就后退几步)
git reset --hard HEAD~数字 (数字表示后退几个版本)
效果
data:image/s3,"s3://crabby-images/ebdad/ebdadff0bd389f33314513d3b094cc1c0fac0687" alt=""
data:image/s3,"s3://crabby-images/c4354/c4354a2118ff57f1de51f9321d3290fe434e5e07" alt=""
删除文件并找回
本质
版本的回溯,所以只能返回到提交文件到本地库的那个状态.如果没有提交,就不能恢复.
命令
git reset --hard 局部索引值(找删除前的版本即可)
比较文件的差异
命令
git diff 文件名(默认和暂存区进行比较)
data:image/s3,"s3://crabby-images/b8b6a/b8b6ad8fa7fdee36c8978d54ff5984cb466f23af" alt=""
git diff 本地库历史版本 文件名
data:image/s3,"s3://crabby-images/9b735/9b735b2f225fba530442d134282fa5b45189eb4f" alt=""
git diff (比较所有文件的差异)
data:image/s3,"s3://crabby-images/38016/38016612d9c02ac9f4b03c4791548c8d6280bcab" alt=""
分枝管理
什么是分枝
在版本迭代中,使用多用户同时推进版本的更新。
分枝的好处
同时开发,提高效率
各个分枝在开发过程中是相对独立的,如果一个分枝开发失败(并不会影响别的分枝),可以克隆一份别的分枝,继续开发。
命令
创建分支:
git branch 分支名
查看分枝
git branch -v
切换分枝
git checkout 分枝名
data:image/s3,"s3://crabby-images/1d333/1d333eeb8bb02399862c9468cce7a51dcc040307" alt=""
合并分枝
步骤:
第一步:切换到需要更新内容的分支上(git checkout 分枝)
第二步:执行git merge 有新内容的分支名
冲突的解决
第一步:与版本冲突的开发人员协商,并修改文件(包括删除git新增符号)
第二步:git add 文件名
第三步:git commit -m "修改信息"
data:image/s3,"s3://crabby-images/7eb44/7eb443a673e3d8e99fd43e1c956a2ac5b2b65dd4" alt=""
data:image/s3,"s3://crabby-images/0ba6a/0ba6a4ecb418341993887852aec6f912c57832c3" alt=""
来源:https://www.cnblogs.com/whllow/p/12195231.html