git
- 版本控制
- 版本控制的分类
- git命令分类
- 基本的Linux命令
- git的环境配置
- git工作原理(核心)
- git项目创建及克隆
- git的基本操作命令
- 使用码云
- idea中集成git
- git分支
版本控制
为了解决版本迭代的
版本控制是一种在开发过程中用于管理我们对文件,目录,工程等内容的修改历史,方便查看更改历史记录,备份以便恢复以前版本的软件工程技术
- 实现跨区域多人协同开发
- 追踪和记载一个或者多个文件的历史记录
- 组织和保护你的文档和源代码
- 统计工作量
- 并行开发,提高开发效率
- 跟踪记录整个软件的开发过程
- 减轻开发人员的负担,节省时间,同时降低人为错误
多人开发必须使用版本控制,不然代价比较大
版本控制的分类
-
本地版本控制
记录文件的每次更新,可以对每一个版本做一个快照,或是记录补丁文件,适合个人用,如rcs -
集中版本控制
所有的版本数据都保存在服务器上,协同开发者从服务器上同步更新或上传自己的修改。
服务器坏了就卒,一般定期保存,如svn -
分布式版本控制系统 git
所有的版本信息仓库全部同步到本地的每个用户,这样就可以在本地查看所有版本历史,可以离线在本地提交,只需在联 时push到相应的服务器或其他用户那里,由于每个用户那里保存的都是所有的版本数据,只要有一个用户的设备没有问题就可以恢复所有的数据,但这增加了本地存储空间的占用
不会因为服务器损坏或者 络问题造成不能工作的情况
git可以直接看到更新了哪些代码
git命令分类
Git Bash:Unix与Linux风格的命令行,使用最多,推荐最多
Git CMD:windows风格的命令行
Git GUI:图形界面的Git,不建议初学者使用,尽量先熟悉常用命令
基本的Linux命令
- cd:改变目录
- cd …:回退到上一个目录,直接cd进入默认目录
- pwd:显示当前目录路径
- clear:清屏(windows 是cls)
- ls(ll):列出当前所有的文件,ll列出内容更详细
- touch:新建一个文件 touch 文件名.文件类型,就会当当前目录下新建文件
- rm:删除文件 remove 文件名.文件类型
- mkdir:新建一个目录,就是新建文件夹
- rm -r:删除一个文件夹,rm -r src 删除src目录
!!!!rm -rf / 不能用,删除根目录,啥都没了 - mv:移动文件 mv 文件名.文件类型 目标文件夹,文件个目标文件夹要在同一个目录下
- reset:重新初始化终端
- history:查看历史记录
- help:帮助
- exit:退出
- #:注释
git的环境配置
查看配置:
- git config -l :查看配置列表
- git config –system –list:查看系统配置列表
- git config –global –list:查看本地配置,用户自己配的
所有配置文件其实都保存在本地
git相关的配置文件:
1.Git/etc/gitconfig:Git安装目录下的gitconfig(系统级)
2.在c盘用户文件下的gitconfig中:只适用于当前登陆用户的配置(用户)
我们可以直接在对应文件里修改配置
用户名和邮箱是必须配置的!!!!
设置用户名和邮箱:
git工作原理(核心)
git本地有三个工作区域:工作目录(work directory),暂存区(stage/index),资源库(repository或者git directory),如果加上远程的git仓库(remove directory)就可以分为四个工作区域,文件在这四个区域的转换关系如下:
- git init :初始化
执行之后可以看到,仅仅在项目目录多出了一个.git目录,关于版本等所有信息都在这个目录里面
2,克隆远程仓库,将远程服务器上的仓库完全镜像一份到本地
- git clone url 克隆一个项目和它的整个代码历史
git的基本操作命令
文件的四种状态:
- Untracked未跟踪,此文件在文件夹中,但并没有加入到git库,不参与版本控制,通过git add状态变为Staged
- Unmodify:文件已入库,未修改,即版本库中的文件快照内容与文件夹中完全一致,这种文件一般有两种去处,如果它被修改,则变为Modified。如果使用git rm移出版本库,则成为Untracked文件
- Modified:文件已修改,仅仅是修改,并没有进行其他的操作,这个文件也有两个去处,通过git add可进入staged状态,使用git checkout则丢弃修改过哟,返回到nmodify状态,这个git checkout即从库中取出文件,覆盖当前修改。
- Staged:暂存状态,执行git commit则将修改同步到库中,这时库中的文件和本地文件又变为一致,文件为Unmodify状态,执行git reset HEAD filename取消暂存,文件状态为Modified。
忽略文件:
有些时候,我们不想把某些文件纳入版本控制,比如数据库文件,临时文件,设计文件等
在主目录下建立“.gitignore”文件,此文件有如下规则:
- 忽略文件中的空行或以井 (#)开始的行将会被忽略
- 可以使用linux通配符。例如:星 (*)代表任意多个字符,问 (代表一个字符,方括 ([abc])代表可选字符范围,大括 代表可选字符串等。
- 如果名称的最前面有一个感叹 ,代表例外规则,将不被忽略
- 如果名称的最前面是一个路径分隔符(/),表示要忽略的文件在此目录下,而子目录中的文件buhulue
- 如果名称的最后面是一个路径分隔符(/),表示要忽略的是此目录下该名称的子目录,而非文件(默认文件或目录都忽略)
使用码云
github是有墙的,比较慢,在国内的话,我们一般使用gitee,公司中有时候会搭建自己的gitlab服务器
1.注册登录,完善信息
2.设置本机绑定shh公钥,实现免密码登录(免密码登录,这一步挺重要的,码云上远程仓库,我们平时工作在本地仓库)
idea中集成git
1.新建项目,绑定git
- 将我们远程的git文件目录拷贝到项目中即可
- 注意观察idea中的变化
2.修改文件,使用idea操作git - 添加到暂存区
- commit提交
- push到远程仓库
3.提交测试
以上都是单个人的操作
git分支
git分支中常用指令
多个分支如果并行执行,就会导致我们代码不冲突,也就是同时存在多个版本
如果冲突的话协商即可
如果同一个文件在合并分支时都被修改了则会引起冲突,解决的办法是我们可以修改冲突文件后重新提交!!!(选择要保留哪一版)
master主分支应该非常稳定,用来发布新版本,一般情况下不允许在上面工作,工作一般情况下在新建的dev分支上工作,工作完成后,比如要发布,或者dev分支代码稳定后可以合并到主分支master上来。
文章知识点与官方知识档案匹配,可进一步学习相关知识Git技能树首页概览2942 人正在系统学习中
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!