MediaWiki

来自 Arch Linux 中文维基

MediaWiki是一个免费、开源的维基软件,用 PHP 写成;原本是为维基百科开发的。它也给 archwiki 提供了帮助。(详情查看 Special:VersionGitHub repository)。

安装[编辑 | 编辑源代码]

为了运行 MediaWiki 你需要三个组件:

如果要在 XAMPP 上安装 MediaWiki,参见 mw:Manual:Installing MediaWiki on XAMPP

配置[编辑 | 编辑源代码]

实现一个可用的 MediaWiki 配置的步骤包括编辑 PHP 设置和添加 MediaWiki 配置片段。

PHP[编辑 | 编辑源代码]

MediaWiki 需要 iconvintl 插件,所以需要把 /etc/php/php.ini 里面的 extension=iconvextension=intl 取消注释。

可选插件:

  • 为了渲染缩略图,安装 ImageMagick 或者 php-gd(二选一)。如果安装的是后者,需要取消注释 extension=gd

启用你的数据库管理系统的 API:

其次,调整会话处理方式,否则可能会在寻找 session.save_path 路径时遇到严重错误(PHP Fatal error: session_start(): Failed to initialize storage module[...])。/var/lib/php/sessions/tmp/ 路径是个不错的选择。

/etc/php/php.ini
session.save_path = "/var/lib/php/sessions"

如果那个目录不存在,你要手动创建它,并更改权限:

# mkdir -p /var/lib/php/sessions/
# chown http:http /var/lib/php/sessions
# chmod go-rwx /var/lib/php/sessions

如果你使用了 PHP's open_basedir 并想允许文件上传,你需要把 /var/lib/mediawiki/ 添加到里面去 (mediawikiimages/ 创建了指向 /var/lib/mediawiki/ 的符号链接)。

网站服务器[编辑 | 编辑源代码]

Apache[编辑 | 编辑源代码]

按照 Apache HTTP Server#PHP 配置 PHP。

复制 /etc/webapps/mediawiki/apache.example.conf/etc/httpd/conf/extra/mediawiki.conf 并按需要修改它。 添加下面这一行到 /etc/httpd/conf/httpd.conf:

Include conf/extra/mediawiki.conf

重启 httpd.service

注意: 默认示例文件 /etc/webapps/mediawiki/apache.example.conf 会覆盖 PHP 的 open_basedir 设置,可能会和其他页面产生冲突。 可以通过把以 php_admin_value 开头的行移到 <Directory> 标签之间来避免这个问题。而如果你运行了多个依赖同一个 server 的应用,你可以把这个值添加到 /etc/php/php.ini 里的 open_basedir 里,而不仅仅是放在 /etc/httpd/conf/extra/mediawiki.conf 里。

Nginx[编辑 | 编辑源代码]

对于 Nginx,请创建这样的一个文件:

/etc/nginx/mediawiki.conf
location / {
   index index.php;
   try_files $uri $uri/ @mediawiki;
}
location @mediawiki {
   rewrite ^/(.*)$ /index.php;
}
location ~ \.php?$ {
   include /etc/nginx/fastcgi_params;
   fastcgi_pass unix:/var/run/php-fpm/php-fpm.sock;
   fastcgi_index index.php;
   fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
   try_files $uri @mediawiki;
}
location ~* \.(js|css|png|jpg|jpeg|gif|ico|svg)$ {
   try_files $uri /index.php;
   expires max;
   log_not_found off;
}
# Restrictions based on the .htaccess files
location ~ ^/(cache|includes|maintenance|languages|serialized|tests|images/deleted)/ {
   deny all;
}
location ~ ^/(bin|docs|extensions|includes|maintenance|mw-config|resources|serialized|tests)/ {
   internal;
}
location ^~ /images/ {
   try_files $uri /index.php;
}
location ~ /\. {
   access_log off;
   log_not_found off; 
   deny all;
}
location /rest.php {
   try_files $uri $uri/ /rest.php?$args;
}

请确保已经安装了 php-fpm启动php-fpm.service

