0

0

MediaWiki 共享数据库表配置与升级指南

花韻仙語

花韻仙語

发布时间:2025-09-27 11:51:01

|

770人浏览过

|

来源于php中文网

原创

MediaWiki 共享数据库表配置与升级指南

本教程详细阐述了在MediaWiki多站点环境下,如何正确配置共享数据库表($wgSharedTables),以实现用户、用户组等数据的共享。文章不仅纠正了常见的配置错误,还特别强调了在MediaWiki 1.21及更高版本升级过程中,为确保共享表正确处理,需要临时清空$wgSharedTables配置的必要步骤和方法,确保数据库初始化与升级的顺利进行。

MediaWiki 共享数据库表配置详解

在构建mediawiki家族(即多个wiki站点共享用户账户等数据)时,共享数据库是一个核心概念。它允许不同的wiki实例访问同一个用户表、用户组表等,从而提供统一的用户体验。mediawiki通过几个关键的配置变量来实现这一功能:$wgshareddb、$wgsharedtables 和 $wgsharedprefix。

  • $wgSharedDB: 指定共享数据库的名称。所有共享的表都将存储在这个数据库中。
  • $wgSharedTables: 一个数组,列出所有需要共享的表名。例如,user、user_groups、actor 等。
  • $wgSharedPrefix: 共享表中使用的前缀。如果共享表没有特定的前缀,则可以将其设置为空字符串。

正确配置 $wgSharedTables

许多用户在配置 $wgSharedTables 时常犯一个错误,即将一个包含多个表名的数组作为单个元素添加到 $wgSharedTables 数组中,导致配置未能正确识别各个共享表。例如,以下配置是不正确的:

// 错误示例:将一个数组作为单个元素添加到 $wgSharedTables 中
$wgSharedTables[] = array('user','user_groups','actor');

这种写法会使得 $wgSharedTables 变成一个包含一个子数组的数组,而不是一个包含多个表名字符串的数组。正确的做法是确保 $wgSharedTables 直接包含表名字符串。以下是两种推荐的正确配置方式:

  1. 使用 array_merge() 合并表名: 这种方法特别适用于在已有 $wgSharedTables 配置的基础上添加新的共享表。

    // 正确示例1:使用 array_merge()
    $wgSharedDB = 'wiki_shared';
    $wgSharedTables = array_merge( $wgSharedTables, ['user','user_groups','actor'] );
    $wgSharedPrefix = '';
  2. 逐个添加表名: 如果 $wgSharedTables 尚未初始化,或者你希望清晰地列出每个共享表,可以逐个添加。

    // 正确示例2:逐个添加表名
    $wgSharedDB = 'wiki_shared';
    $wgSharedTables[] = 'user';
    $wgSharedTables[] = 'user_groups';
    $wgSharedTables[] = 'actor';
    $wgSharedPrefix = '';

    请确保这些配置行放置在 LocalSettings.php 文件中适当的位置。

MediaWiki 升级时的特殊处理:清空 $wgSharedTables

自 MediaWiki 1.21 版本起,在通过 Web 安装器进行升级时,有一个重要的注意事项:必须临时清空 $wgSharedTables 配置。如果不清空,Web 安装器将不会触及任何共享表(无论是带有 $wgSharedPrefix 的表还是带有 $wgDBprefix 的表),这可能导致升级失败或共享表未被正确更新。

为什么需要清空?

Web 安装器在执行升级操作时,需要确保所有相关的数据库表都能够被检查和更新。当 $wgSharedTables 被配置时,安装器会假设这些表已经存在并被正确管理,从而可能跳过对它们的检查和创建/更新操作。临时清空此配置,可以强制安装器将所有表(包括那些最终会共享的表)视为当前Wiki实例的本地表进行处理,确保它们被正确地创建或升级。

Ai好记
Ai好记

强大的AI音视频转录与总结工具

下载

如何临时清空 $wgSharedTables?

清空 $wgSharedTables 的方法非常简单,只需将其设置为空数组即可:

// 在升级期间,临时清空 $wgSharedTables
$wgSharedTables = [];

操作步骤:

  1. 备份: 在进行任何升级操作前,务必完整备份你的MediaWiki文件和数据库。
  2. 修改 LocalSettings.php: 在运行升级脚本或访问 Web 安装器之前,找到 LocalSettings.php 文件中关于 $wgSharedTables 的配置行,并将其修改为 $wgSharedTables = [];。
  3. 执行升级: 运行 MediaWiki 的升级脚本 (php maintenance/update.php) 或通过浏览器访问 Web 安装器完成升级过程。
  4. 恢复配置: 升级完成后,将 LocalSettings.php 中 $wgSharedTables 的配置恢复到其原始的、正确的共享表列表

重要提示: 这种清空操作是临时性的,仅在升级过程中需要。升级完成后,必须恢复正确的 $wgSharedTables 配置,以确保共享功能正常工作。

总结

正确配置 MediaWiki 共享数据库表是构建高效多站点环境的关键。请务必使用 array_merge() 或逐个添加的方式正确定义 $wgSharedTables。同时,在进行 MediaWiki 1.21 及更高版本的升级时,切记要临时清空 $wgSharedTables 配置,以确保所有数据库表都能被安装器正确处理,避免升级失败。遵循这些步骤将有助于你顺利地管理 MediaWiki 共享数据库环境。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2707

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1668

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1527

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

974

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1444

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1235

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1529

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1307

2023.11.13

云朵浏览器入口合集
云朵浏览器入口合集

本专题整合了云朵浏览器入口合集,阅读专题下面的文章了解更多详细地址。

20

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 9万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号