因为后面要采用Git代替Subversion,花了点时间配置了Git服务端和客户端,像以前一样,仍然基于最新的Ubuntu11.10 server/desktop系统。

感谢这几篇文章的作者:

http://www.hackido.com/2010/01/installing-git-on-server-ubuntu-or.html

同时参考一下:

http://www.debuntu.org/ssh-key-based-authentication 这篇文章介绍了SSH公钥和私钥的生成方法。

这篇文章里面介绍了新加用户的部分补充了第一篇文章的不足。

http://www.jiangmiao.org/blog/1600.html

这篇文章介绍了ssh-keygen命令的参数

http://lamp.linux.gov.cn/OpenSSH/ssh-keygen.html

我的安装步骤主要来源于上面引用的第一篇文章,并补充不足之处(比如原文第6条作者没说清楚)。

注意,Git是分布式管理工具,因此没有真正的Server,本文用了三台机器,分别是

S1 代表 机房里面的Ubuntu 11.10 server

C1 代表 第一台拥有管理权限的 Ubuntu desktop

C2 代表 后来被添加进来的拥有管理权限的Ubuntu desktop

三台机器都可以看作是服务器。只是从方便人使用的角度,总是将项目文件提交到S1上,并从S1上获得最新项目文件。

1.Ubuntu server安装Git服务程序

下文称这台Ubuntu server为S1

  1. sudo apt-get install git-core

2.S1上安装Gitosis程序.

Gitosis是一个工具程序,可以帮助我们进行Git仓库的访问控制和远程管理。

  1. sudo apt-get install python-setuptools
  2. mkdir ~/src
  3. cd ~/src
  4. git clone https://github.com/res0nat0r/gitosis.git
  1. cd gitosis
  2. sudo python setup.py install

3.S1上创建一个git帐号。

没有密码。这个帐号是给Gitosis程序使用的。

  1. sudo adduser \
  2. --system \
  3. --shell /bin/sh \
  4. --gecos 'git version control' \
  5. --group \
  6. --disabled-password \
  7. --home /home/git \
  8. git

4.安装远程管理客户端

下文将第一个远程管理客户端称为C1

  1. sudo apt-get install openssh-client
  2. ssh-keygen

如果没有安装openssh-client,才需要第一行命令。ssh-keygen命令会创建公钥和私钥文件。将公钥文件复制到服务端。然后在S1上导入到Gitosis中以后C1就无需用户名和密码便能通过SSH连接服务端了。

  1. scp /home/chenshu/.ssh/id_rsa.pub cncm@S1:/home/cncm
  2. sudo -H -u git gitosis-init < /home/cncm/id_rsa.pub

得到下面的结果:

Initialized empty Git repository in /home/git/repositories/gitosis-admin.git/
Reinitialized existing Git repository in /home/git/repositories/gitosis-admin.git/

意思是S1上已经成功创建了仓库目录,路径是/home/git/repositories,并且里面还创建了一个管理员仓库,叫gitosis-admin。

修改S1上一个文件的权限:

  1. sudo chmod 755 /home/git/repositories/gitosis-admin.git/hooks/post-update

从S1上clone出gitosis-admin仓库到C1:

  1. /home/chenshu/my_git
  2. cd ~/my_git
  1. git clone git@S1:gitosis-admin.git
  2. Cloning into gitosis-admin...
  3. remote: Counting objects: 5, done.
  4. remote: Compressing objects: 100% (4/4), done.
  5. remote: Total 5 (delta 1), reused 5 (delta 1)
  6. Receiving objects: 100% (5/5), done.
  7. Resolving deltas: 100% (1/1), done.

现在你可以通过修改gitosis-admin/gitosis.conf文件来远程管理S1上的仓库:

  1. [gitosis]
  2. [group gitosis-admin]
  3. members = chenshu@chenshu-System-Product-Name
  4. writable = gitosis-admin

上面是之前gitosis初始化导入C1的公钥的时候自动创建的,已经将C1的用户加入到管理员成员中

注意:也可以就在服务器端完成本节操作,不一定非要到客户端。

5.加入新用户

现在另一台Ubuntu客户端C2,用户也想加入进来使用cml项目,并管理git仓库。

C2机器的使用者在C2上产生公钥和私钥文件,并将公钥文件传给C1的使用者(因为C1的使用者现在是管理员)

  1. ~/my_git/gitosis-admin$ mv ~/id_rsa.pub ./keydir/root@s15438266.onlinehome-server.com.pub

上面的命令是在C1上把C2产生的公钥文件id_rsa.pub复制到/home/chenshu/my_git/gitosis-admin/keydir目录下,并改名为root@s15438266.onlinehome-server.com.pub

