git

世界上最好的版本管理工具,分布式版本控制系统。

林纳斯-托瓦斯,自由主义教皇(git、linux)

git 不管理空文件夹

对比于 SVN

mkdir XX        创建一个空目录 XX 指目录名

pwd         显示当前目录的路径
cat xx         查看 xx 文件内容

git rm xx         删除 xx 文件 之后要 commit

git init         把当前的目录变成可以管理的 git 仓库,生成隐藏的 .git 文件夹
git add xx         把 xx 文件添加到暂存区
git commit -m "xx"         提交文件 -m 后面的是注释
git status         查看仓库状态
git log         查看历史记录
git reset --hard HEAD^         往上回退一个版本
git reflog         查看历史记录的版本号 id
git checkout -- xx         把 xx 文件在工作区的修改全部撤销
git remote add origin https://github.com/xxxxx/a.git         关联一个远程库
git push -u origin master         把(第一次要用 -u,以后不用)当前 master 分支推送到远程库
git clone https://github.com/xxxxx         从远程库中克隆
git checkout -b dev         创建 dev 分支 并切换到 dev 分支上
git branch         查看当前所有的分支
git checkout master         切换回 master 分支
git merge dev         在当前分支合并 dev 分支
git branch -d dev        删除 dev 分支
git branch xxx         创建分支 xxx
git remote         查看远程库信息
git remote -v         查看远程库的详细信息
git pull origin master        将远程库的更新拉取到本地来
git push origin master        git 会把 master 分支推送到远程库对应的分支上

  • 安装:
  • 配置环境变量
  • Git 环境的默认路径是通过 HOME 环境变量还指定的
  • Git 的全局配置文件默认在系统用户 home 目录下(如:C:\Users\Administrator,此处Administrator为当前登录用户名)
  • 分别打开 Git 安装目录下的 cmd 目录下的 gitk.cmd 文件和 etc 目录下的 profile 文件
  • HOME ---- %HOMEDRIVE%%HOMEPATH%
  • HOMEDRIVE ---- C:\
  • HOMEPATH ---- \Users\Administrator
  • SystemRoot ---- C:\WINDOWS
  • windir ---- C:\WINDOWS
  • USERPROFILE ---- C:\User\Administrator
  • bash 配置:

git config --global user.name 'RyenToretto'

git config --global user.email '18273727925@qq.com'

git config user.name

git config user.email

  • 基本操作

git status        查看当前项目状态

  • 分支链接

git remote        不带参数,列出已经存在的远程分支

git remote -v        等同于上图命令

git remote add kjf git://github.com/paulboone/ticgit.git        创建一个别名 kjf 代替 长串的地址

git fetch kjf        抓取所有 kjf 有的,但本地仓库没有的信息,字串 kjf 指代对应的仓库地址

  • 内容差异对比

git diff        工作区暂存区 的文件之间的差异对比

git diff --cached        版本区暂存区 文件之间的差异对比

git diff master        工作区版本区 文件之间的差异对比

  • 日志 和 版本

git log        日志 和 版本号,HEAD 表示当前正在使用的分支,还有每次提交的哈希值

git reflog        精简版的 日志 和 版本

  • 版本回退

git checkout -- index.html        用暂存区指定文件替换工作区的指定文件 (危险)

git checkout HEAD index.html        用版本库中的指定文件替换 暂存区和工作区 的文件 (更危险)

git rm --cached index.html        删除暂存区的指定文件

git reset --hard HEAD        把暂存区清空,然后把版本库中的内容 copy 到 暂存区

git reset --hard HEAD^        回退到最近一次的版本

git reset --hard 70d1707        回退到指定的 70d1707 版本

  • 删除被 git 管理的文件

git rm -rf a.txt

git rm -rf test

  • 分支(常见面试题)

git branch -d tags        删除指定分支

git checkout -b tags        新建分支(拷贝自主分支),并切换到分支

git checkout master        切换到 主分支 master (由 .git 切换项目文件)

git checkout tags        切换到 tags 分支 (由 .git 切换项目文件)

git branch        显示 所有分支 和 区别出 当前分支

