Git简单使用
以下部分内容由菜鸟教程整理而来。地址:https://www.runoob.com/git/git-tutorial.html。
1、github和git
1.1、关于github
GitHub是一个面向开源及私有软件项目的托管平台,因为只支持Git作为唯一的版本库格式进行托管,故名GitHub。
GitHub于2008年4月10日正式上线,除了Git代码仓库托管及基本的Web管理界面以外,还提供了订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等功能。目前,其注册用户已经超过350万,托管版本数量也是非常之多,其中不乏知名开源项目 Ruby on Rails、jQuery、python 等。2018年6月4日,微软宣布,通过75亿美元的股票交易收购代码托管平台GitHub。
小结:github是一个开源的代码托管平台,只支持git作为唯一的版本库进行托管。
1.2、关于git
Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。Git是 Linus Torvalds为了帮助管理Linux内核开发而开发的一个开放源码的版本控制软件。Git与常用的版本控制工具 CVS、Subversion等不同,它采用了分布式版本库的方式,不需要服务器端软件支持。
小结:git是一个开源的分布式的版本控制系统,通过使用git,你可以将代码托管到github平台上。使用git的前提是你必须拥有一个github账号。
1.3、github和git的联系和区别
- github只是一个代码托管的平台,这个平台给用户提供git服务,用户在github上注册了账号,那么就不必再搭建git服务器了,直接使用github平台提供的git服务就行了。
- git是一个分布式版本控制系统,和svn、cvs等是同级概念。
注意:使用github托管代码前,最好注册一个github的账号,这样能更好的使用git服务了。
2、git和svn的区别
先看图示:
Git不仅仅是个版本控制系统,它也是个内容管理系统(CMS),工作管理系统等。它与SVN的主要区别如下:
- Git是分布式的,SVN 不是。这是Git和其它非分布式的版本控制系统,例如SVN,CVS 等,最核心的区别。
- Git把内容按元数据方式存储,而SVN是按文件存储。所有的资源控制系统都是把文件的元信息隐藏在一个类似 .svn、.cvs 等的文件夹里。
- Git分支和SVN分支不同。分支在SVN中一点都不特别,其实它就是版本库中的另外一个目录。
- Git没有一个全局的版本号,而SVN有。目前为止这是跟SVN相比Git缺少的最大的一个特征。
- Git的内容完整性要优于SVN。Git的内容存储使用的是SHA-1哈希算法。这能确保代码内容的完整性,确保在遇到磁盘故障和网络问题时降低对版本库的破坏。
3、git的安装及配置
3.1、git安装
先去官网下载:
下载合适版本。
直接运行安装:
一路点击Next按照默认的配置就行了。
安装完毕后的目录:
桌面:
3.2、git配置
点击Git Bash进入命令,也可以通过右键进入。配置用户名和邮箱:
// 配置用户名
git config --global user.name "xxxxxx"
// 配置用户邮箱,在github上绑定的
git config --global user.email "xxxxxxxx@xxx.com"
查看配置信息的话可以使用git config --list
命令。如下:
4、git的工作流程
先看工作流程图示:
过程说明:
- 克隆Git资源作为工作目录。
- 在克隆的资源上添加或修改文件。
- 如果其他人修改了,你可以更新资源。
- 在提交前查看修改。
- 提交修改。
- 在修改完成后,如果发现错误,可以撤回提交并再次修改并提交。
5、git的工作区、暂存区、版本库
关系图示:
- 工作区:就是电脑上的普通目录。
- 暂存区:英文叫stage或index。一般存放在.git 目录下的index文件(.git/index)中,所以我们把暂存区有时也叫作索引(index)。
- 版本库:工作区有一个隐藏目录 .git,这个不算工作区,而是Git的版本库。
如下,先创建一个目录作为工作区:
空的,啥都没有。
然后将该目录关联版本库。先进入该目录:
然后创建版本库:
创建成功后,工作目录下:
多了一个半透明的文件夹.git,这就是版本库。
该目录包含了资源的所有元数据,其他的项目目录保持不变。实际上版本库就是一个本地的git仓库。
6、github上拉取项目
(1)生成一个秘钥文件
先通过ssh-keygen -t rsa -C "email"
命令生成一个秘钥文件,如下:
(2)绑定github账号
找到秘钥文件:
打开,将其中的内容复制下来,然后去github上绑定:
title里随便写,下面的key粘贴上一步复制的秘钥内容,点击Add SSH key,会有一个安全验证,按照提示完成。
测试绑定,命令:ssh -T git@github.com
,如下:
绑定成功。
(3)设置用户名和邮箱
(4)克隆远程仓库到本地
这里通过SSH来克隆,命令:git clone uri
。
克隆成功,查看本地文件:
没问题,OK。
7、本地修改推送到远程仓库
修改前:
添加一个Controller:
内容:
通过命令:git add fileName
添加到暂存区。如下:
提交并添加一个备注:git commit -m "mess"
。如下:
推送到远程仓库中:git push origin master
。如下:
前往github上查看:
没问题。
本地通过git rm fileName
命令删除文件:
前往github查看:
没有了,删除成功。
8、eclipse中使用git
现在一般的IDE中都会集成git,比如eclipse、IDEA等。会从远程仓库拉取项目到本地,并且能够将本地的修改提交到远程仓库就行了。这里使用eclipse。
8.1、eclipse拉取github项目
Window-Show View-other-Git Repositories:
URI直接复制过来,下面的两处会自动填充。
验证里面填你的github账号和密码。
选择分支。
选择一个保存目录。
克隆中,克隆完成后可以去保存目录查看,保存目录一般会设为eclipse的工作空间。
OK了,项目已经拉取到了本地,下面只需要将项目导入到eclipse中。右键–import–选择导入为Maven项目:
选择刚才克隆到本地的项目,点击Finish。
OK,导入成功。
8.2、eclipse推送项目到远程仓库
有时需要推送一个新的项目或者是修改后的项目到github上,想将修改后的内容提交到远程仓库。这里新建一个文件:
选中项目:
然后右键–Team–Fetch From Origin。
提交前一定要从远程拉取一次,看是不是最新的,这是为了避免你提交的同时别人也在提交。出现上面的everything up to date表示一切是最新的,那么可以开始提交。选择项目–右键–Team–Commit。
会出现一个Git Staging。
上面是有改动的文件,点击绿色的十字:
添加到了下面,然后添加提交备注,点击Commit and Push提交并推送:
点击Preview:
输入用户名和密码确认:
点击Push:
推送成功,前往github查看:
OK,推送成功。