文件名是根据id_rsa.pub里面的用户名来的。

  1. [group gitosis-admin]
  2. members = chenshu@chenshu-System-Product-Name root@s15438266.onlinehome-server.com
  3. writable = gitosis-admin

修改gitosis.conf文件,加入root@s15438266.onlinehome-server.com(去掉.pub后缀)到gitosis-admin组,也就是root@s15438266.onlinehome-server.com.pub成了管理员

在gitoosis-admin目录下,提交设置到服务端:

  1. git add .
  2. git commit -am'add a new user'
  3. git push

现在到C2上试一下:

  1. git clone git@S1:gitosis-admin.git

ok,成功获得该目录。

6.创建新项目

仍然编辑C1上的gitsosis.conf文件,加入

  1. [group cml]
  2. members = chenshu@chenshu-System-Product-Name root@s15438266.onlinehome-server.com
  3. writable = cml

[group cml] 一节 代表新的组(项目cml),也将C1,C2的用户加入进来.先提交一下配置文件。

  1. git add .
  2. git commit -am'add a new project named cml'
  3. git push

然后再添加真实的项目文件。在顶层目录,我这里是/home/chenshu/my_git/下面创建项目目录cml,将需要的项目文件复制到cml中,然后执行下面的命令,将cml项目加入到S1中:

  1. cd cml
  2. git init //cml中会创建一个.git,里面包含了git版本库的框架
  1. touch x
  2. git add .
  3. git remote add origin git@S1:cml.git //可以在git add . 之前运行
  4. git commit -am 'add cml project'
  5. git push origin master:refs/heads/master

7.获得cml项目

在C1或者C2机器上任何一个目录下,执行

  1. git clone git@S1:cml.git

就可以获得刚才加入到S1上的cml项目。

8.编写脚本自动编译并部署时的注意

如果想在C2上编写脚本自动从S1上获取最新代码时,要注意:

1.首先之前产生的公钥不能设密码,否则每次git pull的时候都会要求输入密码。

2.不要将项目中的编译中间文件提交到S1上,比如CMake工程里面的build目录的文件,Maven工程里面的target目录里面的文件。否则下次在C2等客户端用git pull会报类似于这样的错误:

error: Untracked working tree file 'public/images/icon.gif' would be overwritten by merge.

需要执行下面的命令才能修复:

  1. git reset --hard HEAD
  2. git clean -f -d
  3. git pull

9.改变默认端口

默认使用的是SSH22端口,也就是Git连接远程服务器的22端口。如果服务器改变了端口号,比如443怎么办?

在你的当前工程根目录下,有一个.git目录,打开里面的config文件,在[remote "origin"] 一节将url修改一下:

url = ssh://git@S1:443/cml.git
#url = git@S1:cml.git

如果还没有工程,需要clone一份,用下面的命令:

git clone ssh://git@S1:443/cml.git

10.Git add违反直觉的多用途

最简单的用法,将一个未被tracked的文件加入到Git中;

比较莫名的是,如果一个已经被tracked的文件被修改了,必须再add一次,才能使得它的状态变为staged,也就是在staged area中记录下来它被修改了,否则接下来的commit操作直接忽视它;。因此在commit之前,用git status来确认所有修改的文件都已经在staged area中很有必要。真的繁琐,其实有时候需要一个快捷命令一次搞定,可以在commit的时候加上-a参数即可。将会自动在commit之前运行add命令。

居然还可以用add标记文件冲突已经解决。

11.Agent admitted failure to sign using the key

遇到一个很奇怪的问题,添加一个用户的时候一切步骤都是正确的,就是一直要求输入密码。当然有个报错信息:

Agent admitted failure to sign using the key

原来需要在客户端导入私钥,用下面的命令:

ssh-add ~/.ssh/id_rsa

原因不明,现在对SSH认证机制的原理还不够清楚,以后慢慢弄明白吧。

12.直接从本地仓库中clone

在Ubuntu下,按照以上的操作完成服务器搭建后,默认git文件会存放在/home/git/repositories目录下。用下面的命令直接clone即可。

git clone /home/git/repositories/cml.git

fatal: remote origin already exists.

解决办法:

$ git remote rm origin

转自:http://blog.csdn.net/sheismylife/article/details/7204345