git diff tags master        显示 tags 分支 和 主分支 master 的有差异文件的 文件内容差异

git diff master tags        显示两个分支之间,有内容差异的文件列表

git diff master tags a.txt        显示 tags 分支 和 主分支 master 指定文件的 文件内容差异

git merge tags        (在目标分支执行) 将 tags 分支合并到 目标分支____可能引发冲突(同一文件同一位置内容冲突)

如果产生冲突,会显示 (master | MERGing)

冲突文件如下显示

处理完成以后,正常操作提交,会发现  (master | MERGing) ----> (master)

  • 局域网服务器,项目版本控制

git init        初始化一个仓库(最好在一个空文件夹下面执行初始化仓库)____线下仓库

编码并提交,然后在 GitHub 新建一个仓库,复制新仓库的地址

git remote remove origin        删除地址别名 origin

git remote add origin https://github.com/RyenToretto/taobao.copy.git        创建一个别名 origin 代替 长串的地址

git push -u origin master        托管上线到 GitHub

git pull origin master        拉取 GitHub 上的代码到本地

ssh-keygen -t rsa -C '18273727925@qq.com'        生成密钥

GitHub

git 项目托管网站

冲突: 同一文件的同一位置,内容出现冲突

处理:(pull 会把远端内容拉取,可能进行自动合并的操作,产生冲突)

第一种方式:

git pull -u origin master        拉取 GitHub 的文件内容到本地,出现冲突

处理冲突文件

git add .

git commit -m '处理 xxx 的冲突'

git push -u origin master

第二种方式:

git fetch origin master:tmp        将 GitHub 的文件内容拉取到 tmp 分支上

git checkout tmp        切换到 tmp 分支

git diff tmp master        显示 tmp 分支 与 master 分支的 文件内容差异

  • pull 和 fetch 的区别:

git pull origin master

将远程仓库的 master 分支上代码版本 复制/合并 到本地 master 分支上

git fetch origin master:dev

新建了一个 dev 分支,将远程仓库的 master 分支上代码版本复制到 dev 分支上
就一定不会产生冲突
git diff master dev 对比两分支内容,观察会不会产生冲突
如果会,先解决,在合并分支。如果不会,就直接合并分支

忽略文件(.gitignore 这个配置文件本身 是需要被提交 给 git 进行管理的)

直接在项目文件夹中创建 .gitignore 并设置忽略文件

.idea

node_modules

WebStorm 处理冲突

add

commit

pull        ----> ok 等待交互后,发现冲突,点 merge

----> apply

push        最终推送成功

Fork & Pull Request & Create Pull Request ----> Merge Request

版本管理_git的更多相关文章

  1. linux系统下使用流行的版本管理工具 Git

    前几天被版本管理困扰了好久,主要是因为 没法回到之前的版本,新版本又出了问题真的很尴尬. 终于决定使用目前网上很火的版本管理工具-------Git 历史啥的就不说了,说些有用的. 我用的是oschi ...

  2. 版本管理工具svn简介

    svn简介 SVN是一种C/S架构的版本管理软件 , 能够帮助我们保存开发过程中各个文件的所有历史版本, 你因此可以方便的找回软件的任何一个历史状态., 日常开发中经常用到. 安装使用 1.  在 u ...

  3. Git 版本管理的简单理解

    来源:百度知道 现在使用Git版本管理代码的项目非常多.但是Git本身是一条复杂的系统.我从几个简单的点来说明Git的基本功能.希望能帮助初学者快速入门. 工具/原料   Git code dot j ...

  4. GIT版本管理工具

    原文:http://blog.csdn.net/ithomer/article/details/7527877 Git 是一个分布式版本控制工具,它的作者 Linus Torvalds 是这样给我们介 ...

  5. MacOS下Python的多版本管理(pyenv)

    与windows下设置绝对路径不同,pyenv使用了一种更优雅的方式来管理Python的版本.pyenv通过在$PATH的最前面插入一个垫片路径(shims),例如:~/.pyenv/shims:/u ...

  6. 版本管理-SVN本地版本管理

    0. 引言 使用工具是人与动物的基本区别,善用工具可以极大的提高效率,降低错误率.在PC软件领域,有很多好用的工具,这些工具都是软件工程重要的基础设施.然而,嵌入式开发,在其代码数量上,很多时候由于没 ...

  7. [BI项目记]-配置Sharepoint2013支持文档版本管理笔记

    做开发或者做方案,写文档是很重要的一个工作,我们经常需要知道文档被修改的次数,谁在什么时间修改的文档,以及在某一个版本中,都修改了哪些内容,以及不同版本的文档之间有什么差别. 如何对文档进行版本管理, ...

  8. [BI项目记]-文档版本管理笔记

    代码的版本管理程序员们有专门的工具,那么作为项目管理人员如何进行文档版本的管理呢,此篇介绍如何通过SharePoint进行文档版本管理. 在没有SharePoint的时代我们如何管理版本呢?通常我们会 ...

  9. 目前流行的源程序版本管理软件和项目管理软件都有哪些?各有什么优缺点?以及Github的注册过程

    一.目前流行的源程序版本管理软件和项目管理软件有Microsoft TFS.GitHub.SVN.Coding等. 二.各有什么优缺点 三.在GitHub注册账户的过程 Microsoft TFS的优 ...