/etc/nginx/nginx.conf添加一个 server 块,类似这样的:

/etc/nginx/nginx.conf
server {
  listen 80;
  server_name mediawiki;
  root /usr/share/webapps/mediawiki;
  index index.php;
  charset utf-8;
# For correct file uploads
  client_max_body_size    100m; # Equal or more than upload_max_filesize in /etc/php/php.ini
  client_body_timeout     60;
  include mediawiki.conf;

}

最后,restart nginx.servicephp-fpm.service

Lighttpd[编辑 | 编辑源代码]

应当先安装并配置好 Lighttpd。lighttpd 的 server.modules array 中需要“mod_alias“和“mod_rewrite“。将以下内容添加至 lighttpd 的配置文件:

/etc/lighttpd/lighttpd.conf
alias.url += ("/mediawiki" => "/usr/share/webapps/mediawiki/")
url.rewrite-once += (
                "^/mediawiki/wiki/upload/(.+)" => "/mediawiki/wiki/upload/$1",
                "^/mediawiki/wiki/$" => "/mediawiki/index.php",
                "^/mediawiki/wiki/([^?]*)(?:\?(.*))?" => "/mediawiki/index.php?title=$1&$2"
)

然后,重启 lighttpd.service 守护进程。

数据库[编辑 | 编辑源代码]

按照你所需要的数据库管理系统(DBMS)的文章配置数据库服务器:MariaDBPostgreSQLSQLiteMySQL

如果数据库密码不为空,MediaWiki会自动创建数据库(设置 MariaDB 密码的方法在 MariaDB#Reset the root password) 。否则你就需要手动创建数据库,详情参考: upstream instructions

LocalSettings.php[编辑 | 编辑源代码]

在浏览器里打开 wiki 的 URL (通常是 http://your_server/mediawiki/index.php) 并进行初始化配置。参考upstream instructions的步骤。

生成的 LocalSettings.php 文件是用来下载的,保存它到 /usr/share/webapps/mediawiki/LocalSettings.php

自 1.38.0 版本起,/usr/share/webapps/mediawiki/LocalSettings.php 内已包含一个符号链接。

警告: LocalSettings.php 包含了数据库连接设置(例如用户名和密码)和网络更新密码。请确保仅 root 和 http 用户可以访问 /etc/webapps/mediawiki/LocalSettings.php 文件:
# chown root:http /etc/webapps/mediawiki/LocalSettings.php
# chmod 640 /etc/webapps/mediawiki/LocalSettings.php

该文件定义了所部署维基的特定设置。升级 mediawiki 软件包不会替换此文件。

LDAP Auth[编辑 | 编辑源代码]

使用 PluggableAuthLDAP Stack。请留意“Compatibility Matrix”章节。目前 LDAP 仅能与 PluggableAuth-5.7 一同使用。

请安装并在配置中添加 ldap stack 扩展和 PluggableAuth:

接下来请设置至少 3 个变量:

  • $LDAPProviderDomainConfigProvider —— 整个 ldap 配置(可以是 json 文件)
  • $wgPluggableAuth_Config —— auth 插件列表
$wgPluggableAuth_Config = array(
       array('plugin' => 'LDAPAuthentication2'),
       array('plugin' => 'LDAPAuthorization'),
);
  • 以及 $LDAPProviderDefaultDomain

配置完成后请运行 php maintenance/update.php

升级[编辑 | 编辑源代码]

参考 mw:Manual:Upgrading, 不要忘记运行:

# cd /usr/share/webapps/mediawiki
# php maintenance/update.php

提示和技巧[编辑 | 编辑源代码]

Unicode[编辑 | 编辑源代码]

请确保PHP, Apache HTTP ServerMariaDB都用的是 UTF-8 编码。否则可能遇到因为编码不匹配导致的奇怪bug。

可视化编辑器[编辑 | 编辑源代码]

VisualEditor(可视化编辑器)扩展为 MediaWiki 提供了一个富文本编辑器。请参照 mw:Extension:VisualEditor 安装。