Git基础和入门

1、Git基础概念

Git功能简单概述java

  • 能够随时回滚到以前的代码版本(git reset --hard );
  • 协同开发时不会覆盖别人的代码(分支);
  • 留下修改记录(git log);
  • 发版时能够方便的管理不一样的版本;

一、Git工做模式

操做git

  • 90%以上的操做在我的计算机上
  • 添加文件、修改文件、提交变动、查看版本历史等
  • 版本库同步
  • 将本地修改推送到版本服务器

版本控制系统:正则表达式

 

 

二、Git文件存储

注意文件存储和SVN不一样:数据库

 

 

Git 不按照SVN那样对待或保存数据。 反之,Git 更像是把数据看做是对小型文件系统的一组快照。 每次你提交更新,或在 Git 中保存项目状态时,它主要对当时的所有文件制做一个快照并保存这个快照的索引。 为了高效,若是文件没有修改,Git 再也不从新存储该文件,而是只保留一个连接指向以前存储的文件。 Git 对待数据更像是一个 快照流。服务器

总结特色:架构

  • 直接记录快照snapshoot。而并不是比较差别;
  • 近乎全部操做都在本地执行;
  • 时刻保持数据完整性
  • 多数操做仅添加数据;
  • 文件的三种状态(只会处于这三种状态)
    • 已修改(modified)
    • 已暂存(staged)
    • 已提交(committed)

 

三、Git文件状态

  • Git文件: 已被版本库管理的文件;
  • 已修改: 在工做目录(working directory)修改Git文件;
  • 已暂存: 对已修改的文件执行Git暂存操做,将文件存入暂存区(staging area); (注意SVN中没有暂存区这个概念)
  • 已提交: 将已暂存的文件执行Git提交操做,将文件存入版本库(git directory);

 

 

Git 仓库目录是 Git 用来保存项目的元数据和对象数据库的地方。 这是 Git 中最重要的部分,从其它计算机克隆仓库时,拷贝的就是这里的数据。并发

工做目录是对项目的某个版本独立提取出来的内容。 这些从 Git 仓库的压缩数据库中提取出来的文件,放在磁盘上供你使用或修改。分布式

暂存区域是一个文件,保存了下次将提交的文件列表信息,通常在 Git 仓库目录中。 有时候也被称做‘索引’,不过通常说法仍是叫暂存区域。高并发

基本的 Git 工做流程以下:spa

  1. 在工做目录中修改文件。
  2. 暂存文件,将文件的快照放入暂存区域git add
  3. 提交更新,找到暂存区域的文件,将快照永久性存储到 Git 仓库目录git commit
git add 放到暂存区;
git commit 从暂存区放到版本仓库中;

四、本地版本库与服务器版本库

Git是分布式的。

 

 

2、Git经常使用命令

一、config和email

 

 

关于配置user.nameuser.email:

能够有三个地方配置:

好比输入git config命令, 会出现下面三个信息,即系统级别system,全局global,和局部local。其中优先级不断升高。

zxzxin@zxzxin:~/Git/gitlearn$ git config
usage: git config [<options>]

Config file location
    --global              use global config file
    --system              use system config file
    --local               use repository config file
    -f, --file <file>     use given config file
    --blob <blob-id>      read config from given blob object

这里展现一下配置咱们局部的gitlearn仓库:

 

 

git 提交的id( commit id)是一个摘要值,这个摘要值其实是一个 sha1计算出来的。

二、git rm 和rm的区别

git rm :

  • 一、删除了一个文件
  • 二、将被删除的文件归入到了暂存区(stage);(能够直接调用git commit来提交)

若想恢复被删除的文件,须要进行两个动做:

  • 一、git reset HEAD test2.txt,将待删除的文件从暂存区恢复到工做区;
  • 二、git checkout -- test2.txt, 将工做区的修改丢弃掉;

**rm **:

  • 只是将文件删除;注意: 这时,被删除的文件并未归入到暂存区当中。
  • 这时是提交(git commit)不了的。要想归入暂存区,必需要再调用一次git add

实战对比:

 

 

三、git mv 和 mv的对比

git mv(和git rm 相似):

  • 先完成重命名;
  • 而后提交到暂存区;

git mv演示:

 

 

而 mv:

  • 只是完成重命名;
  • 须要本身调用git add提交到暂存区;

 

 

使用技巧: 能够经过 git commit --amend -m '修正内容'更改上次错误的提交消息。(就是 -m '')后面的提交信息写错了。

四、git log查看日志

git log -n 能够查看最近的n条日志。

git log --pretty=oneline以一行一行的方式显示出来。

查看git命令帮助:

 

 

五、.gitignore文件

在开发中,若是咱们不想将全部的文件都放到git当中,而是要忽略少数一些文件(好比jar包、配置文件等),咱们能够在咱们的目录建立一个.gitignore文件,git就不会将这些文件放入暂存区,也不会提交(不会加入版本控制系统)。

 

 

此时咱们能够建立一个.gitignore文件:

 

 

简而言之,放在.gitignore中的文件会直接被git无视

其中,放在 .gitignore中的文件也支持正则表达式。
例如:
  • *.a,会忽略全部.a结尾的文件;
  • !lib.a,不要忽略lib.a(排除这个忽略);
  • /test.txt,仅仅忽略项目根目录下的TODO文件,不包括子目录下的test.txt文件;
  • dir1/,忽略dir1/目录下的全部文件;
  • dir1/*.txt,会忽略dir1/a.txt但不会包括dir1/dir2/a.txt
  • 例如dir1/*.txt会忽略dir1下的全部.txt文件,dir1/*/*.txt会忽略dir1下全部层下的.txt,而dir1/**/*.txt会忽略dir1/下的任意层的.txt文件。

 

.gitignore中用#表示注释。

 

原文:Java架构笔记

免费Java高级资料须要本身领取,涵盖了Java、Redis、MongoDB、MySQL、Zookeeper、Spring Cloud、Dubbo高并发分布式等教程,一共30G。
传送门: https://mp.weixin.qq.com/s/JzddfH-7yNudmkjT0IRL8Q
相关文章
相关标签/搜索