🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
在《[Publishing Mercurial Repositories](http://mercurial.selenic.com/wiki/PublishingRepositories)》这篇文章中介绍了很多种将我们自己的hg代码库发布/公开的办法。其中最轻量型的办法是使用hg自带的web server发布,只需要在代码库目录下执行命令hg serve就搞定。但是这只是一个临时的方案,如果想要更健壮更安全,官网还是建议使用hgweb脚本+Web server(apache,IIS等)的方式。 查看资料后,我权衡利弊,准备以《[Serving Mercurial repositories with Apache and mod_wsgi](http://mercurial.selenic.com/wiki/modwsgi)》为蓝本再结合其他教程和实践,来搭建自己的hg server供局域网中的小伙伴使用。 #### 1.工具 mod_wsgi:apache和python沟通的桥梁。 apache2:这个家伙仍然在web server领域引领风骚。 python:2.7版本足以。 mercurial:这是我们的主角。 hgweb.wsgi:mercurial给我们提供的。 linc注:我是这WEB方面的门外汉,对cgi和wsgi等概念是一无所知,之前搭建Scrum环境是在Windows下使用傻瓜似工具,根本没机会配置apache。因此,接下来的工作令我苦不堪言。有不足之处也在所难免。更请高手指正。 #### 2.安装 我在Ubuntu下使用apt-get install安装这些工具,十分顺利,闲言少叙。 *sudo apt-get install apache2* 完成后即使不做任何配置,在浏览器中输入localhost,也会出现“It works!”。那么apache就算安装成功。 *sudo apt-get install libapache2-mod-wsgi* 安装后在/usr/lib/apache2/modules/目录下会发现多了mod_wsgi.so ~~~ lrwxrwxrwx 1 root root     15 Nov 19 00:50 mod_wsgi.so -> mod_wsgi.so-2.7   -rw-r--r-- 1 root root 152064 Nov 19 00:50 mod_wsgi.so-2.7   ~~~ #### 3.关于apache目录这件小事 1)/var/www 这个目录是用来放置我们的网站的入口,默认这里会有个index.html,刚才我们打开localhost出现的界面就是这个index.html了。后续我们会在这个目录下做文章。 2)/etc/apache2 我们要在这里做apache的配置,重点文件有apache2.conf,httpd.conf,以及sites-available下的default。 #### 4.配置 按照教程的例子,我也以虚拟主机 “hg.example.net"来完成整个配置。 **第一步,加载mod_wsgi** 我们的配置(user configurations)在/etc/apache2/httpd.conf中进行, 加载mod_wsgi只需添加LoadModule wsgi_module modules/mod_wsgi.so 即可。 linc注:后来我又将此句注释掉,发现依然运行正常。 **第二步,配置apache** 依例子的要求,我们要做以下工作。 1)在www下创建新文件夹 /var/www/vhosts/hg.example.net/cgi-bin /var/www/vhosts/hg.example.net/htdocs 2)修改/etc/apache2/sites-avaiable/default 变成如下: ~~~        ServerName hg.example.net       DocumentRoot /var/www/vhosts/hg.example.net/htdocs          WSGIScriptAliasMatch ^(.*)$ /var/www/vhosts/hg.example.net/cgi-bin/hgweb.wsgi$1                     Options FollowSymlinks           DirectoryIndex index.html           AllowOverride None           Order allow,deny           Allow from all                            Options ExecCGI FollowSymlinks              AddHandler wsgi-script .wsgi           AllowOverride None           Order allow,deny           Allow from all             ~~~ **第三步,配置Mercurial** 1)将hgweb.wsgi文件复制到/var/www/vhosts/hg.example.net/cgi-bin/ sudo cp /usr/share/doc/mercurial-common/examples/hgweb.wsgi /var/www/vhosts/hg.example.net/cgi-bin/ 修改成如下: ~~~ # Path to repo or hgweb config to serve (see 'hg help hgweb')   config = "/var/www/vhosts/hg.example.net/cgi-bin/hgweb.config"      # enable demandloading to reduce startup time   from mercurial import demandimport; demandimport.enable()      from mercurial.hgweb import hgweb   application = hgweb(config)   ~~~ 2)hgweb.config 在/var/www/vhosts/hg.example.net/cgi-bin/新加文件hgweb.config 内如如下: ~~~ [web]   style = coal      [paths]   / = /var/www/vhosts/hg.example.net/htdocs/**   ~~~ 重启apache: *sodu /etc/init.d/apache2 restart* 到此,《Serving Mercurial repositories with Apache and mod_wsgi》便结束了。 **第四步,创建hg代码仓库** 将代码放在哪里?一直没有好主意,看到有人将其放在/var下了,姑且我也这样吧。 新建目录/var/hg/repos/test, *mkdir /var/hg/repos/test; cd /var/hg/repos/test; hg init* 一个临时的代码仓库就创建完了,下面如何跟server联系在一起呢? 回过头来,我们还要修改一下hgweb.config,加入下面两句: ~~~ [collections]   /var/hg = /var/hg   ~~~ 重启apache后,在浏览器中输入:localhost/repos/test 你的代码库就出现了呢。这样就说明我们的工作完成了。你可能要问,直接在浏览器中输入hg.example.net不也可以吗?是这样的,但是我们还要做一项工作,在/etc/hosts文件中加入127.0.0.1   hg.example.net 才行. 好吧,先庆祝一下,下文再说代码提交遇到的问题以及身份认证问题。 参考: http://mercurial.selenic.com/wiki/PublishingRepositories http://mercurial.selenic.com/wiki/modwsgi http://stackoverflow.com/questions/12347373/how-to-setup-mercurial-server-in-ubuntu-to-serve-60-repositories http://thepanz.netsons.org/post/ubuntu-10-4-and-mercurial-server-apache2-mod_wsgi/comment-page-1 http://blog.sina.com.cn/s/blog_4567bb800100whho.html http://blog.csdn.net/tony1130/article/details/5326015 http://blog.csdn.net/kongdaoxian/article/details/7944872