Git是个好工具(转)

Git是分布式版本控制系统,我们常用的版本控制工具还有SVN。这里就得区分下什么是分布式版本控制系统,什么是集中化的版本控制系统。

集中化的版本控制系统

集中化的版本控制系统( Centralized Version Control Systems,简称 CVCS )。这类系统,诸如 CVS,Subversion 以及 Perforce 等,都有一个单一的集中管理的服务器,保存所有文件的修订版本,而协同工作的人们都通过客户端连到这台服务器,取出最新的文件或者提交更新。

优点:

1. 每个人可以看到别人做了什么

2. 管理员管理权限也比较简单

缺点:

依赖中央服务器,存在单点故障的风险。

1. 中央服务器宕机后,都无法协同工作

2. 如果中央服务器的文件损毁,又没有备份时,丢失的数据无法找回

分布式版本控制系统

分布式版本控制系统( Distributed Version Control System,简称 DVCS )。在这类系统中,像 Git,Mercurial,Bazaar 以及 Darcs 等,客户端并不只提取最新版本的文件快照,而是把代码仓库完整地镜像下来。这么一来,任何一处协同工作用的服务器发生故障,事后都可以用任何一个镜像出来的本地仓库恢复。因为每一次的提取操作,实际上都是一次对代码仓库的完整备份。

优点: 1. 适合分布式开发,强调个体

PS:允许支持上千个并行开发的分支 2. 公共服务器压力和数据量都不会太大 3. 速度快、灵活

PS:特别在打分支和打Tag时候 4. 任意两个开发者之间可以很容易的解决冲突 5. 离线工作

PS:本地仓库

缺点: 代码保密性差,一旦开发者把整个库克隆下来就可以完全公开所有代码和版本信息

分支

Git最关键地方即是分支,分支意味着你可以从开发主线上分离开来,然后在不影响主线的同时继续工作。如果要了解Git,这个是最重要的,可以查看下面学习资料。

 

学习资源

这一篇文章纯粹只是记录一些东西,并不会讲Git的工作原理、怎么用,因为资料已经非常完善了,使用到时查看即可。

1. 廖雪峰Git教程(中文)

http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/0013744142037508cf42e51debf49668810645e02887691000

2. 图解Git/图形化的Git参考手册(了解原理非常有用)

http://blog.jobbole.com/22647/

3. Git官方教程(英文)

http://git-scm.com/blog

4. Git - 生成 SSH 公钥

https://git-scm.com/book/zh/v1/服务器上的-Git-生成-SSH-公钥

下载Git

1. window git安装包

https://git-for-windows.github.io/

2. mac

Git安装工具:http://sourceforge.net/projects/git-osx-installer/

通过Xcode安装:Xcode->Preferences->Downloads,选择“Command Line Tools”

Eclipse Git

我是个懒人,不喜欢打命令去操作Git,可视化操作才是我想要的,所以就找了在Eclipse上使用Git方法。

1. Eclipse上安装GIT插件EGit及使用

http://yufenfei.iteye.com/blog/1750124/

2. 解决eclipse中egit中的cannot open git-upload-pack问题

http://www.xuebuyuan.com/1587775.html

总结

使用什么版本控制工具,无论是集中式或分布式,没有谁绝对取代谁,存在都是原因的,各有各自的适用场景。

附录

下面记录一些命令,来源于培训教程 创建Git仓库 初始化Git仓库

$ git init  

配置用户信息

$ git config user.name 'someGuy'
$ git config user.email 'someGuy@bingo.com'

添加文件 创建一个文件

$ touch README.md

查看仓库当前状态

$ git status

添加文件到暂存区

$ git add .

提交暂存区文件到仓库

$ git commit -m 'add README.md file'

提交修改 将修改添加到暂存区

$ git add README.md

将暂存区中的修改提交到仓库

$ git commit -m 'edit README.md'

撤销 撤销add到暂存区的操作

$ git reset HEAD README.md

撤销对文件所做的修改

$ git checkout — README.md

将暂存区中的修改提交到仓库

$ git commit -m 'edit README.md'

版本回滚 查看提交历史记录

$ git log

回到上次的提交

$ git reset --hard README.md

返回最近的提交

$ git reset --hard 0ff9

链接到远程仓库 添加远程仓库

$ git remote add origin git@git.bingosoft.net:gongke/GitLession.git

提交代码到本地仓库

$ git commit -a -m '将要提交到远程'

将本地的master分支推送到远程的origin分支,并与之建立连接

$ git push -u origin master

在分支上提交、合并分支 修改若干文件,提交

$ git commit

切换回master分支

$ git checkout master

合并分支

$ git merge dev

删除分支

$ git branch -d dev

有冲突的合并 新建一个分支并切换到它

$ git checkout -b new_feature

合并分支

$ git merge new_feature

若没有发生冲突则会自动生成一个提交若发生冲突,则需要手动解决冲突,再提交

$ git add conflict_filegit commit - m 'conflict solved'

打标签 创建标签

git tag v1.0
git tag -a v1.1 -m '1.1 released!'

查看标签

