一、分支管理

在Git里,master是主分支,同时可以创建其他分支,支持各分支合并到主分支上,基本命令如下

          

1.创建分支

git checkout -b dev       创建dev分支,并切换到dev分支

相当两条命令: git branch dev 创建dev分支  与  git checkout dev  切换到dev分支

                                                      

    2.查看分支
git branch [-a]

        3.合并分支

            

            dev分支的工作成果合并到master分支上: git merge dev

4.删除分支

合并完成后,就可以放心地删除分支了

git branch -d dev

5.解决冲突

            两个分支都修改,都提交了,合并会产生冲突

                

           

       5.分支策略

          在实际开发中,我们应该按照几个基本原则进行分支管理:

首先,master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活;

然后,在dev分支上干活,也就是说,在某个时候,比如1.0版本发布时,再把dev分支合并到master上,在master分支发布1.0版本;

团队中的每个人都在dev分支上干活,每个人同时也都有自己的分支,时不时地往dev分支上合并就可以了。

或者,直接弄dev分支也可以,就像使用SVN一样

二、多人协作

       1.从远程库克隆项目到本地

          git clone 地址 [本地目录]  

       2.查看远程库信息

3.推送分支

         推送分支,就是把该分支上的所有本地提交推送到远程库。推送时,要指定本地分支,这样,Git就会把该分支推送到远程库对应的远程分支上:

git push origin master

         推送其它分支:比如dev

git push origin dev

4.抓取分支

多人协作时,团队成员都往masterdev分支上推送各自的修改

git pull 相当于两条命令:    git fetch 相当于update   与   git merge origin/master

三、标签管理

       1.创建标签

          git tag 标签名称 分支名称     或       先checkout切换到要打标签的分支,然后 git tag 标签名称

          git tag -a 标签名称 -m "指定标签信息"  

       2.查看标签(所有)

     git tag   

3.将标签推送到远程服务器

         git push origin 标签名称         或者,一次性推送全部尚未推送到远程的本地标签     git push origin --tags 

       4.删除标签

          删除本地标签: git tag -d 标签名称

删除远程库的标签(如果远程库有标签):  git push origin :refs/tags/<tagname>

四、忽略特殊文件

      有些文件是不需要提交,比如一些txt、.bak或者npm的东西,需要让git忽略一些文件,需要引入 .gitignore文件

# 以'#' 开始的行,被视为注释.
# 忽略掉所有文件名是 foo.txt 的文件.
# foo.txt
# 忽略所有生成的 html 文件,
# *.html
# foo.html是手工维护的,所以例外.
# !foo.html
# 忽略所有.o 和 .a文件.
# *.[oa]
# /bootstrap/compiled.php
# /vendor
# composer.phar
# .env.*.php
# .env.php
# .DS_Store
# Thumbs.db
# sftp-config.json
# /nbproject/private/
.idea # app/controllers/TestController.php # app/views/test/index.blade.php

需要将忽略文件提交至本地库,并推送至远程库

写到这里,Git的使用基本就完成了,不过个人本身对这些操作命令真是不屑一顾,有TM工具(Tortoise Git),多方便呀,个人比较反感装逼,直接 pengXX 多好呀。妈的一个工具,整那么复杂干啥,蛋疼地写完这边文章,我强烈建议大家看看下一篇文章,咱都好好的,别装逼,装逼招雷劈!

下一篇,咱就讲解如何像使用svn 一样使用 git。

       

