本文出自:

准备

安装以下工具:

nginx

uwsgi

virtualenv

nginx和uwsgi搭建另一篇文章:

安装virtualenv,需先安装pip,pip可以很方便的安装、卸载和管理Python的包。

virtualenv则可以建立多个独立的虚拟环境,各个环境中拥有自己的python解释器和各自的package包,互不影响。virtualenv 工具可将你系统所安装的 python 程序抽离出来,放在一个特定的目录下,供 python 应用程序(例如本文所讲的 moinmoin)使用。这样即便系统中更换了 python 版本,也不会对已部署的 python 应用产生负面影响。

pip和virtualenv可以很好的协同工作,同时使用这两个工具非常方便。

一般先安装pip,安装好后,pip install virtualenv就可以自动从网上下载并安装virtualenv了。然后virtualenv env1就可以创建一个名为env1的虚拟环境了,进入这个虚拟环境后,再使用pip install安装其它的package就只会安装到这个虚拟环境里,不会影响其它虚拟环境或系统环境。

安装pip:

pip下载地址是:

下载后解压,

tar zxvf pip-1.4.1.tar.gz

cd pip-1.4.1

python setup.py install

安装:virtualenv

pip install virtualenv

如果出现:-bash: pip: command not found,找到pip可执行文件路径:

[root@htuidc ~]# find /* -name pip

/usr/local/python27/bin/pip

然后:

[root@htuidc ~]# /usr/local/python27/bin/pip install virtualenv

就能成功安装。

一、下载moinmoin 软件包

cd /data/web

wget http://static.moinmo.in/files/moin-1.9.7.tar.gz

tar zxvf moin-1.9.7.tar.gz

cd moin-1.9.7

二、安装 moinmoin:

######## 构建 python 的隔离环境

# mkdir -p /data/web/moinmoin

# virtualenv /data/web/moinmoin/python-env

######## 激活 python 隔离环境,并将 moinmoin 安装至其中

# cd /data/web/moin-1.9.7

# source /data/web/moinmoin/python-env/bin/activate

# python setup.py install

######## 将 moinmoin 的实例安装至 /data/web/moinmoin/wiki 目录

# cp -r ./wiki /data/web/moinmoin

# cd /data/web/moinmoin/wiki

# cp config/wikiconfig.py ./

# cp server/moin.wsgi ./

######## 关闭 python 隔离环境

# deactivate

完成上述步骤之后,可以发现,拜 virtualenv 工具所赐,所有与 moinmoin 相关的文件均被安装至 /var/www/moinmoin/python-env/share/moin 与 /var/www/moinmoin/python-env/lib/python2.7/site-packages/MoinMoin 目录,而原本它们默认是被安装至 /usr/share/moin 与 /usr/lib/python2.7/site-packages/MoinMoin 目录。

三、配置 nginx:

server {

listen 80;

server_name localhost;

location ^~ /wiki {

include uwsgi_params;

uwsgi_pass 127.0.0.1:8630;

uwsgi_param UWSGI_PYHOME /data/web/moinmoin/python-env/;

uwsgi_param UWSGI_CHDIR /data/web/moinmoin/wiki/;

uwsgi_param UWSGI_SCRIPT moin_wsgi;

uwsgi_param SCRIPT_NAME /wiki;

uwsgi_modifier1 30;

}

location ^~ /wiki/moin_static/ {

alias /data/web/moinmoin/python-env/lib/python2.7/site-packages/MoinMoin/web/static/htdocs/;

add_header Cache-Control public;

expires 1M;

}

location = /favicon.ico {

log_not_found off;

}

}

下面,大致分析一下上述代码的工作过程。

如果网页浏览器传入的请求是“192.168.0.2/wiki”,那么 nginx 会根据 "location ^~ /wiki" 代码段的设定主要进行以下处理:

加载 /etc/nginx 目录中的“uwsgi_params.conf”文件;

通过 127.0.0.1:8630与 uwsgi 服务器通信,类似于进程管道;

设置 python 运行环境,这里使用的是上文中 virtualenv 工具所构造的 python 目录,其中包含着 python 程序本身以及上文中所安装的 moinmoin 软件包;

设置 uwsgi 服务器在相应 http 请求(http://192.168.0.7)之前,先进入 /data/web/moinmoin/wiki 目录,这个目录是前文中我们建立的 moinmoin 实例;

设置 uwsgi 服务器要运行的 python 程序,即 moin.wsgi;

设置 uwsgi 服务器所运行的 python 程序对应的 http 请求为

四、配置 uwsgi:

如果希望直接在命令行中启动 uwsgi,那么只需使用以下命令即可:

uwsgi -x /etc/uwsgi/uwsgi.xml

当然,这需要在 /etc/uwsgi 目录中建立 uwsgi 的配置文件 uwsgi.xml,内容如下:

<uwsgi>

<socket>/tmp/wiki.sock</socket>

<limit-as>256</limit-as>

<processes>6</processes>

<memory-report/>

<vhost/>

<no-site/>

</uwsgi>

五、打开

如果出现网页没有图片和css样式的显示问题,请检查网页源码中引用CSS的路径是不是不存在(查看方法:网页中右击,选择"查看源码"),然后根据情况修改 location ^~ /wiki/moin_static/ 的alias路径和moinwiki模板跟目录wikiconfig.py配置文件中的url_prefix_static的值,直到正确显示为止。