专注收集记录技术开发学习笔记、技术难点、解决方案
网站信息搜索 >> 请输入关键词:
您当前的位置: 首页 > 行业应用

git的装配和使用

发布时间:2010-06-06 17:58:42 文章来源:www.iduyao.cn 采编人员:星星草
git的安装和使用

git是个分布式的版本控制工具。它可以使用git协议,http协议和本身linux常用的ssh协议进行远程传输。

具体的知识可以搜索git服务器出来的这篇文章:http://blog.jobbole.com/25944/ 。

我这里要介绍的是git的最简单使用方法(很通用和方便的方法)。

第一步、linux上安装git软件,yum install git-core;

第二步、在某个目录下新建一个目录用来作为代码仓库。比如:mkdir /data/codes

第三步、初始化代码仓库。cd /data/codes; git init

第四步、将需要托管的代码拷贝到仓库里。cp /data/c/* /data/codes -r

第五步、将代码添加到代码仓库:git add *

第六步、提交:git commit -m "添加代码托管"

至此,“服务器”侧的代码仓库就已经建好了。我们在该目录下执行git branch -a可以看到当前的分支只有master。

这样就可以到别的机器上,利用ssh协议将这个代码克隆过来,比如服务器ip为192.168.1.10,这上面建立用户git,user add git; passwd git;给密码pd123;我们到另一台ip为192.168.1.11的主机上操作:

git clone ssh://git@192.168.1.10/data/codes

这样代码就被克隆下来了。

不过 现在只有master一个分支,10主机上当前工作分支和11主机相同,所以为了安全,git默认11主机不能push代码,我们在11上创建dev分支:

git branch dev

git checkout dev

这样11上就创建了dev分支并且切换过来了。我们将dev分支push到服务器上:

git push origin dev

这样 10主机上就会有dev分支了,我们到10上执行git branch 就能看到。

以后修改了代码,就可以提交到10上的dev分支了。

如果 代码稳定了,想要合并到master,需要到10上执行git merge dev,这样就将dev分支合并到当前分支(master)了。

 

当然 分支管理是灵活的,比如10上可以切换到dev分支,这时候11就无法提交dev分支里的修改了,但可以提交master的分支。

 

【高级设置】

配置 .git/config里增加如下两行:

[receive]
denyCurrentBranch = ignore

增加后可以解决无法提交到相同工作分支的问题,但是提交后在服务器侧需要执行git reset --hard才能看到提交后的修改。

建议别用这个方式,使用不同分支提交,用merge合并更安全。

 

【实用技巧】

打开用户主目录下的.bashrc(mac os里打开.bash_profile),

vim ~/.bashrc

在最后加上如下三行:

 

WHITE="\[\033[0m\]"

 

GREEN="\[\033[1;32m\]"

 

export PS1="\u@\h \W$GREEN\$(git branch --no-color 2> /dev/null | sed -e '/^[^*]/d' -e 's/* \(.*\)/[\1]/')$WHITE\$"

 

这样,就可以在系统默认的提示符的基础上,增加用户切换至某仓库目录下用绿色字体显示分支名;

 

 

 

vim ~/.gitconfig

 

增加如下几行:

 

[diff]

tool = vimdiff

[difftool]

prompt = false

[alias]

logp = log --pretty=format:'%h [%ci] (%an) -%C(green)%d%Creset %s' 

增加后,在代码仓库里执行git difftool就可以用vimdiff的方式查看差异,执行git logp就可以以简洁的彩色文字查看git log。

上面两种配置对于git仓库的修改和查看差异、日志都是很实用的技术,建议进行配置。

 

 

对于架设web服务器的人来说,如果代码都是解释执行的,那么可以这样做:

A主机192.168.1.10为web服务器;B主机192.168.1.11为开发机。

A上的普通用户user1用户目录下/home/user1/建立原始代码仓库(也可以在别处,只要这个用户可写),目录名为web服务器需要的那个目录名如wwwroot,然后git init,并添加好代码,也可以在这里创建dev分值,但切换到master里工作。

在web服务器主目录下需要布置代码的位置进行git clone /data/wwwroot,然后切换分支到dev,git checkout dev;

在开发机B上git clone ssh://user1@192.168.1.10/home/user1/wwwroot,并切换分值到dev,git checkout dev;

在B上开发代码,调试好后,提交到服务器,git commit -a "xxxxx"; git push;

在A上的/home/usr1/wwwroot下已经保存了这个提交了,不必理会这个目录,去/data/wwwroot下执行git pull,就可以把最新的dev代码拉下来,怎样,是否方便呢?当代码稳定时,可以去/home/user1/wwwroot下将dev代码合并到master,git merge dev。

 

 

友情提示:
信息收集于互联网,如果您发现错误或造成侵权,请及时通知本站更正或删除,具体联系方式见页面底部联系我们,谢谢。

其他相似内容:

  • 《松本行弘的程序全世界》之面向对象

    《松本行弘的程序世界》之面向对象 最近读《SICP》把脑细胞搞死大半,还没看完2章,而且看得也是一知半解,实在是受不了了,...

  • GroovyHelp 3.2.7 GA公布

    GroovyHelp 3.2.7 GA发布 GroovyHelp简介   GroovyHelp是一款Javadoc及Groovydoc搜索查阅软件,它能够帮助Java开发人员以...

  • Velocity在Roller中的使用

    Velocity在Roller中的应用 Velocity是java世界中出现比较早,也比较成熟的、性能比较好的、应用也比较广泛的模板框架。   所...

  • Rpc远程调用框架的设计与兑现(2)

    Rpc远程调用框架的设计与实现(2) 接上: 3   基于Json的前后端数据交互 3.1   轻量级的数据交换形式 3.1.1    什么是Jso...

  • excel 单元格的锁定 以及 JXL的兑现方式

    excel 单元格的锁定 以及 JXL的实现方式 在使用excel表格时,有些列是不希望用户可以修改的,诸如审计日志里面确定的部分,而审计...

  • 仓秤跟散料秤:java连接opc Server

    仓秤和散料秤:java连接opc Server 这三篇都是之前写好的,一直没发。 这次一起发出来吧。   java连接硬件很痛苦,特别是对我这...

  • Rpc远程调用框架的设计与兑现(1)

    Rpc远程调用框架的设计与实现(1) Rpc远程调用框架的设计与实现 1     Rpc远程调用框架设计概述 1.1   研究背景 1.1.1...

  • 集合中的线程安全有关问题

    集合中的线程安全问题 一、why? Java中常用的集合框架推荐使用的三个实现:HashSet\ArrayList\HashMap都是线程不安全的.如...

  • Java定时任务的兑现

    Java定时任务的实现 本例依据Java自身提供的接口实现,通过监听器(Listener)和定时器(Timer)定时执行某个任务(Task)。 MyListener: ...

  • java中log日记的使用

    java中log日志的使用 一、介绍  Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控...

热门推荐: