10分钟学会Linux系统下Git的本地使用

  身边的技术大牛一直都建议我使用git进行代码管理,而我每次都把这件事情忘之脑后。最近,好像感觉到了git的重要性。下面是最简单的使用git的入门方法,仅适用于像熊二飞月这样的菜鸟级git选手。

Git是一个分布式版本控制软件,原是Linux内核开发者Linus Torvalds为更好地管理Linux内核开发而设计的。

主要功能

Git是用于Linux内核开发的版本控制工具。与CVS、Subversion一类的集中式版本控制工具不同,它采用了分布式版本库的方法,不需要服务器端软件,就可以运作版本控制,使得源代码的发布和交流及其方便。Git的速度很快,这对于诸如Linux内核这样的大项目来说自然很重要。Git最为出色的是它的合并追踪(merge tracing)能力。

实际上内核开发团队决定开始开发和使用Git来作为内核开发的版本控制系统的时候,世界上开源社区的反对声音不少,最大的理由是Git太艰涩难懂,从Git的内部工作机制来说,的确是这样。但是随着开发的深入,Git的正常使用都由一些友善的命令稿来执行,使Git变得非常好用。

工作步骤

1. 安装git

熊二飞月使用的是ubuntu系统,使用apt-get install git即可安装。

2. 设置Git

在能够使用Git进行工作之前,我们需要进行一次性的配置。为了能让Git能够跟踪谁做了修改,我们需要设置你的用户名。

git config --global user.name "bear2flymoon"

git config --global user.email [email protected]

这里我的用户名就设置为:bear2flymoon

邮箱为:[email protected](谷歌被墙,无法登陆)

3. 创建一个本地代码库

假设我们的代码写在机器的/home/bear2flymoon文件夹下的’test‘文件夹内。在命令行输入下列命令:

cd /home/bear2flymoon/test/

下面,我们需要告诉Git这个文件夹是我们需要跟踪的项目。所以我们在该目录下输入以下命令来初始化一个新的本地Git代码库

git init

Git会在test文件夹下创建一个名为.git的隐藏文件夹,这就是你的本地代码库。

4. 暂存(stage)文件

我们需要暂存(stage)test文件夹下所有项目文件,输入以下命令:

git add .

最后的“.”符号的意思是“所有文件、文件夹和子文件夹”。假如我们只需要把特定文件添加到源代码控制中去,我们可以指定它们:

git add my_file,my_other_file

5. 提交文件

现在,我们想要提交已经暂存(staged)的文件。我们提交我们的文件时,总是附带着有意义的注释,描述它们现在的状态。我一直用“initial commit"来描述我的第一个提交的注释。

git commit -m "initial commit"

同样,你随时可以回滚到这个提交状态。如果你需要检查现在已暂存和未暂存文件的状态、提交等,你可以输入以下命令询问git的状态:

git status

6. 创建分支

创建分支是你创建代码独立版本的动作,这个新分支独立于你的主干。默认的,每次你提交到Git的代码都会被存储到”master(主干)”分支。

现在,比如我们想向项目中添加一个功能,但我们又想要能够回滚到现在的版本,为了防止出现差错,或者我们会最终放弃这个功能。这时候,我们就可以创建分支并切换到新建的分支,发送命令:

git checkout -b new_feature

或者先创建一个分支,然后切换

git branch new_feature

git checkout new_feature

要看项目下所有的分支,发送命令:

git branch

现在你可以在你的项目上无所顾忌地做任何你想做的:任何时候,你都可以回到你创建分支前的状态。注意,你同时可以有多个分支,甚至可以从一个分支上再创建一个分支。

7. 合并分支

当我们对新功能满意的时候,我们想要把它加到主干分支上。当我们在的新功能分支上时,我们首先需要加载并且提交文件:

git add .

git commit -m "adds my new feature"

然后移到主干分支:

git checkout master

像这样合并:

git merge new_feature

此时,我们的主干分支和新功能分支会变成一样。

8. 丢弃并删除分支

当我们想要丢弃并删除一个分支时,首先加载我们的文件并且在分支里提交:

git add .

git commit -m "feature to be discarded"

然后,移到主干分支

git checkout master

然后发送删除命令

git branch -d new_featrue

假如修改已经合并了,它只会删除分支。假如分支没有合并,我们会得到一个错误信息。删除一个未合并的分支(通常我们不想保留的修改),我们需要发送一样的命令附带一个大写D。意思是“强制删除分支,无论如何我不想要它了。”:

git branch -D new_feature

9. 回滚到之前提交的状态

在某些情况下,我们可能想要回到之前的代码版本。首先,我们需要找到想回到到哪个版本。需要查看所有完成的提交,发送命令:

git log

输出提交的历史记录

commit ca82a6dff817ec66f44342007202690a93763949Author: your_username [email protected]:   Mon Nov 4 12:52:11 2013 -0700    changes the frontpage layout
commit 085bb3bcb608e1e8451d4b2432f8ecbe6306e7e7Author: your_username [email protected]:   Mon Nov 4 11:40:33 2013 -0700    adds my new feature
commit a11bef06a3f659402fe7563abf99ad00de2209e6Author: your_username [email protected]:   Mon Nov 4 10:37:28 2013 -0700    initial commit

如果我们想回到“adds my new feature"这个提交,简单的使用提交的ID做签出(checkout)(通常只用ID的开头9个字母)

git checkout 085bb3bcb

我们也可以签出一个新的分支

git checkout -b my_previous_version 085bb3bcb

只是别太疯狂了!分支越复杂,我们就越难确定我们在做什么。

10. 别名

Git允许我们为常用的命令创建快捷方式(别名)。例如,如果我们不想每次都输入git commit -m “some comment”,而是输入git c “some comment”,我们可以向git全局配置里添加一个别名来实现,像这样:

