在 CentOS 下使用 apache+mod_wsgi 部署了 MoinMoin,但是编辑和保存页面很慢,于是准备使用 nginx+uwsgi 重新部署
本文假定已经按照官方指引 Quick MoinMoin on CentOS 完成了 apache 和 mod_wsgi 之外的基础安装
安装 Nginx
默认情况下,CentOS 下没有 nginx 的源,需要自己手动添加,访问 http://nginx.org/en/linux_packages.html#stable 下载 CentOS 6 的 rpm 包,并安装
1
2
|
wget http: //nginx .org /packages/centos/6/noarch/RPMS/nginx-release-centos-6-0 .el6.ngx.noarch.rpm
rpm -ivh nginx-release-centos-6-0.el6.ngx.noarch.rpm
|
然后执行下面的命令安装 nginx
yum install nginx
安装 uwsgi
安装 python 包管理工具 pip
1
2
|
yum install python-devel python-setuptools
wget https: //raw .github.com /pypa/pip/master/contrib/get-pip .py -O - | python
|
通过 pip 安装 uwsgi (使用豆瓣的境像)
1
|
pip install - v uwsgi -i http: //pypi .douban.com /simple
|
使用 uwsgi 启动 moin
创建 uwsgi 配置 /etc/uwsgi/uwsgi.xml 内容如下
1
2
3
4
5
6
7
8
9
|
< uwsgi >
< socket >/var/run/moin.sock</ socket >
< chmod-socket >666</ chmod-socket >
< limit-as >256</ limit-as >
< processes >6</ processes >
< memory-report />
< vhost />
< no-site />
</ uwsgi >
|
其中 <chmod-socket>666</chmod-socket> 这句是这了防止 nginx 访问 moin.sock 没有权限。
重命名 moin 的 wsgi 启动脚本,以被 uwsgi 识别
1
2
|
cd /usr/local/share/moin
mv moin.wsgi moin_wsgi.py
|
要启动 uwsgi 可以使用下面的命令
1
|
uwsgi -x /etc/uwsgi/uwsgi .xml
|
配置 nginx 访问 uwsgi
建立 /etc/nginx/conf.d/moin.conf 内容如下
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
# moinmoin 虚拟主机配置
server {
listen YOUR_SERVER_IP: 80 ;
server_name localhost;
access_log / var / log / nginx / moin.access_log main;
error_log / var / log / nginx / moin.error_log info;
location ^~ / {
include uwsgi_params;
uwsgi_pass unix: / / / var / run / moin.sock;
# uwsgi_param UWSGI_PYHOME /usr/local/lib/python2.6/; #site-packages/;
uwsgi_param UWSGI_CHDIR / usr / local / share / moin / ;
uwsgi_param UWSGI_SCRIPT moin_wsgi;
uwsgi_param SCRIPT_NAME / ;
uwsgi_modifier1 30 ;
}
location ^~ / moin_static193 / {
alias / usr / local / lib / python2. 6 / site - packages / MoinMoin / web / static / htdocs / ;
add_header Cache - Control public;
expires 1M ;
}
}
|
运行 nginx
1
|
nginx
|
运行及故障排除
接下来你可以通过浏览器访问 Wiki 了,但是发现编辑和保存页面依旧很慢,然后稍微 Google 了下就发现了 一篇解决这个问题的文章,很快解决了慢的问题
编辑 wikiconfig.py 加入如下配置
log_reverse_dns_lookups = False
重启 uwsgi 后再访问 Wiki,发现慢的问题解决了(为什么我之前没有找到这篇文章!)