Git版本控制软件

Git:

Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。
Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。
Git 与常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版本库的方式,不必服务器端软件支持。
Git 不仅仅是个版本控制系统,它也是个内容管理系统(CMS),工作管理系统等。
如果你是一个具有使用SVN背景的人,你需要做一定的思想转换,来适应Git提供的一些概念和特征。

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

安装之前请先下载Git的Windows下的安装包。机器是64位的,下载64位安装包
1、安装Git客户端:Git-2.x.x-64-bit_setup.xxx
地址:https://git-scm.com/downloads

Eclipse插件:
http://eclipse.org/egit/download
直接安装地址:
http://download.eclipse.org/egit/updates/
注意:新版本Eclipse自带git插件

https://github.com官网注册账号:
要求:用户名 密码 邮箱(会发送验证)
创建公有仓库repository->public
创建私有仓库repository->private(2019.1.8免费,只能3人协作)

常用功能:
Watch:关注
Star:收藏
Fork:克隆
Pull request:推送请求
Issues:提交问题

创建个人主页:
以用户名.github.io建一个仓库,进入新建的仓库,Create new file->index.html
https://用户名.github.io/

创建项目主页:
进入仓库->settings->GitHub Pages->Choose a theme
https://用户名.github.io/项目名(响应式布局)

码云个人主页:
以用户名建一个仓库,进入新建的仓库,文件->新建(上传)文件index.html->服务->Pages->启动服务
https://用户名.gitee.io/

码云项目主页:
进入仓库->文件->新建index.html
进入仓库->服务->Gitee Pages->启动
https://用户名.gitee.io/项目名

IDEA简单操作:(不使用命令行,会自动创建本地仓库及在github用户下创建远程仓库)
IDEA安装码云插件:安装gitee,装完后搜索GitOSC

VCS->Import into Version Contoller->Share Project on GitHub
或者:
1、创建本地仓库:
VCS->Import into Version Contoller->Create Git Repository->选择对应目录
2、提交:
右键->git->add
右键->git->commit directory
右键->git->repository->push

操作和svn差不多:commit(提交本地仓库) push(提交远程仓库)

注意:
idea导入maven项目打开后要重新设置maven路径,否则又变回自带设置导致没有jar包
eclipse导入maven项目也需要重新导入,否则是目录的形式存在

注意:
Git整个项目目录(包含pom.xml等)而不是src
commit报stag…错误,修改Git->Committing->Use Staging View…(去掉勾)

idea解决文件内容冲突:
1、首先将本地代码文件进行stash 即保存到git栈中,命名为xxx(git-repository-stash changes)
2、pull master代码
3、将本地修改取出(git-repository-unstash changes)选中之前创建的"xxx" 恢复
4、此时会提示有冲突,点击解决冲突,中间的result为解决结果,可以直接选择左或右或修改结果merge
5、把本地代码文件add、commit、push提交到远程仓库即完成

不论是从svn还是git拉下的项目都必须:
new->Module from Exists …->选择导出的项目->Import module from external model->maven

新增合作者(允许组员用他账号提交我的仓库):
1、仓库->Settings->左侧菜单栏选择Collaborators->输入组员账号->Add collaborator
2、等待对方同意Awaiting xx response | Copy invite link(邀请链接) | Cancel invite(取消邀请)
3、被邀请的人在登录邮箱,点击View invitation,然后点击下方Accept invitation(同意邀请),同意之后,就可以一起合作开发项目了。当然也可以选择Decline拒绝邀请。

完成后原来Awaiting xx response就会显示合作者账号了!

忽略部分文件(如target):(.ignore插件)
在根目录下添加文件.gitignore
内容:

此为注释 – 将被 Git 忽略

.css # 忽略所有 .css 结尾的文件
!lib.a # 但 lib.a 除外
/TODO # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
static/ # 忽略 static/ 目录下的所有文件
doc/
.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt

注:在Windows下,如果无法使用UI来创建.gitignore,重命名也会失败。但是 我们可是先创建一个名为gitignore.txt的文件,而后通过下面命令进行重命名:

ren gitignore.txt .gitignore

如果遇到加上这个文件,发现忽略的文件还是有上传。

原因:
在git库中已存在了这个文件,之前push提交过该文件。
.gitignore文件只对还没有加入版本管理的文件起作用,如果之前已经用git把这些文件纳入了版本库,就不起作用了

解决:
需要在git库中删除该文件,并更新。
然后再次git status查看状态,文件不再显示状态。。git清除本地缓存命令如下:

git rm -r --cached .
git add .
git commit -m ‘update .gitignore’

另外 git 还提供了另一种 exclude 的方式来做同样的事情,不同的是 .gitignore 这个文件本身会提交到版本库中去。用来保存的是公共的需要排除的文件。而 .git/info/exclude 这里设置的则是你自己本地需要排除的文件。 他不会影响到其他人。也不会提交到版本库中去。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值