git config --global alias.c ‘commit -m‘
这是我使用的别名列表:
git config --global alias.c ‘commit -m‘
git config --global alias.co ‘checkout‘
git config --global alias.cob ‘checkout -b‘
git config --global alias.br ‘branch‘
git config --global alias.m ‘merge‘
git config --global alias.a ‘add .‘
git config --global alias.s ‘status‘
git config --global alias.dbr ‘branch -d‘

这下就可以使用Git进行最基本的程序版本管理啦!

学习资料:

Pro Git http://iissnan.com/progit/

本文参考整理自以下资料:

维基百科 http://zh.wikipedia.org/zh-cn/Git

伯乐在线 http://blog.jobbole.com/53573/

特别感谢

                      2015-03-14  熊二飞月

时间: 2024-10-07 20:12:30

10分钟学会Linux系统下Git的本地使用的相关文章

10分钟学会Linux

10分钟学会Linux有点夸张,但是可以让一个新手初步熟悉Linux中最重要最基本的知识,本文翻译的英文网页在众多Linux入门学习的资料中还是非常不错的. 英文地址:http://freeengineer.org/learnUNIXin10minutes.html 中文译文如下: 前言  这是我已经在过去的几年中给学生(CAD用户培训)培训中所使用的材料. 其目的是在一个页面上就可以使用 UNIX的shell的基础命令.(这样他们就没有打电话问我了). 本文档受版权保护,但根据GFDL的条款自

U盘10分钟安装linux系统

说来可能不信,10分钟包括创建U盘启动盘,用U盘启动,安装,不联网,不更新,不安装语言包,等装好系统再更新. Windows系统硬盘分区 如果你用的是Windows系统,现有的硬盘没有未分配的空间,需要调整硬盘空间的,请看这里,否则跳过. 工具:EASEUS Partition Manager 9.1,华军下载.这个软件Windows 7 64bit能使用,无需注册,无需付费,可使用全部功能.关键是因为你要调整硬盘分区,需要重启,并且在不加载系统的情况下进行.目前市面上几个声称能安全调整分区,能

linux系统下git使用

转载:http://www.cnblogs.com/bear2flymoon/p/4335364.html?ADUIN=563508762&ADSESSION=1430887070&ADTAG=CLIENT.QQ.5401_.0&ADPUBNO=26464 身边的技术大牛一直都建议我使用git进行代码管理,而我每次都把这件事情忘之脑后.最近,好像感觉到了git的重要性.下面是最简单的使用git的入门方法,仅适用于像熊二飞月这样的菜鸟级git选手. Git是一个分布式版本控制软件,原

Linux系统下Git操作命令整理

1.显示当前的配置信息 git config --list 2. 创建repo从别的地方获取 git clone git://git.kernel.org/pub/scm/git/git.git 自己建立 mkdir testcd testgit init 3. 显示状态 git status 4. commitgit add file.1 file.2 先增加文件,增加到index中.这样commit的时候才知道要commit哪些文件.或者 git add -p 用来interactively

linux系统下 git 使用教程

1.首先安装git软件,安装环境是centos 7.x下的云服务器.使用命令: #yum install git 2.设置用户名和邮箱(必须): # git config --global user.name "Your Name" # git config --global user.email "[email protected]" 3.创建一个版本库,选择一个合适的地方,创建一个空目录: # mkdir learngit #在服务器中创建learngit文件夹

linux系统下本地搭建git服务器

linux系统下如何搭建本地git服务器,用于存放团队的开发代码,如下步骤: 1.先用一台服务器来安装git,安装好linux以后,在这里选用的是Ubuntu 14.04.然后配置静态IP:172.16.0.110.执行下面命令: >> sudo apt-get install git 2.创建一个git用户: >> sudo adduser git 3.建立/home/git/.ssh/authorized_keys文件,将团队每个人的~/.ssh/id_rsa.pub文件复制到

Linux系统下修改环境变量PATH路径的三种方法

比如要把/etc/apache/bin目录添加到PATH中,方法有三: 1.#PATH=$PATH:/etc/apache/bin 使用这种方法,只对当前会话有效,也就是说每当登出或注销系统以后,PATH 设置就会失效 2.#vi /etc/profile 在适当位置添加 PATH=$PATH:/etc/apache/bin (注意:= 即等号两边不能有任何空格) 这种方法最好,除非你手动强制修改PATH的值,否则将不会被改变 3.#vi ~/.bash_profile 修改PATH行,把/et

第九章 Linux系统下分区、格式化磁盘,学会挂载和卸载磁盘

1. 请查资料了解这些术语:/dev/hda, /dev/hdb, /dev/sda, /dev/sdb, 他们之间有什么区别?/dev/hda, /dev/hdb 是 IDE借口硬盘的块文件. /dev/hda  第一块IDE磁盘 : /dev/hdb 第二块IDE磁盘 /dev/sda, /dev/sdb 是SCSI接口硬盘的块文件. /dev/sda 第一块SCSI磁盘 :/dev/sdb 第二块SCSI磁盘 2. 为什么 du -b /etc/passwd  和 du -k  /etc/

Linux系统下如何查看已经登录用户

Linux系统下如何查看已经登录用户 虽然前面介绍了用户管理,但是那部分主要是管理用户的帐号,也就静态的用户列表.而LINUX是个多用户系统,一旦连接到网络中,它可以同时为多个登录用户提供服务.系统管理员可以随时了解系统中有那些用户,用户都在进行什么操作. 查看用户的操作 系统管理员若想知道某一时刻用户的行为,只需要输入命令W 即可,在SHELL终端中输入如下命令: [[email protected] ROOT] # W2:31PM UP 11 DAY ,21:18 4 USERS, LODE