随机推荐

  1. 金融量化分析【day112】:股票数据分析Tushare2

    目录 1.使用tushare包获取某股票的历史行情数据 2.使用pandas包计算该股票历史数据的5日局限和60日均线 3.matplotlib包可视化历史数据的收盘价和历史均线 4.分析输出所有金叉 ...

  2. LFYZ-OJ ID: 1009 阶乘和

    思路 循环n次,每次计算i的阶乘i!,并加入sum中. n的范围从1~100,这里一定要使用高精度运算,涉及到"高精度乘低精度","高精度加高精度". 避免每次 ...

  3. Ubuntu 开机自动挂载硬盘

    1.查看Linux硬盘信息: $ sudo fdisk -l 2.格式化硬盘(根据需要确定文件系统): sudo mkfs.xfs /dev/sdb 3.创建/data目录 sudo mkdir /d ...

  4. 第十三节: EF的三种模式(三) 之 来自数据库的CodeFirst模式

    一. 简介 [来自数据库的Code First模式]实质上并不是CodeFirst模式,而是DBFirst模式的轻量级版本,在该模式中取消了edmx模型和T4模板,直接生成了EF上下文和相应的类,该模 ...

  5. python从爬虫基础到爬取网络小说实例

    一.爬虫基础 1.1 requests类 1.1.1 request的7个方法 requests.request() 实例化一个对象,拥有以下方法 requests.get(url, *args) r ...

  6. 排序算法以及其java实现

    一.术语了解 稳定:如果a原本在b前面,而a=b,排序之后a仍然在b的前面: 不稳定:如果a原本在b的前面,而a=b,排序之后a可能会出现在b的后面: 内排序:所有排序操作都在内存中完成: 外排序:由 ...

  7. TCP-IP详解笔记6

    TCP-IP详解笔记6 用户数据报协议和IP分片 UDP是一种保留消息边界的面向数据报的传输层协议. 不提供差错纠正, 队列管理, 重复消除, 流量控制和拥塞控制. 提供差错检测, 端到端(end-t ...

  8. C++设计模式——职责链模式

    什么是职责链模式? 在GOF的<设计模式:可复用面向对象软件的基础>一书中对职责链模式是这样说的:使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系.将这些对象连成一条 ...

  9. OpenCV3编程入门-读书笔记3-滤波

    一.领域滤波(卷积) 邻域算子值利用给定像素周围像素的值决定此像素的最终输出.如图左边图像与中间图像卷积得到右边图像.目标图像中绿色的像素由原图像中蓝色标记的像素计算得到. 通用线性邻域滤波是一种常用 ...

  10. AngularJS 作用域(Scope)

    AngularJS作用域(Scope) Scope作用域是应用在视图和控制器之间的纽带,Scope是一个对象包含可用的方法和属性,Scope可以应用在试图和控制器上. $scope是针对当前的cont ...