Git 安装与使用(二)的更多相关文章

  1. 版本管理之Git(二):Win7上Git安装及简单配置过程

    一.安装包 msysgit(Windows版本的Git) 下载地址:http://code.google.com/p/msysgit/downloads/list?q=full+installer+o ...

  2. Git 笔记二-Git安装与初始配置

    git 笔记二-Git安装与初始配置 Git的安装 由于我日常生活和工作基本上都是在Windows上,因此此处只说windows上的安装.Windows上的安装和其他程序一样,只需要到http://g ...

  3. git安装和使用(二)

    一.git安装 1.目的 通过git管理github托管项目代码 2.下载安装 Git - Downloading Package​www.git-scm.com 点击桌面,右击鼠标,出现两个git单 ...

  4. 二、Git安装--Windows

    Git安装配置 在使用Git前我们需要先安装 Git.Git 目前支持 Linux/Unix.Solaris.Mac和 Windows 平台上运行. Git 各平台安装包下载地址为:http://gi ...

  5. Git安装与配置

    一.简介 Git是一款免费.开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目版本管理. Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的 ...

  6. Git 安装

    安装参考资料: http://lzw.me/a/msysgit-tortoisegit-win-git.html http://blog.csdn.net/qwiwuqo/article/detail ...

  7. 转 git安装配置

    Win7上Git安装及配置过程 一.安装说明 1.Git在windows平台上安装说明. Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件 ...

  8. git安装--linux下的安装

    一般linux自带git版本很旧,会有一定问题,可以先卸载系统自带git: yum remove git下载及安装git: wget https://github.com/git/git/archiv ...

  9. Win7上Git安装及配置过程

    Win7上Git安装及配置过程 文档名称 Win7上Git安装及配置过程 创建时间 2012/8/20 修改时间 2012/8/20 创建人 Baifx 简介(收获) 1.在win7上安装msysgi ...

  10. git学习——<一>git安装

    一.windows.linux平台安装 windows平台安装简单方便,到git官网上下载exe安装包即可,会把git bash shell给你安装好,你到命令窗口便可直接使用. linux平台安装, ...

随机推荐

  1. C语言面试题大汇总

    static有什么用途?(请至少说明两种)1.限制变量的作用域2.设置变量的存储域7. 引用与指针有什么差别?1) 引用必须被初始化,指针不必.2) 引用初始化以后不能被改变,指针能够改变所指的对象. ...

  2. MySQL 子查询 EXISTS 和 NOT EXISTS(转)

    MySQL EXISTS 和 NOT EXISTS 子查询 MySQL EXISTS 和 NOT EXISTS 子查询语法如下: SELECT ... FROM table WHERE EXISTS ...

  3. Debian下的PPPOE服务器配置

    参考: http://blog.csdn.net/zhangwenjianqin/article/details/7655375 http://blog.sina.com.cn/s/blog_8043 ...

  4. poj1328解题报告(贪心、线段交集)

    POJ 1328,题目链接http://poj.org/problem?id=1328 题意: 有一海岸线(x轴),一半是陆地(y<0).一半是海(y>0),海上有一些小岛(用坐标点表示P ...

  5. envi中selected rgb bands contain different spatial sizes

    是选择了不同的影像文件envi中selected rgb bands contain different spatial sizes

  6. 网络编程(发送get和post请求到服务器端,并获取响应)

    一:B/S结构,浏览器端到服务器端通信依赖http协议 交互过程: 1:在浏览器地址栏输入http://ip:port/应用/资源路径 2:浏览器根据ip和服务器建立连接,port确定和那个应用进行交 ...

  7. eclipse导入安卓工程时出现 Invalid project description. overlaps the location of another project提示

    eclipse导入工程时出现了如下问题: Invalid project description. /Users/yang/Documents/workspace/BarCodeTest overla ...

  8. 软件设计师考试计算机系统知识——CPU

    第一章: 计算机系统知识 1.1.1计算机系统硬件的基本组成 运算器.控制器.存储器.输入设备.输出设备 1.1.2 中央处理器 ①CPU的功能: a.程序控制:CPU通过执行指令来控制程序执行的顺序 ...

  9. 7月15日学习之BOM

    setTimeout() //延时器,只执行一次代码 clearTimeout() //清除演示器 setIntervla() //定时器,根据指定时间间隔执行一次代码 clearInterval() ...

  10. JMS - Temporary Destination

    Although sessions are used to create temporary destinations, this is only for convenience. Their sco ...