搭建 Windows 上 Apache + Git 服务器

在公司一直使用 SVN 作版本控制,不过 SVN 的 branch 是在过于灵活。我们所希望的只是一种简单的分支系统:各个分支能够完全独立开来,不会牵扯到复杂的 merge 操作。因此,决定搭建一个 Git 服务器。由于目前没有合适的 Linux 服务器,因此只能尝试在 Windows 上搭建。

在 Windows 上搭建 Git 服务器一般使用 SSL + putty + msysGit 完成。不过按照网上的做法始终不能成功。所以开始选择另外的一种搭建方法:基于 Apache 服务器搭建 Git 服务器。这样做的好处是免除了 SSH 在 Windows 上的配置,同时可以使用 HTTP(S) 协议访问版本库。经过一番尝试,终于实现了在 Windows 上搭建好 Apache + Git 服务器,现在将搭建方法记录于此。

第一步:安装 Git

由于 Git 官方没有提供 Windows 上的安装程序,我们只能使用第三方实现。好在还是有不错的选择,而且其实现也算是比较完美。我选择的是 msysGit,你可以从这里下载到最新版本。在本文写作时,最新版本是 1.7.6。下载完成后直接双击安装就可以。这里需要注意的是,网上有些文章声称,需要在安装时选择 Run git from the Windows Command prompt。对此持保留意见,因为不选择这一项也是可以的。不过为了谨慎起见,还是选择此项为好。

安装完毕后,开始菜单会多出 Git 一项,里面有 Git GUI 和 Git Bash,前者是图形界面,后者是命令行界面。msysGit 默认的安装路径是 C:\Program Files\Git。下面我们可以进入 C:\Program Files\Git\libexec\git-core 目录,双击运行 git-http-backend.exe 程序。这个程序的作用就是处理 HTTP 请求。不过,此时你应该得到一个错误:

git error no dll

这个错误是说缺少 libiconv-2.dll。该文件位于 C:\Program Files\Git\bin。我们可以将其从这里复制到 C:\Program Files\Git\libexec\git-core 即可。

第二步:安装 Apache 服务器

下一步,你应该安装 Apache 服务器。从这里可以找到安装文件(包含 OpenSSL)。本文写作时最新稳定版本是 2.2.21。正常安装之后,Apache 会自动启动,并且占据 80 端口。你可以根据需要修改监听端口。然后我们打开浏览器,进入 http://localhost。如果浏览器页面显示 It works! 说明我们的服务器已经正确安装,那么就可以进行下一步操作了。

第三步:配置 Apache 服务器

现在,我们的 Git 和 Apache 都已经安装成功,下面就是配置 Apache 服务器。

进入 Apache 安装目录下的 conf 目录,用记事本打开 httpd.conf 文件。首先,找到<directory />,修改如下:

<directory />

Options FollowSymLinks

AllowOverride None

Order deny,allow

Allow from all

</directory>

然后在 httpd.conf 文件末尾追加:

# Set this to the root folder containing your Git repositories.

# 指定 Git 版本库的位置

SetEnv GIT_PROJECT_ROOT C:/workspace

# Set this to export all projects by default (by default,

# git will only publish those repositories that contain a

# file named “git-daemon-export-ok”

# 该目录下的所有版本库都可以透过 HTTP(S) 的方式存取

SetEnv GIT_HTTP_EXPORT_ALL

# Route specific URLS matching this regular expression to the git http server.

# 令 Apache 把 Git 相关 URL 导向给 Git 的 http 处理程序

ScriptAliasMatch \

“(?x)^/(.*/(HEAD | \

info/refs | \

objects/(info/[^/]+ | \

[0-9a-f]{2}/[0-9a-f]{38} | \

pack/pack-[0-9a-f]{40}\.(pack|idx)) | \

git-(upload|receive)-pack))$” \

“C:/Program Files/Git/libexec/git-core/git-http-backend.exe/$1”

 

<Location />

AuthType Basic

AuthName “GIT Repository”

AuthUserFile “C:/Program Files/Git/htpasswd”

Require valid-user

</Location>

上面修改内容中,第一个指令设置 Git 的版本库位置;第二个指令表示,该目录下的所有版本库都可以通过 HTTP(S) 的方式存取;第三个指令则是让 Apache 把 Git 相关 URL 导向给 Git 的 HTTP 处理程序,也就是我们前面提到的 git-http-backend.exe。最后的<Location />区段设定了虚拟根路径 “/” 的验证规则;C:/Program Files/Git/htpasswd 是账号密码文件,该文件可以在任何位置,也可以使任何名字,只要在这里指定即可。

完成上述修改之后,重启 Apache 服务。

如果你希望将来透过远端存取版本库时,一律使用 http://my-server/git/* 开头的 URL,则可将 ScriptAliasMatch 指令改为 “(?x)^/git/(.*/(HEAD | \ …….”

第四步:添加用户

下面,我们将向 htpassword 文件添加用户名和密码。这样,在我们提交版本是,Apache 服务器就可以根据这里我们指定的用户名和密码判断是否具有权限。

添加用户名和密码的操作应该使用 Apache 提供的 htpasswd 命令。使用命令提示符来到 Apache 安装目录下的 bin,输入命令:

htpasswd -cmb htpassword abc 123456

该命令执行后,会在当前目录下生成一个名为 htpassword 的文件,用户名为 abc,密码为 123456(加密的)。

htpasswd 命令还可以追加用户、修改用户密码、删除用户等,具体操作请查阅 htpasswd 使用手册。

第五步:测试

这里我们要建立一个测试库,以便查看我们的服务器是否能够正常运行。

我们使用 Git Bash,来到 C:/workspace 目录,运行如下命令:

git init –bare myapp.git

此时,会在 workspace 目录下建立一个空的版本库 myapp.git。然后我们运行

git clone http://localhost/myapp.git

此时,Git 会要求我们提供用户名和密码,之后就可以正常 clone。然后尝试修改文件,运行一下

git push origin master

在提供用户名和密码之后即可成功提交。

如果上面的命令都可以正常进行,则说明我们的服务器基本已经搭建完成。

30 Comments

  1. xeonwell 2011年10月12日
    • DevBean 2011年10月12日
      • xeonwell 2011年10月12日
        • DevBean 2011年10月12日
        • sooyoo 2011年12月16日
      • lean 2013年12月5日
        • 豆子 2013年12月8日
        • patton88 2015年12月27日
          • 豆子 2015年12月28日
          • patton88 2015年12月28日
          • patton88 2015年12月28日
  2. baibaiwei 2011年11月1日
    • DevBean 2011年11月1日
      • Kiwi 2012年8月7日
        • DevBean 2012年8月7日
          • troy 2013年2月4日
    • coommissar 2012年5月7日
    • lameck 2012年9月8日
      • robot 2012年9月28日
  3. haishizi 2012年4月6日
    • DevBean 2012年4月6日
  4. haishizi 2012年4月6日
  5. haishizi 2012年4月10日
    • DevBean 2012年4月10日
  6. haishizi 2012年4月10日
    • coommissar 2012年5月7日
  7. swteen 2016年12月20日
  8. swteen 2016年12月20日
    • 豆子 2016年12月25日

Leave a Reply