git服务搭建
追求好的版本控制, 让开发变得更加简单是学习git的一个理由, 且git不会在每个目录下都生成.svn文件.分布式版本部署,强大的分支功能让我觉得git很有魅力.
使用git也会对我目前熟悉的开发工具产生些震荡, 要慢慢从windows下的开发转向linux的开发.
一 git常用命令:
设置git默认文本编辑器
$ git config --global core.editor vi
设置解决合并冲突时使用哪种差异分析工具
$ git config --global merge.tool vimdiff
第一次下载,包括源码和版本库
git clone http://projectname 或 git clone git@gitserver:/projectname
下载服务器上最新的更新
git pull
检出某个修订版本
git reset –hard -r
新增被跟踪文件
git add /path/to/file
移除被跟踪文件
git rm /path/to/file
查看已暂存和未暂存的更新
$ git status
生成补丁
git diff >patch_file
提交
git commit git remote add origin git@gitserver:/home/git/w3cnotes.git
二 git服务器架设
把一个git仓库放到你和你的同事都能用ssh访问,读写的服务器上, 就搭建好了一个git服务.
在ubuntu下安装git
$ apt-get instal git-core
在windows下安装git
请下载msysgit,下载地址 http://code.google.com/p/msysgit/
都安装好了之后, 部署一个git代码仓库相当简单.进入项目目录/home/git/w3cnotes.git
1 .创建一个空的代码仓库
使用 –bare 选项运行 git init 来设定一个空仓库,这会初始化一个不包含工作目录的仓库
$ git init --bare
2. 把用户事先生成的公钥内容追加到authorized_keys 文件
完成这一步需要在你本机上进入SSH 公钥默认储存在账户的 ~/.ssh 目录
$$ cd ~/.ssh $ ls authorized_keys2 id_dsa known_hosts config id_dsa.pub
然后执行命令:
$ ssh-keygen Generating public/private rsa key pair. Enter file in which to save the key (/Users/schacon/.ssh/id_rsa): id_rsa.yk Enter passphrase (empty for no passphrase): Enter same passphrase again: Your identification has been saved in /Users/schacon/.ssh/id_rsa. Your public key has been saved in /Users/schacon/.ssh/id_rsa.pub. The key fingerprint is: 43:c5:5b:5f:b1:f1:50:43:ad:20:a6:92:6a:1f:9a:3a schacon@agadorlaptop.local
这里我生成了id_rsa.yk.pub公钥, 并上传到服务器上的/tmp目录,追加到home/yk/.ssh/authorized_keys 文件后
$ cat /tmp/id_rsa.yk.pub >> ~/.ssh/authorized_keys
三 本地推送代码到服务器 $ cd testgit
$ git init
$ git add .
$ git commit -m 'initial commit'
$ git remote add origin git@gitserver:/home/git/w3cnotes.git
$ git push origin master
注:gitserver为服务器ip或域名,@前面为服务器用户.
四 本地拉取git服务器代码 $ git clone git@gitserver:/home/git/w3cnotes.git
$ vim README
$ git commit -am 'fix for the README file'
$ git push origin master
git工具参考:
http://code.google.com/p/msysgit/
http://code.google.com/p/tortoisegit/
Cygwin
eclipse EGit
资料参考:
http://progit.org/book/zh
SVN,HG,GIT命令对照
bare
[b??] 添加生词
改进词条
adj.赤裸的, 空的, 仅有的
vt.使裸露, 暴露
beanstalk不稳定,无奈,还是得自己搭git服务
reference :
http://progit.org/book/zh/ch4-2.html
在服务器部署 Git
开始架设 Git 服务器的时候,需要把一个现存的仓库导出为新的纯仓库——不包含当前工作目录的仓库。方法非常直截了当。 把一个仓库克隆为纯仓库,可以使用 clone 命令的 --bare 选项。纯仓库的目录名以 .git 结尾, 如下:
$ git clone --bare my_project my_project.git Initialized empty Git repository in /opt/projects/my_project.git/
该命令的输出有点迷惑人。由于 clone 基本上等于 git init 加 git fetch ,这里出现的就是 git init 的输出,它建立了一个空目录。实际的对象转换不会有任何输出,不过确实发生了。现在在 my_project.git 中已经有了一份 Git 目录数据的副本。
大体上相当于
$ cp -Rf my_project/.git my_project.git
在配置文件中有几个小改变;不过从效果角度讲,克隆的内容是一样的。它仅包含了 Git 目录,没有工作目录,并且专门为之(译注: Git 目录)建立了一个单独的目录。
将纯目录转移到服务器
有了仓库的纯副本以后,剩下的就是把它放在服务器上并设定相关的协议。假设一个域名为 git.example.com 的服务器已经架设好,并可以通过 SSH 访问,而你想把所有的 Git 仓库储存在 /opt/git 目录下。只要把纯仓库复制上去:
$ scp -r my_project.git user@git.example.com:/opt/git
现在,其他对该服务器具有 SSH 访问权限并可以读取 /opt/git 的用户可以用以下命令克隆:
$ git clone user@git.example.com:/opt/git/my_project.git
假如一个 SSH 用户对 /opt/git/my_project.git 目录有写权限,他会自动具有推送权限。这时如果运行 git init 命令的时候加上 --shared 选项,Git 会自动对该仓库加入可写的组。
$ ssh user@git.example.com $ cd /opt/git/my_project.git $ git init --bare --shared
可见选择一个 Git 仓库,创建一个纯的版本,最后把它放在你和同事都有 SSH 访问权的服务器上是多么容易。现在已经可以开始在同一项目上密切合作了。
值得注意的是,这的的确确是架设一个少数人具有连接权的 Git 服务的全部——只要在服务器上加入可以用 SSH 接入的帐号,然后把纯仓库放在大家都有读写权限的地方。一切都做好了,无须更多。
下面的几节中,你会了解如何扩展到更复杂的设定。这些内容包含如何避免为每一个用户建立一个账户,给仓库添加公共读取权限,架设网页界面,使用 Gitosis 工具等等。然而,只是和几个人在一个不公开的项目上合作的话,仅仅是一个 SSH 服务器和纯仓库就足够了,请牢记这一点。
小型安装
如果设备较少或者你只想在小型的开发团队里尝试 Git ,那么一切都很简单。架设 Git 服务最复杂的方面之一在于账户管理。如果需要仓库对特定的用户可读,而给另一部分用户读写权限,那么访问和许可的安排就比较困难。
SSH 连接如果已经有了一个所有开发成员都可以用 SSH 访问的服务器,架设第一个服务器将变得异常简单,几乎什么都不用做(正如上节中介绍的那样)。如果需要对仓库进行更复杂的访问控制,只要使用服务器操作系统的本地文件访问许可机制就行了。
如果需要团队里的每个人都对仓库有写权限,又不能给每个人在服务器上建立账户,那么提供 SSH 连接就是唯一的选择了。我们假设用来共享仓库的服务器已经安装了 SSH 服务,而且你通过它访问服务器。
有好几个办法可以让团队的每个人都有访问权。第一个办法是给每个人建立一个账户,直截了当但过于繁琐。反复的运行 adduser 并且给所有人设定临时密码可不是好玩的。
第二个办法是在主机上建立一个 git 账户,让每个需要写权限的人发送一个 SSH 公钥,然后将其加入 git 账户的 ~/.ssh/authorized_keys 文件。这样一来,所有人都将通过 git 账户访问主机。这丝毫不会影响提交的数据——访问主机用的身份不会影响commit的记录。
另一个办法是让 SSH 服务器通过某个 LDAP 服务,或者其他已经设定好的集中授权机制,来进行授权。只要每个人都能获得主机的 shell 访问权,任何可用的 SSH 授权机制都能达到相同效果。
http://www.ossxp.com/doc/git/gitolite.html