git server 配置的更多相关文章

  1. Windows下安装 msysGit 以及初始化 Git server环境

    Windows下git工具msysGit使用以及Git server初始化 Windows下git工具,这里选择msysGit,版本为msysGit-netinstall-1.8.1.2-previe ...

  2. Windows 下用 gogs 配置局域网 git server

    大道曙光 Windows 下用 gogs 配置局域网 git server 最近要用 C# 开发一个新的项目,所以需要在 Windows 局域网环境下构建一个 git server. 在 Window ...

  3. Jenkins-在windows上配置自动化部署(Jenkins+Bonobo.Git.Server)

    本文配置Jenkins.git服务器采用 Bonobo.Git.Server 1. 登录后,打开Jenkins界面,新建一个任务 2. 配置信息 3. 配置git项目地址,我们先进行其他配置,等会再继 ...

  4. 使用群晖NAS:配置Git server

    1.首先在群晖的DSM的控制面板中创建一个用户例如是Git_test(我给了管理员权限) 2.在套件中心安装 Git server 3.打开Git server 勾选用户 Git_test 4.在控制 ...

  5. 使用Gitblit 在windows 上部署你的Git Server

    Gitblit: 在windows 上部署你的Git Server 前言 之前在dudu的文章里看到过用bonobogit 部署在 IIS 7.5 上的Window 平台的git 服务器.学着部署使用 ...

  6. Ubuntu server 搭建Git server

    Ubuntu server 搭建Git server,git相比svn,最主要就是分布式了,每个客户端用户的本地都是一个版本管理控制器. Ubuntu server 版本为12.04 搭建步骤如下: ...

  7. UBUNTU上的GIT SERVER

    Git是一个开源的版本控制系统,由Linus Torvalds主导,用于支持Linux内核开发.每一个Git工作目录,都是一个完整的代码库,包含所有的提交历史.有能力跟踪所有的代码版本,而不会去依赖于 ...

  8. 在 mac os 上搭建 git server

    前言:之前学习了如何使用 git 后,一直想搭建一个本机搭建一个 git server 的,一开始不知道走了弯路用了 gitosis,折腾了我好几天都没配置好.昨晚查资料发现 gitosis 早就过时 ...

  9. ubuntu 14.04 安装git server

    版本信息 ubuntu : 14.04.1 git version 1.9.1 perl v5.10.1 ssh OpenSSH_6.6.1p1 本次安装的git server使用gitolite实现 ...

随机推荐

  1. 动态代理Dynamic Proxy

    代理模式是常用的Java设计模式,他的特征是代理类与委托类有同样的接口,代理类主要负责为委托类 预处理消息,过滤消息,把消息转发给委托类,以及事后处理消息等. 代理类与委托类之间通常会存在关联关系,一 ...

  2. cocoapod引入FLEX,debug模式正常,Release报错library not found for -lXXX

    cocoapod引入FLEX,debug模式正常,Release报错library not found for -lXXX, 因为podfile是这么写的: pod 'FLEX', '~> 2. ...

  3. java JDBC (六) org.apache.commons.dbutils 增删改

    dbutils是apache封装了JDBC的工具类,比mysql-connector更方便些 下载地址:http://commons.apache.org/proper/commons-dbutils ...

  4. 【Python爬虫】Requests库的基本使用

    Requests库的基本使用 阅读目录 基本的GET请求 带参数的GET请求 解析Json 获取二进制数据 添加headers 基本的POST请求 response属性 文件上传 获取cookie 会 ...

  5. Oracle内置函数SQLCODE和SQLERRM的使用

    在我们写proc程序中经常要有错误处理,在错误处理中我们经常要输出错误信息来给帮助我们分析和解决错误原因,从而更正数据.这时候就会用到SQLCODE和SQLERRM. SQLCode:数据库操作的返回 ...

  6. WordPress禁用插件另类方法不用进后台

    刚刚一小美女说她在WordPress后台启用了一个插件后出现了问题,网站前端和后端都不能打开了,ytkah查看了一下是有个插件api和另一个插件冲突了,但要怎么禁用呢?有两个办法可以解决 1.直接删除 ...

  7. what's the 头寸

    头寸,是一种市场约定,承诺买卖外汇合约的最初部位,买进外汇合约者是多头,处于盼涨部位:卖出外汇合约为空头,处于盼跌部位.头寸可指投资者拥有或借用的资金数量. “头寸”一词来源于近代中国,银行里用于日常 ...

  8. 敏捷开发— —Scrum 学习笔记

    敏捷开发模式是一种从1990年代开始逐渐引起广泛关注的一些新型软件开发方法,是一种应对快速变化的需求的一种软件开发能力.它们的具体名称.理念.过程.术语都不尽相同,相对于"非敏捷" ...

  9. 根据构建类型动态设置AndroidManifest.xml文件中的meta-data

    当debug和release版本使用不同的值时,使用Gradle设置相应的值. Android主配置文件 <meta-data android:name="com.amap.api.v ...

  10. Python itsdangerous 生成token和验证token

    代码如下 class AuthToken(object): # 用于处理token信息流程: # 1.更加给定的用户信息生成token # 2.保存生成的token,以便于后面验证 # 3.对用户请求 ...