手册:Wiki农场
A wiki family is a collection of two or more wikis that run on the same server and share a common set of resources from the parent installation, while each wiki remains otherwise independent. This setup is an alternative to running fully separate installations of MediaWiki. It may be the preferred choice if the site admin wants to reduce the amount of work involved in managing multiple wikis, or cut down on inode usage. For this reason, some wiki hosting services opt for the wiki family model.
The best known implementation of a wiki family is the wiki farm, although other approaches are possible. A list of known wiki farms is available on WikiApiary .
下面是设置MediaWiki的各個指示,說明如何托管多个wiki。
方法
维基农场
以下步骤是在相同版本的MediaWiki中运行多个wiki
- 正常安装第一个wiki。 更多资料,請看手册:安装指南 。
- 启用您的Web服务器用来和所有wiki共享您的MediaWiki安装。 For multiple (sub)domains, have your web server accept connections from all the relevant domains. 对于多个子目录,你可以使用重写规则、别名或符号链接。
- 在
LocalSettings.php
顶部添加如下代码,解析当前wiki。 需要注意的是,如果--wiki
的参数包含一个连字符,参数将在连字符处被拆分,得到的两个值将分别赋值给MW_DB
和MW_PREFIX
。 对于按域名分类的wiki:$wikis = [ 'example.org' => 'examplewiki', 'one.example.org' => 'onewiki', ]; if ( defined( 'MW_DB' ) ) { // 自动引用传给维护脚本的--wiki选项 $wikiID = MW_DB; } else { // 使用MW_DB环境变量或映射域名 $wikiID = $_SERVER['MW_DB'] ?? $wikis[ $_SERVER['SERVER_NAME'] ?? '' ] ?? null; if ( !$wikiID ) { die( 'Unknown wiki.' ); } } $wgLocalDatabases = $wgConf->wikis = array_values( $wikis ); $wgDBname = $wikiID; $wgDBuser = 'mediawiki';
- 設定所有wiki必要的不同的设置。例如:
$wgCacheDirectory = "/tmp/mediawiki_cache/$wgDBname"; $wgUploadDirectory = "$IP/images/$wgDBname"; $wgUploadPath = "/w/images/$wgDBname";
- 設定前一個维基的改写。 这应该包括至少
$wgServer
和$wgArticlePath
。这可以从单独的文件完成,例如:$wgConf->settings = [ 'wgServer' => [ 'examplewiki' => 'https://example.org', 'onewiki' => 'https://one.example.org', ], 'wgArticlePath' => [ 'default' => '/wiki', ], 'wgSitename' => [ 'default' => 'Example', 'onewiki' => 'One', ], 'wgLogo' => [ 'default' => '/images/examplewiki/Example_logo.png', ], 'wgLanguageCode' => [ 'default' => 'en', 'onewiki' => 'pt', ], ]; extract( $wgConf->getAll( $wgDBname ) );
# LocalSettings.php $wgConf->settings = require __DIR__ . '/LocalSettings_overrides.php'; # LocalSettings_overrides.php <?php return [ 'wgServer' => .., .., ];
To add a new wiki to the family:
- Create its database and add its settings first , with
--wiki=mywiki
if you runinstall.php
from the command line. - Run
php maintenance/update.php --wiki=mywiki
.
单独的设置文件
这种方法是用于操作完全独立的wiki們,但仍共享相同的Web服务器和MediaWiki源代码。
- 像往常一样,通过Web或CLI安装程序安装第一个wiki,这会设置您的数据库并生成一个LocalSettings.php 文件。
- 安装后,重命名生成的
LocalSettings.php
文件以包含wiki ID(例如数据库名称),如LocalSettings_mywiki.php
。 - 对要创建的每个wiki重复上述步骤1和2。
- 创建一个新的
LocalSettings.php
文件,该文件将加载正确的文件。 与上面的维基农场示例一样,包含连字符的--wiki
参数将被分割成两个值,分别分配给MW_DB
和MW_PREFIX
。如果你的wiki在同一个域上,但路径不同(例如:<?php $wikis = [ 'example.org' => 'examplewiki', 'one.example.org' => 'onewiki', ]; if ( defined( 'MW_DB' ) ) { // 自动从--wiki选项设置为维护脚本 $wikiID = MW_DB; } else { // 使用MW_DB环境变量或映射域名 $wikiID = $_SERVER['MW_DB'] ?? $wikis[ $_SERVER['SERVER_NAME'] ?? '' ] ?? null; } if ( $wikiID ) { require_once "LocalSettings_$wikiID.php"; } else { die( 'Unknown wiki.' ); } // 添加需要应用于此行以下所有wiki的所有设置 // -------
example.org/wiki1
,example.org/wiki2
等),你可以这样操作:<?php $wikis = [ '/example' => 'examplewiki', '/w_example' => 'examplewiki', '/one' => 'onewiki', '/w_one' => 'onewiki', ]; if ( defined( 'MW_DB' ) ) { // 自动从--wiki选项设置为维护脚本 $wikiID = MW_DB; } else { $path = explode( '/', $_SERVER['REQUEST_URI'] ?? '', 3 )[1] ?? ''; $wikiID = $_SERVER['MW_DB'] ?? $wikis[ $path ] ?? null; } if ( $wikiID ) { require_once "LocalSettings_$wikiID.php"; } else { die( 'Unknown wiki.' ); }
Drupal样式的网站
这种设置的优点是对用户完全透明,图像目录也相当安全。
- 创建一个包含所有 MediaWiki 文件的基本目录。示例:
mkdir /home/web/mediawiki
. - 如同往常一样,将 MediaWiki 和其他工具安装到一个版本说明子目录(示例:,
/home/web/mediawiki/mediawiki-1.10.0
)中。 - 将版本声明目录链接到代码目录。 示例:
ln -s /home/web/mediawiki/mediawiki-1.10.0 /home/web/mediawiki/code
- 创建一个 sites 目录,以容納我们的图片和设置:
mkdir /home/web/mediawiki/sites
- 从/code目录中正常设置维基。
- 安装成功后,将移动
LocalSettings.php
到网站目录中,在检查网站时就会匹配。 例如,要捕获http://example.com/mywiki,可以创建目录example.com.mywiki。 示例:mkdir /home/web/mediawiki/sites/example.com.mywiki
有关详细信息,请参阅Drupal的settings.php
文件。 - 如果打算使用媒体文件,请在网站目录中创建一个images目录。 示例:
mkdir /home/web/mediawiki/sites/example.com.wiki/images
根据需要使其可写。 - 将Drupal样式
LocalSettings.php
文件放到主目录下:cp DrupalLocalSettings.php /home/web/mediawiki/code/LocalSettings.php
- 修改每个子网站的
LocalSettings.php
,使其指向正确的地方:- 首先注释掉与
$IP
有关的代码(1.15.3中的第16-20行),因为它会被index.php
设置为 code 目录。 - 接下来插入以下两行,以确保可以访问图像文件,"'示例'":
$wgUploadDirectory = "/home/web/mediawiki/sites/wiki.example.com/images";
和$wgUploadPath = "/images";
。 这些变量需要放在调用DefaultSettings.php
后(1.15.3中的第25行),否则将被重置。 - 根据需要进一步修改。
- 首先注释掉与
- 准备 Apache 2 安装。网站示例: wiki.example.com
- 如果需要,创建指向code目录的链接 示例:
ln -s /home/web/mediawiki/code /home/web/wiki.example.com
- 创建适当的虚拟主机配置:
<VirtualHost *:80> ServerAdmin me@example.com DocumentRoot /home/web/wiki.example.com ServerName wiki.example.com CustomLog /var/log/apache2/wiki.mysite.log common # 可访问网站的别名 Alias /mediawiki/code /home/web/mediawiki/code # 为维基提供别名,使图像正常工作 Alias /images /home/web/mediawiki/sites/wiki.example.com/images # 如果您想用密码保护您的网站 # <Directory /home/web/wiki.example.com> # AuthType Basic # AuthName "我的受保护的维基" # AuthUserFile /etc/apache2/htpasswd/users-mywiki # require valid-user # </Directory> </VirtualHost>
- 如果需要,创建指向code目录的链接 示例:
- 11. 如果在本地设置网站,请用网站名称更新
hosts
文件。 现在网站应该可以正常运行了。
就我而言,我制作了另一份代码副本,用于安装和更新我的LocalSettings.php
和数据库。
注意从命令行运行维护脚本时,配套 Drupal 代码中的 $_SERVER['HTTP_HOST']
未定义,因此此解决方案不能够在不做修改的情况下使用维护脚本。
Ubuntu 的 Drupal 样式设置方法
在 Ubuntu/Kubuntu 上使用多个维基和多个(或嵌套的)子维基的简化方法,大致基于上述方法,可在以下网址找到:
维护脚本如何处理wiki农场
MediaWiki维护脚本(例如update.php)接受一个--wiki
参数,该参数将作为常数MW_DB
、MW_PREFIX
、和MW_WIKI_NAME
传递给你的LocalSettings.php 文件。
--wiki
参数的全部值是MW_WIKI_NAME
的值。
--wiki
参数中有一个破折号,那么破折号之前的部分被分配给MW_DB
,破折号之后的部分被分配给MW_PREFIX
。本表展示了这如何工作:
--wiki |
MW_WIKI_NAME |
MW_DB |
MW_PREFIX
|
---|---|---|---|
enwiki | enwiki | enwiki | empty |
enwiki-one | enwiki-one | enwiki | one |
enwiki-one-two | enwiki-one-two | enwiki | one-two |
由于网络请求没有--wiki
参数,因此必须以不同的方式处理。
通常情况下,域名和/或URL路径被用来选择一个wiki。
维基之间共享的技巧
您可以使用$wgForeignFileRepos
在维基中共享上传的媒体文件。这与维基百科的维基共享资源类似。
例如:
- en.example.org - 英语
- fr.example.org - 法语
- de.example.org - 德语
- pool.example.org - 所有wiki的共享媒体文件。
commons
表示维基共享资源。
还要避免使用名称“media”(例如media.example.org),因为这可能会导致您的跨维基与用于访问本地媒体文件的内部命名空间Media:
(例如[[media:File.png]])之间的冲突。
共享数据表
请考虑对用户帐户使用共享数据库。 有关设置共享数据库表的说明,请参阅 手册:共享数据库 。
跨Wiki
您可以使用Extension:Interwiki 在所有wiki之间创建跨维基链接。 如果wiki是语言编辑版本,建议在确切的语言代码之后命名跨维基前缀。例如,“de”代表您农场中的德语wiki。 这样,您可以使用语言链接连接有关同一主题的页面。
在英文“主页”上添加[[de:Hauptseite]]将在语言侧边栏中创建一个链接“Deutsch”。 更多信息请参见Help:Interwiki linking 。
如果你有一个用于文件的中央wiki,也要为此创建一个前缀。
例如,pool
到 https://pool.example.org/wiki/$1,并启用“转发”复选框以将其识别为同一系列中的本地 wiki。
上传
首先确认 pool-wiki 文件夹的“images”权限是可写的。
将language-wikis的"Upload file"链接更改为指向 poolwiki 的上传站点很重要。 打开每种语言维基的“LocalSettings.php”,然后添加:
$wgUploadNavigationUrl = "https://pool.example.org/index.php/Special:Upload";
在1.17中,您还必须设置$wgUploadMissingFileUrl
才能重定向到红色链接上的pool-wiki。
$wgUploadMissingFileUrl= "https://pool.example.org/index.php/Special:Upload";
如果想要只允许pool wiki上传,使用以下内容:
if ( $wgDBname === 'pool' ) {
$wgEnableUploads = true;
} else {
$wgEnableUploads = false;
}
共享文件
要在语言维基中使用poolwiki的文件,请为每个语言wiki打开“LocalSettings.php”并添加:
$wgUseSharedUploads = true;
$wgSharedUploadPath = 'https://pool.example.org/images';
$wgSharedUploadDirectory = '/(LOCALPATH)/POOL-FOLDER/images/';
$wgHashedSharedUploadDirectory = true;
现在,您可以将池的文件与语言维基中的文件(例如[[File:MyLogo.png]])集成。
图像描述
在每个languagewiki中打开(以管理员身份)消息 MediaWiki:Sharedupload-desc-here。
将文本更改为:
该文件存储在数据池中(data-pool)。 有关信息和说明,请访问[[:pool:File:{{PAGENAME}}|描述]]。
(请注意行首的“:”,它阻止“pool”包含在页面左侧的跨维基列表中。)
如果你想输出存储在PoolWiki中的媒体描述,请添加到语言维基的“LocalSettings.php”中:
$wgFetchCommonsDescriptions = true;
$wgSharedUploadDBname = 'pool'; # DB-Name of PoolWiki
$wgSharedUploadDBprefix = 'wiki_'; # Table name prefix for PoolWiki
$wgRepositoryBaseUrl = "https://pool.example.org/index.php/Image:";
wiki農場擴充功能
有几个 MediaWiki 扩展试图通过仅使用一个代码库来简化多个 wiki 的托管,但目前只有一个值得参考:
- Extension:MediaWikiFarm - beta.
- Extension:SkinCustomiser : 用于侧边栏 的本地化问题并分别自定义相关参数
MediaWiki:Cologneblue.css
,MediaWiki:Modern.css
,MediaWiki:Monobook.css
,MediaWiki:Vector.css
,MediaWiki:Mobile.css
,MediaWiki:Common.css
的皮肤。
其它说明
- Extension:中央认证
- 手册:InitialiseSettings.php
- 手册:CommonSettings.php
- 手册:$wgConf
- 手册:中心ID — 用户帐户可以有一个额外的'central'标识符的机制。