git tag

删除标签

git tag -d v1.0

把标签推送到远程

git push  --tag

 

本文为原创文章,转载请保留原出处,方便溯源,如有错误地方,谢谢指正。

本文地址 :http://www.cnblogs.com/lovesong/p/5042155.html

 

时间: 2024-11-18 19:31:35

Git是个好工具(转)的相关文章

git/svn diff可视化工具配置

 以前一直使用svn diff / git diff,看到的都是console下的对比提示. 今天花了点时间找了一款工具,基于GUI的diff操作.   软件 选择的是p4merge , 下载路径: http://www.perforce.com/perforce/downloads/index.html   下载完成后,直接解压缩到 /usr/local/program/p4merge 目录   git diff配置 1. 创建相应脚本 gitmerge.sh脚本: 1.#!/bin/sh 2

给予 GIT 的程序发布工具

#!/bin/bash ##################################################################### # Description: Automation Deployment Script  # Netkiller series utilities # Author: Neo<openunix@163.com> # Homepage: http://netkiller.sourceforge.net/ # $Id$ ########

git-info-bar 1.1.2发布 git属性快速查看工具

git-info-bar 是一个提供了快速查看各种git属性的shell插件,运行于git资料库.它主要显示的信息包括:当前分支.当前文件显示的标识符与大小和隐藏在消息区域的计算.它包括一个安装脚本和删除脚本,目前通过bash和ksh93的测试,使用一个Perl后端作为一个跨shell的兼容性. git-info-bar 1.1.2该版本整合了删除脚本,并提高了移出过程.它简化了安装程序,改变了在信息栏的文本格式"分支".它修复了一些错误. 软件信息:https://github.co

Git版本控制工具(一)----git的安装及创建版本库

[正文] 一.初识Git: Git是目前世界上最先进的分布式版本控制系统(没有之一).它的开发者就是大名鼎鼎的Linux操作系统的作者Linus Torvalds.Git被开发出来的初衷是为了更好的管理Linux内核,而现在却广泛应用于各种项目中.Git迅速成为最流行的分布式版本控制系统,尤其是2008年,GitHub网站上线了,它为开源项目免费提供Git存储,无数开源项目开始迁移至GitHub,包括jQuery,PHP,Ruby等等. 那那什么是版本控制系统呢?如果有一个软件,不但能自动帮我记

CentOS 6系统( 64位)安装Git工具步骤详解

有些时候我们项目的调试需要,在本地Windows环境中搭建的Git环境可能使用的时候有一些问题,于是我就直接在VPS环境中搭建Git工具环境使用.虽然在Linux系统环境中带有git源,我们可以直接yum或者apt-get安装,但是源不是最新版本,安装的git环境提交版本的时候会出现错误,所以我们需要单独手工安装git才可以确保工具的正常使用.   昨天在Q群中,老左有看到有网友提到在Centos环境中安装git的问题,于是今天上午就搜罗信息,把基于centos 6 64位环境的安装git方法分

Gitblit 0.8.2发布 Java的Git管理工具

Gitblit 是一个纯 Java 库用来管理.查看和处理 Git 资料库.相当于 Git 的 Java 管理工具.它设计的主要目的是在主机集中软件库中作为一个小型工作组的工具. Gitblit 0.8.2此版本修复了一个bug,升级users.properties users.conf. 下载地址: gitblit-0.8.2.war gitblit-0.8.2.zip

CentOS下Git的服务器版安装和使用

Git分布式版本控制系统: Git的使用体验,早已习惯了svn [集中式] 代码管理的吾,第一次接触分布式的git的时候,感觉很难使用,煎熬了一段时间,整个项目组,也是花费了很大的代价,就是出现代码被覆盖很多次,代码都不敢提交了! 记得在中国民航的时候,由于服务器硬件搬家过程中损坏,导致整个系统和代码全部丢失,不是很重要所以没有去做数据恢复,svn就挂了. 记得在金葵花的时候,由于svn服务器端口被抢占,导致没有启动,早上经理不在,没权限,所有,大家闲置了一早上. 使用了一段时间的git,使用过

Git远程09:Git服务搭建

GitHub和Gitlab是最常见的两个免费的Git Server,本博客就是搭建在GitHub上,GitLab没有于GitHub出名,其提供了免费的私有Git库,GitHub的私有库则是收费的.也可以在自己的服务器上搭建Git远程库,推送和拉取的速度比直接使用GitHub快,也不会存在安全性问题,本文介绍相关操作. 环境 操作系统:CentOS6.6 服务器IP地址:192.168.80.6 服务器Git版本:1.7.1 若服务器没有安装Git,请先安装. 1 # yum install gi

git初学常用命令解析

git初接触核心指令 1. 配置git的基本信息. 在每次提交时都会引用这两条基本信息,标识更新提交者,会随更新一起保存在log中 git config –-global user.name "Your Name" git config –-global user.email "you@example.com" 使用–global 会把修改的配置信息保存在主目录下,所有项目都会默认使用此配置,如果想要针对特定项目配置用户信息,只需把–global去掉 2. 设置默认