Упатство:MoinMoin
Упатство за инсталација на MoinMoin со mod_wsgi (по мое)
Целта на ова упатство е целосно инсталиран и функционален MoinMoin wiki софтвер во mod_wsgi околина, во Linux.
MoinMoin е wiki софтвер напишан во Python. Главната разлика со на пр. MediaWiki е што MediaWiki е претежно ориентиран кон јавни wiki-ја, додека MoinMoin овозможува поголема контрола, посебно преку флексибилниот ACL систем. Исто така згодно е што може да се проширува со богата палета на Python код. Исто така има можност за подобро организирање на страните, во хиерархија и категории и може да користи повеќе markup јазици за содржината. MoinMoin не користи база на податоци и си има сопствен full-text search. Некои сајтови кои користат MoinMoin се Ubuntu, Fedora, Debian и други.
mod_wsgi е модул за Apache кој го вклучува Python интепретерот директно во Apache web серверот и овозможува на едноставно сервирање на WSGI апликации. mod_wsgi е напишан како одговор на mod_python модулот кој со годините стана прекомплициран и напластен од проблеми за кои нема лесно решение. Ако прашањето е Python+Apache, одговорот е mod_wsgi.
Оваа комбинација сметам дека е најдобра варијанта од сите за хостирање на MoinMoin wiki, па и за wiki софтвер воопшто.
За упатствово се користени последните верзии на MoinMoin (1.6.2) и mod_wsgi (2.0) кои беа достапни во времето на пишување. Упатството е тестирано на Убунту-сервер JEOS (не за друго, истовремено го тестирав и него).
Пред да почнеме
Претпоставката е дека имате основни познавања од Apache2, каде му се конфигурациските датотеки, како се додава виртуелен host, како се рестартира и сл. Исто така познавање и снаоѓање со shell алатки многу ќе ви помогне. Конечно за еден дел од упатството ќе треба да знаете како кој user работи Apache-то - ова е различно на разни дистрибуции (www-data на Debian/Ubuntu, nobody на ArchLinux).
Поглед врз големата слика (the 10,000 feet view)
TODO
Инсталација на mod_wsgi
Шансите се дека mod_wsgi го имате како пакет во вашата Linux дистрибуција. Ако не, инсталацијата е прилично едноставна. Познатата процедура:
tar xf mod_wsgi-2.0.tar.gz cd mod_wsgi-2.0 ./configure make sudo make install
ќе работи секогаш и секаде. На крајот треба да се добие една единствена датотека во /usr/lib/apache/ (или /usr/lib/apache2/ или /usr/lib/httpd/ или сл. зависно од дистрибуцијата) 'mod_wsgi.so'.
Инсталација на MoinMoin
Стандардната инсталација на MoinMoin (python setup.py install) моментално нема опција да ги инсталира датотеките по моја желба, но затоа едноставно копирање врши работа.
tar xf moin-1.6.2.tar.gz cd moin-1.6.2/ mkdir /srv/moin cp -r MoinMoin/ /srv/moin/ cp -r wiki/htdocs/ /srv/moin/ python -m compileall /srv/moin/MoinMoin/
Креирање на wiki инстанца
Откако е поставена онсновната инфраструктура, продолжуваме со креирање на wiki инстанца. Wiki инстанци може да имаме повеќе секоја со посебен изглед, посебни преференции и сл. Првото wiki нека се вика my-wiki. Сеуште во директориумот со отпакуваниот source на moin (moin-1.6.2/) ги извршуваме следниве команди:
mkdir /srv/moin/my-wiki cp -r wiki/data/ wiki/underlay/ /srv/moin/my-wiki/ cp wiki/config/wikiconfig.py wiki/server/moin.wsgi /srv/moin/my-wiki/
Содржината на /srv/moin/my-wiki/moin.wsgi треба да биде следнава (се повеќе може да се брише):
# -*- coding: utf-8 -*- import sys sys.path.insert(0, '/srv/moin/my-wiki') from MoinMoin.server.server_wsgi import WsgiConfig, moinmoinApp class Config(WsgiConfig): logPath = '/srv/moin/my-wiki/moin.log' # adapt this to your needs! #import logging #loglevel_file = logging.INFO # adapt if you don't like the default config = Config() # MUST create an instance to init logging! application = moinmoinApp
Во wikiconfig.py се подесуваат сите параметри на MoinMoin инстанцата. Нема да ги објаснувам деталите бидејќи има коментари во самата датотека, но најважно е да се подесат абсолутни патеки до следните директориуми:
data_dir = '/srv/moin/my-wiki/data/' ... data_underlay_dir = '/srv/moin/my-wiki/underlay/'
Постојат две важни можности за хостирање на апликации со mod_wsgi. Првата е вграден (embedded) режим, во кој wsgi апликацијата работи со исти привилегии како Apache процесот (www-data, nobody или друго). Втората е daemon режим во кој секоја wsgi апликација си работи со посебни привилегии т.е. како посебен корисник.
Вграден режим
Во овој режим, wiki инстанцата ја доделуваме на корисникот „www-data“ за да може apache процесот да запишува во датотеките:
chown www-data -R /srv/moin/my-wiki/
Конфигурацијата за виртуелниот Apache домаќин:
WSGIPythonPath /srv/moin <VirtualHost *> ServerName wiki DocumentRoot /srv/moin/htdocs/ Alias /moin_static162/ /srv/moin/htdocs/ <Directory "/srv/moin/htdocs/"> Options FollowSymLinks Order allow,deny Allow from all </Directory> WSGIScriptAlias / /srv/moin/my-wiki/moin.wsgi ErrorLog /var/log/apache2/wiki-error.log CustomLog /var/log/apache2/wiki-access.log combined LogLevel warn </VirtualHost>
Ова е помалку препорачан режим, кој има смисла единствено ако MoinMoin е единствената апликација на серверот.
Daemon режим
Овој режим е посигурен, бидејќи апликацијата си работи како посебен корисник. Во случај да имаме повеќе апликации на истиот сервер, тие апликации нема да можат да се мешаат во работата на другите. За таа цел прво ќе креираме нов корисник, па потоа на тој корисник ќе му ги доделиме датотеките од wiki инстанцата.
adduser --no-create-home --disabled-password --disabled-login \ --gecos "" --home /srv/moin/my-wiki/ --ingroup nogroup my-wiki chown my-wiki -R /srv/moin/my-wiki/
Конфигурацијата за виртуелниот Apache домаќин:
<VirtualHost *> ServerName wiki DocumentRoot /srv/moin/htdocs/ Alias /moin_static162/ /srv/moin/htdocs/ <Directory "/srv/moin/htdocs/"> Options FollowSymLinks Order allow,deny Allow from all </Directory> WSGIDaemonProcess my-wiki user=my-wiki home=/srv/moin/my-wiki python-path=/srv/moin WSGIProcessGroup my-wiki WSGIScriptAlias / /srv/moin/my-wiki/moin.wsgi ErrorLog /var/log/apache2/wiki-error.log CustomLog /var/log/apache2/wiki-access.log combined LogLevel warn </VirtualHost>
Надградба
Кога би требало да го надградиме MoinMoin софтверот, прво треба да се прочитаа забелешките за новата верзија. Претежно процедурата е дека освен /srv/moin/my-wiki/data и config датотеките, сѐ друго треба да се пребрише со нови верзии (MoinMoin, htdocs, underlay). Во source дрвото на moin има и алатка за евентуална миграција на data директориумот.