Recent from talks
Nothing was collected or created yet.
MediaWiki
View on Wikipedia
| MediaWiki | |
|---|---|
Screenshot The Main Page of the English Wikipedia running an alpha version of MediaWiki 1.40 | |
| Original authors | |
| Developer | Wikimedia Foundation |
| Initial release | January 25, 2002 |
| Stable release | 1.44.2[1] |
| Repository | |
| Written in | PHP[2] |
| Operating system | Windows, macOS, Linux, FreeBSD, OpenBSD, Solaris |
| Size | 79.05 MiB (compressed) |
| Available in | 459[3] languages |
| Type | Wiki software |
| License | GPLv2+[4] |
| Website | www |
MediaWiki is a free and open-source wiki software originally developed by Magnus Manske and released for use on Wikipedia on January 25, 2002, and further enhanced by Lee Daniel Crocker,[5][6] after which development has been coordinated by the Wikimedia Foundation. It powers several wiki hosting websites across the Internet, as well as most websites hosted by the Wikimedia Foundation including Wikipedia, Wiktionary, Wikimedia Commons, Wikiquote, Meta-Wiki and Wikidata, which define a large part of the set requirements for the software.[7] Besides its usage on Wikimedia sites, MediaWiki has been used as a knowledge management and content management system on websites such as Fandom, wikiHow and major internal installations like Intellipedia and Diplopedia.
MediaWiki is written in the PHP programming language and stores all text content into a database. The software is optimized to efficiently handle large projects, which can have terabytes of content and hundreds of thousands of views per second.[7][8] Because Wikipedia is one of the world's largest and most visited websites, achieving scalability through multiple layers of caching and database replication has been a major concern for developers. Another major aspect of MediaWiki is its internationalization; its interface is available in more than 400 languages.[9] The software has hundreds of configuration settings[10] and more than 1,000 extensions available for enabling various features to be added or changed.[11]
Key features
[edit]MediaWiki provides a rich core feature set and a mechanism to attach extensions to provide additional functionality.
Internationalization and localization
[edit]Due to the strong emphasis on multilingualism in the Wikimedia projects, internationalization and localization has received significant attention by developers. The user interface has been fully or partially translated into more than 400 languages on translatewiki.net,[9] and can be further customized by site administrators (the entire interface is editable through the wiki).
Several extensions, most notably those collected in the MediaWiki Language Extension Bundle, are designed to further enhance the multilingualism and internationalization of MediaWiki.
Installation and configuration
[edit]Installation of MediaWiki requires that the user have administrative privileges on a server running both PHP and a compatible type of SQL database. Some users find that setting up a virtual host is helpful if the majority of one's site runs under a framework (such as Zope or Ruby on Rails) that is largely incompatible with MediaWiki.[12] Cloud hosting can eliminate the need to deploy a new server.[13]
An installation PHP script is accessed via a web browser to initialize the wiki's settings. It prompts the user for a minimal set of required parameters, leaving further changes, such as enabling uploads,[14] adding a site logo,[15] and installing extensions, to be made by modifying configuration settings contained in a file called LocalSettings.php.[16] Some aspects of MediaWiki can be configured through special pages or by editing certain pages; for instance, abuse filters can be configured through a special page,[17] and certain gadgets can be added by creating JavaScript pages in the MediaWiki namespace.[18] The MediaWiki community publishes a comprehensive installation guide.[19]
Markup
[edit]One of the earliest differences between MediaWiki (and its predecessor, UseModWiki) and other wiki engines was the use of "free links" instead of CamelCase. When MediaWiki was created, it was typical for wikis to require text like "WorldWideWeb" to create a link to a page about the World Wide Web; links in MediaWiki, on the other hand, are created by surrounding words with double square brackets, and any spaces between them are left intact, e.g. [[World Wide Web]]. This change was logical for the purpose of creating an encyclopedia, where accuracy in titles is important.
MediaWiki uses an extensible[20] lightweight wiki markup designed to be easier to use and learn than HTML. Tools exist for converting content such as tables between MediaWiki markup and HTML.[21] Efforts have been made to create a MediaWiki markup spec, but a consensus seems to have been reached that Wikicode requires context-sensitive grammar rules.[22][23] The following side-by-side comparison illustrates the differences between wiki markup and HTML:
| MediaWiki syntax (the "behind the scenes" code used to add formatting to text) |
HTML equivalent (another type of "behind the scenes" code used to add formatting to text) |
Rendered output (seen onscreen by a site viewer) |
|---|---|---|
====A dialogue====
"Take some more [[tea]]," the March Hare said to Alice, very earnestly.
"I've had nothing yet," Alice replied in an offended tone: "so I can't take more."
"You mean you can't take ''less''," said the Hatter: "it's '''very''' easy to take ''more'' than nothing."
|
<h4>A dialogue</h4>
<p>"Take some more <a href="/wiki/Tea" title="Tea">tea</a>," the March Hare said to Alice, very earnestly.</p> <br>
<p>"I've had nothing yet," Alice replied in an offended tone: "so I can't take more."</p> <br>
<p>"You mean you can't take <i>less</i>," said the Hatter: "it's <b>very</b> easy to take <i>more</i> than nothing."</p>
|
A dialogue
"Take some more tea," the March Hare said to Alice, very earnestly. "I've had nothing yet," Alice replied in an offended tone: "so I can't take more." "You mean you can't take less," said the Hatter: "it's very easy to take more than nothing." |
(Quotation above from Alice's Adventures in Wonderland by Lewis Carroll)
Editing interface
[edit]
MediaWiki's default page-editing tools have been described as somewhat challenging to learn.[24] A survey of students assigned to use a MediaWiki-based wiki found that when they were asked an open question about main problems with the wiki, 24% cited technical problems with formatting, e.g. "Couldn't figure out how to get an image in. Can't figure out how to show a link with words; it inserts a number."[25]
To make editing long pages easier, MediaWiki allows the editing of a subsection of a page (as identified by its header). A registered user can also indicate whether or not an edit is minor. Correcting spelling, grammar or punctuation are examples of minor edits, whereas adding paragraphs of new text is an example of a non-minor edit.
Sometimes while one user is editing, a second user saves an edit to the same part of the page. Then, when the first user attempts to save the page, an edit conflict occurs. The second user is then given an opportunity to merge their content into the page as it now exists following the first user's page save.
MediaWiki's user interface has been localized in many different languages. A language for the wiki content itself can also be set, to be sent in the "Content-Language" HTTP header and "lang" HTML attribute.
VisualEditor has its own integrated wikitext editing interface known as 2017 wikitext editor, the older editing interface is known as 2010 wikitext editor.
Application programming interface
[edit]MediaWiki has an extensible web API (application programming interface) that provides direct, high-level access to the data contained in the MediaWiki databases. Client programs can use the API to log in, get data, and post changes. The API supports thin web-based JavaScript clients and end-user applications (such as vandal-fighting tools). The API can be accessed by the backend of another web site.[26] An extensive Python bot library, Pywikibot,[27] and a popular semi-automated tool called AutoWikiBrowser, also interface with the API.[28] The API is accessed via URLs such as https://en.wikipedia.org/w/api.php?action=query&list=recentchanges. In this case, the query would be asking Wikipedia for information relating to the last 10 edits to the site. One of the perceived advantages of the API is its language independence; it listens for HTTP connections from clients and can send a response in a variety of formats, such as XML, serialized PHP, or JSON.[29] Client code has been developed to provide layers of abstraction to the API.[30]
Tracking edits
[edit]Among the features of MediaWiki to assist in tracking edits is a Recent Changes feature that provides a list of recent edits to the wiki. This list contains basic information about those edits such as the editing user, the edit summary, the page edited, as well as any tags (e.g. "possible vandalism")[31] added by customizable abuse filters and other extensions to aid in combating unhelpful edits.[32] On more active wikis, so many edits occur that it is hard to track Recent Changes manually. Anti-vandal software, including user-assisted tools,[33] is sometimes employed on such wikis to process Recent Changes items. Server load can be reduced by sending a continuous feed of Recent Changes to an IRC channel that these tools can monitor, eliminating their need to send requests for a refreshed Recent Changes feed to the API.[34][35]
Another important tool is watchlisting. Each logged-in user has a watchlist to which the user can add whatever pages he or she wishes. When an edit is made to one of those pages, a summary of that edit appears on the watchlist the next time it is refreshed.[36] As with the recent changes page, recent edits that appear on the watchlist contain clickable links for easy review of the article history and specific changes made.
There is also the capability to review all edits made by any particular user. In this way, if an edit is identified as problematic, it is possible to check the user's other edits for issues.
MediaWiki allows one to link to specific versions of articles. This has been useful to the scientific community, in that expert peer reviewers could analyse articles, improve them and provide links to the trusted version of that article.[37]
Navigation
[edit]Wikilinks
[edit]Navigation through the wiki is largely through internal wikilinks. MediaWiki's wikilinks implement page existence detection, in which a link is colored blue if the target page exists on the local wiki and red if it does not. If a user clicks on a red link, they are prompted to create an article with that title. Page existence detection makes it practical for users to create "wikified" articles—that is, articles containing links to other pertinent subjects—without those other articles being yet in existence.
Interwiki links
[edit]Interwiki links function much the same way as namespaces. A set of interwiki prefixes can be configured to cause, for instance, a page title of wikiquote:Jimbo Wales to direct the user to the Jimbo Wales article on Wikiquote.[38] Unlike internal wikilinks, interwiki links lack page existence detection functionality, and accordingly there is no way to tell whether a blue interwiki link is broken or not.
Interlanguage links
[edit]
Interlanguage links are the small navigation links that show up in the sidebar in most MediaWiki skins that connect an article with related articles in other languages within the same Wiki family. This can provide language-specific communities connected by a larger context, with all wikis on the same server or each on its own server.[39]
Previously, Wikipedia used interlanguage links to link an article to other articles on the same topic in other editions of Wikipedia. This was superseded by the launch of Wikidata.[40]
Content organization
[edit]Page tabs and associated pages
[edit]
Page tabs are displayed at the top of pages. These tabs allow users to perform actions or view pages that are related to the current page. The available default actions include viewing, editing, and discussing the current page. The specific tabs displayed depend on whether the user is logged into the wiki and whether the user has sysop privileges on the wiki. For instance, the ability to move a page or add it to one's watchlist is usually restricted to logged-in users. The site administrator can add or remove tabs by using JavaScript or installing extensions.[41]
Each page has an associated history page from which the user can access every version of the page that has ever existed and generate diffs between two versions of his choice. Users' contributions are displayed not only here, but also via a "user contributions" option on a sidebar. In a 2004 article, Carl Challborn and Teresa Reimann noted that "While this feature may be a slight deviation from the collaborative, 'ego-less' spirit of wiki purists, it can be very useful for educators who need to assess the contribution and participation of individual student users."[42]
Namespaces
[edit]MediaWiki provides many features beyond hyperlinks for structuring content. One of the earliest such features is namespaces. One of Wikipedia's earliest problems had been the separation of encyclopedic content from pages pertaining to maintenance and communal discussion, as well as personal pages about encyclopedia editors. Namespaces are prefixes before a page title (such as "User:" or "Talk:") that serve as descriptors for the page's purpose and allow multiple pages with different functions to exist under the same title. For instance, a page titled "[[The Terminator]]", in the default namespace, could describe the 1984 movie starring Arnold Schwarzenegger, while a page titled "[[User:The Terminator]]" could be a profile describing a user who chooses this name as a pseudonym. More commonly, each namespace has an associated "Talk:" namespace, which can be used to discuss its contents, such as "User talk:" or "Template talk:". The purpose of having discussion pages is to allow content to be separated from discussion surrounding the content.[43][44]
Namespaces can be viewed as folders that separate different basic types of information or functionality. Custom namespaces can be added by the site administrators. There are 16 namespaces by default for content, with 2 "pseudo-namespaces" used for dynamically generated "Special:" pages and links to media files. Each namespace on MediaWiki is numbered: content page namespaces have even numbers and their associated talk page namespaces have odd numbers.[45]
Category tags
[edit]Users can create new categories and add pages and files to those categories by appending one or more category tags to the content text. Adding these tags creates links at the bottom of the page that take the reader to the list of all pages in that category, making it easy to browse related articles.[46] The use of categorization to organize content has been described as a combination of:
- Collaborative tagging systems like del.icio.us and
- Hierarchical classifications like the Dewey Decimal Classification.[47]
Subpages
[edit]In addition to namespaces, content can be ordered using subpages. This simple feature provides automatic breadcrumbs of the pattern [[Page title/Subpage title]] from the page after the slash (in this case, "Subpage title") to the page before the slash (in this case, "Page title").
Customization
[edit]
If the feature is enabled, users can customize their stylesheets and configure client-side JavaScript to be executed with every pageview. On Wikipedia, this has led to a large number of additional tools and helpers developed through the wiki and shared among users. For instance, navigation popups is a custom JavaScript tool that shows previews of articles when the user hovers over links and also provides shortcuts for common maintenance tasks.[48]

The entire MediaWiki user interface can be edited through the wiki itself by users with the necessary permissions (typically called "administrators"). This is done through a special namespace with the prefix "MediaWiki:", where each page title identifies a particular user interface message. Using an extension,[49] it is also possible for a user to create personal scripts, and to choose whether certain sitewide scripts should apply to them by toggling the appropriate options in the user preferences page.
Templates
[edit]The "MediaWiki:" namespace was originally also used for creating custom text blocks that could then be dynamically loaded into other pages using a special syntax. This content was later moved into its own namespace, "Template:".
Templates are text blocks that can be dynamically loaded inside another page whenever that page is requested. The template is a special link in double curly brackets (for example "{{Disputed|date=October 2018}}"), which calls the template (in this case located at Template:Disputed) to load in place of the template call.
Templates are structured documents containing attribute–value pairs. They are defined with parameters, to which are assigned values when transcluded on an article page. The name of the parameter is delimited from the value by an equals sign. A class of templates known as infoboxes is used on Wikipedia to collect and present a subset of information about its subject, usually on the top (mobile view) or top right-hand corner (desktop view) of the document.
Pages in other namespaces can also be transcluded as templates. In particular, a page in the main namespace can be transcluded by prefixing its title with a colon; for example, {{:MediaWiki}} transcludes the article "MediaWiki" from the main namespace. Also, it is possible to mark the portions of a page that should be transcluded in several ways, the most basic of which are:[50]
<noinclude>...</noinclude>, which marks content that is not to be transcluded;<includeonly>...</includeonly>, which marks content that is not rendered unless it is transcluded;<onlyinclude>...</onlyinclude>, which marks content that is to be the only content transcluded.
A related method, called template substitution (called by adding subst: at the beginning of a template link) inserts the contents of the template into the target page (like a copy and paste operation), instead of loading the template contents dynamically whenever the page is loaded. This can lead to inconsistency when using templates, but may be useful in certain cases, and in most cases requires fewer server resources (the actual amount of savings can vary depending on wiki configuration and the complexity of the template).
Templates have found many different uses. Templates enable users to create complex table layouts that are used consistently across multiple pages, and where only the content of the tables gets inserted using template parameters. Templates are frequently used to identify problems with a Wikipedia article by putting a template in the article. This template then outputs a graphical box stating that the article content is disputed or in need of some other attention, and also categorize it so that articles of this nature can be located. Templates are also used on user pages to send users standard messages welcoming them to the site,[51] giving them awards for outstanding contributions,[52][53] warning them when their behavior is considered inappropriate,[54] notifying them when they are blocked from editing,[55] and so on.
Groups and restriction of access
[edit]MediaWiki offers flexibility in creating and defining user groups. For instance, it would be possible to create an arbitrary "ninja" group that can block users and delete pages, and whose edits are hidden by default in the recent changes log. It is also possible to set up a group of "autoconfirmed" users that one becomes a member of after making a certain number of edits and waiting a certain number of days.[56] Some groups that are enabled by default are bureaucrats and sysops. Bureaucrats have the power to change other users' rights. Sysops have power over page protection and deletion and the blocking of users from editing. MediaWiki's available controls on editing rights have been deemed sufficient for publishing and maintaining important documents such as a manual of standard operating procedures in a hospital.[57]
MediaWiki comes with a basic set of features related to restricting access, but its original and ongoing design is driven by functions that largely relate to content, not content segregation. As a result, with minimal exceptions (related to specific tools and their related "Special" pages), page access control has never been a high priority in core development and developers have stated that users requiring secure user access and authorization controls should not rely on MediaWiki, since it was never designed for these kinds of situations. For instance, it is extremely difficult to create a wiki where only certain users can read and access some pages.[58] Here, wiki engines like Foswiki, MoinMoin and Confluence provide more flexibility by supporting advanced security mechanisms like access control lists.
Extensibility
[edit]The MediaWiki codebase contains various hooks using callback functions to add additional PHP code in an extensible way. This allows developers to write extensions without necessarily needing to modify the core or having to submit their code for review. Installing an extension typically consists of adding a line to the configuration file, though in some cases additional changes such as database updates or core patches are required.
Five main extension points were created to allow developers to add features and functionalities to MediaWiki. Hooks are run every time a certain event happens; for instance, the ArticleSaveComplete hook occurs after a save article request has been processed.[59] This can be used, for example, by an extension that notifies selected users whenever a page edit occurs on the wiki from new or anonymous users.[60] New tags can be created to process data with opening and closing tags (<newtag>...</newtag>).[61] Parser functions can be used to create a new command ({{#if:...|...|...}}).[62] New special pages can be created to perform a specific function. These pages are dynamically generated. For example, a special page might show all pages that have one or more links to an external site or it might create a form providing user submitted feedback.[63] Skins allow users to customize the look and feel of MediaWiki.[64] A minor extension point allows the use of Amazon S3 to host image files.[65]
Extensions
[edit]Text manipulation
[edit]
Among the most popular extensions is a parser function extension, ParserFunctions, which allows different content to be rendered based on the result of conditional statements.[66] These conditional statements can perform functions such as evaluating whether a parameter is empty, comparing strings, evaluating mathematical expressions, and returning one of two values depending on whether a page exists. It was designed as a replacement for a notoriously inefficient template called {{Qif}}.[67] Schindler recounts the history of the ParserFunctions extension as follows:[68]
In 2006 some Wikipedians discovered that through an intricate and complicated interplay of templating features and CSS they could create conditional wiki text, i.e. text that was displayed if a template parameter had a specific value. This included repeated calls of templates within templates, which bogged down the performance of the whole system. The developers faced the choice of either disallowing the spreading of an obviously desired feature by detecting such usage and explicitly disallowing it within the software or offering an efficient alternative. The latter was done by Tim Starling, who announced the introduction of parser functions, wiki text that calls functions implemented in the underlying software. At first, only conditional text and the computation of simple mathematical expressions were implemented, but this already increased the possibilities for wiki editors enormously. With time further parser functions were introduced, finally leading to a framework that allowed the simple writing of extension functions to add arbitrary functionalities, like e.g. geo-coding services or widgets. This time the developers were clearly reacting to the demand of the community, being forced either to fight the solution of the issue that the community had (i.e. conditional text), or offer an improved technical implementation to replace the previous practice and achieve an overall better performance.
Another parser functions extension, StringFunctions, was developed to allow evaluation of string length, string position, and so on. Wikimedia communities, having created awkward workarounds to accomplish the same functionality,[69] clamored for it to be enabled on their projects.[70] Much of its functionality was eventually integrated into the ParserFunctions extension,[71] albeit disabled by default and accompanied by a warning from Tim Starling that enabling string functions would allow users "to implement their own parsers in the ugliest, most inefficient programming language known to man: MediaWiki wikitext with ParserFunctions."[72]
Lua extension
[edit]Since 2012 an extension, Scribunto, has existed that allows for the creation of "modules"—wiki pages written in the scripting language Lua—which can then be run within templates and standard wiki pages. Scribunto has been installed on Wikipedia and other Wikimedia sites since 2013 and is used heavily on those sites. Scribunto code runs significantly faster than corresponding wikitext code using ParserFunctions.[73]
For footnotes and academic-related display
[edit]Another very popular extension is a citation extension that enables footnotes to be added to pages using inline references.[74] This extension has, however, been criticized for being difficult to use and requiring the user to memorize complex syntax. A gadget called RefToolbar attempts to make it easier to create citations using common templates. MediaWiki has some extensions that are well-suited for academia, such as mathematics extensions[75] and an extension that allows molecules to be rendered in 3D.[76]
Integration
[edit]A generic Widgets extension exists that allows MediaWiki to integrate with virtually anything. Other examples of extensions that could improve a wiki are category suggestion extensions[77] and extensions for inclusion of Flash Videos,[78] YouTube videos,[79] and RSS feeds.[80] Metavid, a site that archives video footage of the U.S. Senate and House floor proceedings, was created using code extending MediaWiki into the domain of collaborative video authoring.[81]
Combating linkspam
[edit]There are many spambots that search the web for MediaWiki installations and add linkspam to them, despite the fact that MediaWiki uses the nofollow attribute to discourage such attempts at search engine optimization.[82] Part of the problem is that third party republishers, such as mirrors, may not independently implement the nofollow tag on their websites, so marketers can still get PageRank benefit by inserting links into pages when those entries appear on third party websites.[83] Anti-spam extensions have been developed to combat the problem by introducing CAPTCHAs,[84] blacklisting certain URLs,[85] and allowing bulk deletion of pages recently added by a particular user.[86]
Searches and queries
[edit]
MediaWiki comes pre-installed with a standard text-based search. Extensions exist to let MediaWiki use more sophisticated third-party search engines, including Elasticsearch (which since 2014 has been in use on Wikipedia), Lucene[87] and Sphinx.[88]
Various MediaWiki extensions have also been created to allow for more complex, faceted search, on both data entered within the wiki and on metadata such as pages' revision history.[89][90] Semantic MediaWiki is one such extension.[91][92]
Rich content
[edit]
Various extensions to MediaWiki support rich content generated through specialized syntax. These include mathematical formulas using LaTeX, graphical timelines over mathematical plotting, musical scores and Egyptian hieroglyphs.
The software supports a wide variety of uploaded media files, and allows image galleries and thumbnails to be generated with relative ease. There is also support for Exif metadata. MediaWiki operates the Wikimedia Commons, one of the largest free content media archives.
For WYSIWYG editing, VisualEditor is available to use in MediaWiki which simplifying editing process for editors and has been bundled since MediaWiki 1.35.[93] Other extensions exist for handling WYSIWYG editing to different degrees.[94]
Database
[edit]
MediaWiki can use either the MySQL/MariaDB, PostgreSQL or SQLite relational database management system. Support for Oracle Database and Microsoft SQL Server has been dropped since MediaWiki 1.34.[95] A MediaWiki database contains several dozen tables, including a page table that contains page titles, page ids, and other metadata;[96] and a revision table to which is added a new row every time an edit is made, containing the page id, a brief textual summary of the change performed, the user name of the article editor (or its IP address the case of an unregistered user) and a timestamp.[97][98]
In a 4½ year period prior to 2008, the MediaWiki database had 170 schema versions.[99] Possibly the largest schema change was done in 2005 with MediaWiki 1.5, when the storage of metadata was separated from that of content, to improve performance flexibility. When this upgrade was applied to Wikipedia, the site was locked for editing, and the schema was converted to the new version in about 22 hours. Some software enhancement proposals, such as a proposal to allow sections of articles to be watched via watchlist, have been rejected because the necessary schema changes would have required excessive Wikipedia downtime.[100]
Performance and storage
[edit]Because it is used to run one of the highest-traffic sites on the Web, Wikipedia, MediaWiki's performance and scalability have been highly optimized.[101] MediaWiki supports Squid, load-balanced database replication, client-side caching, memcached or table-based caching for frequently accessed processing of query results, a simple static file cache, feature-reduced operation, revision compression, and a job queue for database operations. MediaWiki developers have attempted to optimize the software by avoiding expensive algorithms, database queries, etc., caching every result that is expensive and has temporal locality of reference, and focusing on the hot spots in the code through profiling.[102]
MediaWiki code is designed to allow for data to be written to a read-write database and read from read-only databases, although the read-write database can be used for some read operations if the read-only databases are not yet up to date. Metadata, such as article revision history, article relations (links, categories etc.), user accounts and settings can be stored in core databases and cached; the actual revision text, being more rarely used, can be stored as append-only blobs in external storage. The software is suitable for the operation of large-scale wiki farms such as Wikimedia, which had about 800 wikis as of August 2011. However, MediaWiki comes with no built-in GUI to manage such installations.
Empirical evidence shows most revisions in MediaWiki databases tend to differ only slightly from previous revisions. Therefore, subsequent revisions of an article can be concatenated and then compressed, achieving very high data compression ratios of up to 100×.[102]
For more information on the architecture, such as how it stores wikitext and assembles a page, see External links.
Limitations
[edit]The parser serves as the de facto standard for the MediaWiki syntax, as no formal syntax has been defined. Due to this lack of a formal definition, it has been difficult to create WYSIWYG editors for MediaWiki, although several WYSIWYG extensions do exist, including the popular VisualEditor.
MediaWiki is not designed to be a suitable replacement for dedicated online forum or blogging software,[103] although extensions do exist to allow for both of these.[104][105]
It is common for new MediaWiki users to make certain mistakes, such as forgetting to sign posts with four tildes (~~~~),[106] or manually entering a plaintext signature,[107] due to unfamiliarity with the idiosyncratic particulars involved in communication on MediaWiki discussion pages. On the other hand, the format of these discussion pages has been cited as a strength by one educator, who stated that it provides more fine-grain capabilities for discussion than traditional threaded discussion forums. For example, instead of 'replying' to an entire message, the participant in a discussion can create a hyperlink to a new wiki page on any word from the original page. Discussions are easier to follow since the content is available via hyperlinked wiki page, rather than a series of reply messages on a traditional threaded discussion forum. However, except in few cases, students were not using this capability, possibly because of their familiarity with the traditional linear discussion style and a lack of guidance on how to make the content more 'link-rich'.[108]
MediaWiki by default has little support for the creation of dynamically assembled documents, or pages that aggregate data from other pages. Some research has been done on enabling such features directly within MediaWiki.[109] The Semantic MediaWiki extension provides these features. It is not in use on Wikipedia, but in more than 1,600 other MediaWiki installations.[110] The Wikibase Repository and Wikibase Repository client are however implemented in Wikidata and Wikipedia respectively, and to some extent provides semantic web features, and linking of centrally stored data to infoboxes in various Wikipedia articles.
Upgrading MediaWiki is usually fully automated, requiring no changes to the site content or template programming. Historically troubles have been encountered when upgrading from significantly older versions.[111]
Security
[edit]MediaWiki developers have enacted security standards, both for core code and extensions.[112] SQL queries and HTML output are usually done through wrapper functions that handle validation, escaping, filtering for prevention of cross-site scripting and SQL injection.[113] Many security issues have had to be patched after a MediaWiki version release,[114] and accordingly MediaWiki.org states, "The most important security step you can take is to keep your software up to date" by subscribing to the announcement mailing list and installing security updates that are announced.[115]
Support
[edit]Support for MediaWiki users consists of:
License
[edit]MediaWiki is free and open-source and is distributed under the terms of the GNU General Public License version 2 or any later version. Its documentation, located at its official website at www.mediawiki.org, is released under the Creative Commons BY-SA 4.0 license, with a set of help pages intended to be freely copied into fresh wiki installations and/or distributed with MediaWiki software in the public domain instead to eliminate legal issues for wikis with other licenses.[119][120] MediaWiki's development has generally favored the use of open-source media formats.[121]
Development
[edit]MediaWiki has an active volunteer community for development and maintenance. MediaWiki developers are spread around the world, though with a majority in the United States and Europe. Face-to-face meetings and programming sessions for MediaWiki developers have been held once or several times a year since 2004.[122]
Anyone can submit patches to the project's Git/Gerrit repository.[123] There are also paid programmers who primarily develop projects for the Wikimedia Foundation. MediaWiki developers participate in the Google Summer of Code by facilitating the assignment of mentors to students wishing to work on MediaWiki core and extension projects.[124] During the year prior to November 2012, there were about two hundred developers who had committed changes to the MediaWiki core or extensions.[125] Major MediaWiki releases are generated approximately every six months by taking snapshots of the development branch, which is kept continuously in a runnable state;[126] minor releases, or point releases, are issued as needed to correct bugs (especially security problems). MediaWiki is developed on a continuous integration development model, in which software changes are pushed live to Wikimedia sites on regular basis.[126] MediaWiki also has a public bug tracker, phabricator.wikimedia.org, which runs Phabricator. The site is also used for feature and enhancement requests.
History
[edit]
When Wikipedia was launched in January 2001, it ran on an existing wiki software system, UseModWiki. UseModWiki is written in the Perl programming language, and stores all wiki pages in text (.txt) files. This software soon proved to be limiting, in both functionality and performance. In mid-2001, Magnus Manske—a developer and student at the University of Cologne, as well as a Wikipedia editor—began working on new software that would replace UseModWiki, specifically designed for use by Wikipedia. This software was written in the PHP scripting language, and stored all of its information in a MySQL database. The new software was largely developed by August 24, 2001, and a test wiki for it was established shortly thereafter.
The first full implementation of this software was the new Meta Wikipedia on November 9, 2001. There was a desire to have it implemented immediately on the English-language Wikipedia.[127] However, Manske was apprehensive about any potential bugs harming the nascent website during the period of the final exams he had to complete immediately prior to Christmas;[128] this led to the launch on the English-language Wikipedia being delayed until January 25, 2002. The software was then, gradually, deployed on all the Wikipedia language sites of that time. This software was referred to as "the PHP script" and as "phase II", with the name "phase I", retroactively given to the use of UseModWiki.
Increasing usage soon caused load problems to arise again, and soon after, another rewrite of the software began; this time being done by Lee Daniel Crocker, which became known as "phase III". This new software was also written in PHP, with a MySQL backend, and kept the basic interface of the phase II software, but with the added functionality of a wider scalability. The "phase III" software went live on Wikipedia in July 2002.
The Wikimedia Foundation was announced on June 20, 2003. In July, Wikipedia contributor Daniel Mayer suggested the name "MediaWiki" for the software, as a play on "Wikimedia".[129] The MediaWiki name was gradually phased in, beginning in August 2003. The name has frequently caused confusion due to its (intentional) similarity to the "Wikimedia" name (which itself is similar to "Wikipedia").[130] The first version of MediaWiki, 1.1, was released in December 2003.

The old product logo was created by Erik Möller, using a flower photograph taken by Florence Nibart-Devouard, and was originally submitted to the logo contest for a new Wikipedia logo, held from July 20 to August 27, 2003.[131][132] The logo came in third place, and was chosen to represent MediaWiki rather than Wikipedia, with the second place logo being used for the Wikimedia Foundation.[133] The double square brackets ([[ ]]) symbolize the syntax MediaWiki uses for creating hyperlinks to other wiki pages; while the sunflower represents the diversity of content on Wikipedia, its constant growth, and the wilderness.[134]
Later, Brooke Vibber, the chief technical officer of the Wikimedia Foundation,[135] took up the role of release manager.[136][101]
Major milestones in MediaWiki's development have included: the categorization system (2004); parser functions, (2006); Flagged Revisions, (2008);[68] the "ResourceLoader", a delivery system for CSS and JavaScript (2011);[137] and the VisualEditor, a "what you see is what you get" (WYSIWYG) editing platform (2013).[138]
The contest of designing a new logo was initiated on June 22, 2020, as the old logo was a bitmap image and had "high details", leading to problems when rendering at high and low resolutions, respectively. After two rounds of voting, the new and current MediaWiki logo designed by Serhio Magpie was selected on October 24, 2020, and officially adopted on April 1, 2021.[139]
Sites using MediaWiki
[edit]
MediaWiki's most famous use has been in Wikipedia and, to a lesser degree, the Wikimedia Foundation's other projects. Fandom, a wiki hosting service formerly known as Wikia, runs on MediaWiki. Other public wikis that run on MediaWiki include wikiHow and SNPedia. WikiLeaks began as a MediaWiki-based site, but is no longer a wiki.
A number of alternative wiki encyclopedias to Wikipedia run on MediaWiki, including Citizendium, Metapedia, Scholarpedia and Conservapedia. MediaWiki is also used internally by a large number of companies, including Novell and Intel.[140][141]
Notable usages of MediaWiki within governments include Intellipedia, used by the United States Intelligence Community, Diplopedia, used by the United States Department of State, and milWiki, a part of milSuite used by the United States Department of Defense. United Nations agencies such as the United Nations Development Programme and INSTRAW chose to implement their wikis using MediaWiki, because "this software runs Wikipedia and is therefore guaranteed to be thoroughly tested, will continue to be developed well into the future, and future technicians on these wikis will be more likely to have exposure to MediaWiki than any other wiki software."[142]
The Free Software Foundation uses MediaWiki to implement the LibrePlanet site.[143]
Comparison to other online collaboration software
[edit]Users of online collaboration software are familiar with MediaWiki's functions and layout due to its noted use on Wikipedia. A 2006 overview of social software in academia observed that "Compared to other wikis, MediaWiki is also fairly aesthetically pleasing, though simple, and has an easily customized side menu and stylesheet."[144] However, in one assessment in 2006, Confluence was deemed to be a superior product due to its very usable API and ability to better support multiple wikis.[76]
A 2009 study at the University of Hong Kong compared TWiki to MediaWiki. The authors noted that TWiki has been considered as a collaborative tool for the development of educational papers and technical projects, whereas MediaWiki's most noted use is on Wikipedia. Although both platforms allow discussion and tracking of progress, TWiki has a "Report" part that MediaWiki lacks. Students perceived MediaWiki as being easier to use and more enjoyable than TWiki. When asked whether they recommended using MediaWiki for knowledge management course group project, 15 out of 16 respondents expressed their preference for MediaWiki giving answers of great certainty, such as "of course", "for sure".[145] TWiki and MediaWiki both have flexible plug-in architecture.[146]
A 2009 study that compared students' experience with MediaWiki to that with Google Docs found that students gave the latter a much higher rating on user-friendly layout.[147]
A 2021 study conducted by the Brazilian Nuclear Engineering Institute compared a MediaWiki-based knowledge management system against two others that were based on DSpace and Open Journal Systems, respectively.[148] It highlighted ease of use as an advantage of the MediaWiki-based system, noting that because the Wikimedia Foundation had been developing MediaWiki for a site aimed at the general public (Wikipedia), "its user interface was designed to be more user-friendly from start, and has received large user feedback over a long time", in contrast to DSpace's and OJS's focus on niche audiences.[148]
See also
[edit]- List of content management systems
- List of wiki software
- BlueSpice
- Semantic MediaWiki
- XOWA – for viewing Wikipedia and other wikis offline
- PHP – a programming language that powers MediaWiki
References
[edit]- ^ Sam Reed (October 3, 2025). "Security and maintenance release: 1.39.15 / 1.43.5 / 1.44.2 - MediaWiki-announce - lists.wikimedia.org". Retrieved October 3, 2025.
- ^ Reed, Sam (December 19, 2019). "Announcing MediaWiki 1.34.0". mediawiki-announce (Mailing list). Archived from the original on December 19, 2019. Retrieved December 19, 2019.
- ^ "Names.php • mediawiki". github.com. April 8, 2021. Archived from the original on July 15, 2021. Retrieved May 19, 2021.
- ^ "Copyright". mediawiki.org. Archived from the original on September 19, 2015. Retrieved September 7, 2015.
- ^ Manske, Magnus (August 24, 2001). "[Wikipedia-l] PHP Wikipedia". Retrieved October 2, 2025.
- ^ Barrett, Daniel J. (October 2008). MediaWiki. O'Reilly Media. ISBN 978-0-596-51979-7. Retrieved April 23, 2010.
- ^ a b "What is MediaWiki?". MediaWiki. January 9, 2021. Archived from the original on July 22, 2018. Retrieved March 27, 2021.
- ^ "Wikipedia:Statistics – Wikipedia, the free encyclopedia". Wikipedia. Archived from the original on August 28, 2021. Retrieved May 30, 2010.
- ^ a b "Message group statistics: MediaWiki core". translatewiki.net. August 20, 2023. Archived from the original on August 20, 2023. Retrieved August 20, 2023.
488 languages (not including languages that are supported but have no translations)
- ^ "Category:MediaWiki configuration settings". MediaWiki. September 11, 2016. Archived from the original on November 10, 2014. Retrieved September 11, 2016.
- ^ "Extension Matrix". MediaWiki. Archived from the original on September 11, 2016. Retrieved September 6, 2017.
- ^ Lerner, Reuven M. (February 23, 2006), Installing and Customizing MediaWiki, Linux Journal, archived from the original on April 6, 2010, retrieved April 23, 2010
- ^ Petrazickis, Leons (2009), Deploying PHP applications on IBM DB2 in the cloud: MediaWiki as a case study, Proceedings of the 2009 Conference of the Center for Advanced Studies on Collaborative Research, pp. 304–305, doi:10.1145/1723028.1723069, S2CID 27463043
- ^ "Manual:$wgEnableUploads". MediaWiki. Archived from the original on June 25, 2010. Retrieved May 30, 2010.
- ^ "Manual:$wgLogo". MediaWiki. December 12, 2009. Archived from the original on June 25, 2010. Retrieved May 30, 2010.
- ^ "Manual:LocalSettings.php". MediaWiki. March 29, 2007. Archived from the original on June 25, 2010. Retrieved May 30, 2010.
- ^ "Extension:AbuseFilter". MediaWiki. Archived from the original on June 25, 2010. Retrieved May 30, 2010.
- ^ Cacycle. "wikEd". Archived from the original on November 23, 2007.
- ^ "Manual:Installation guide". MediaWiki. Archived from the original on June 25, 2010. Retrieved May 30, 2010.
- ^ "Manual:Extending wiki markup". MediaWiki. Archived from the original on May 1, 2011. Retrieved May 30, 2010.
- ^ "HTML to Wiki Converter – tables". WMF Labs. March 29, 2008. Archived from the original on July 13, 2014. Retrieved June 12, 2014.
- ^ "Markup spec". MediaWiki. Archived from the original on December 19, 2007. Retrieved May 30, 2010.
- ^ "Extricating Meaning from Wikimedia Article Archives" (PDF). Archived (PDF) from the original on March 10, 2011. Retrieved January 2, 2011.
- ^ Jakes, David (August 15, 2006), Wild about Wikis, Tech & Learning, archived from the original on May 2, 2010, retrieved April 23, 2010
- ^ Foley, Brian & Chang, Tae (2008), Wiki as a professional development tool (PDF), Technology and Teacher Education, archived (PDF) from the original on April 30, 2011, retrieved April 23, 2010
- ^ "API". MediaWiki. May 17, 2010. Archived from the original on May 27, 2010. Retrieved May 30, 2010.
- ^ "Pywikibot – MediaWiki". mediawiki.org. Archived from the original on March 9, 2018. Retrieved March 16, 2018.
- ^ Česky. "Wikipedia:AutoWikiBrowser – Wikipedia, the free encyclopedia". En.wikipedia.org. Archived from the original on April 20, 2010. Retrieved May 30, 2010.
- ^ Bartolo, Laura M.; Lowe, Cathy S.; Songar, Poonam; Tandy, Robert J. (May 20, 2009), Facilitating Wiki/Repository Communication with Metadata, Georgia Institute of Technology, archived from the original on January 9, 2011, retrieved April 23, 2010
- ^ "API:Client code". MediaWiki. May 24, 2010. Archived from the original on June 26, 2010. Retrieved May 30, 2010.
- ^ "Tags – Wikipedia, the free encyclopedia". En.wikipedia.org. Archived from the original on March 4, 2010. Retrieved May 30, 2010.
- ^ "Manual:Tags". MediaWiki. August 31, 2009. Archived from the original on June 25, 2010. Retrieved May 30, 2010.
- ^ "Wikipedia:Huggle – Wikipedia, the free encyclopedia". En.wikipedia.org. Archived from the original on March 31, 2011. Retrieved May 30, 2010.
- ^ "IRC/Channels". Meta-Wiki. Archived from the original on March 23, 2010. Retrieved May 30, 2010.
- ^ Daniel Nasaw (July 25, 2012). "Meet the 'bots' that edit Wikipedia". BBC News. Archived from the original on July 28, 2012. Retrieved July 30, 2012.
- ^ "Manual:Watchlist". MediaWiki. November 24, 2009. Archived from the original on May 1, 2011. Retrieved May 30, 2010.
- ^ Kevin Yager (March 16, 2006), "Wiki ware could harness the Internet for science", Nature, 440 (7082): 278, Bibcode:2006Natur.440..278Y, doi:10.1038/440278a, PMID 16541049
- ^ "Manual:Interwiki". MediaWiki. Archived from the original on December 3, 2010. Retrieved May 30, 2010.
- ^ "Interlanguage links". MediaWiki. Archived from the original on March 12, 2021. Retrieved March 17, 2021.
- ^ Pintscher, Lydia (September 23, 2013). "Wikidata is Here!". Commons:Village pump. Archived from the original on December 6, 2021. Retrieved March 17, 2021.
- ^ "Help:Navigation". MediaWiki. May 21, 2010. Archived from the original on May 27, 2010. Retrieved May 30, 2010.
- ^ Carl Challborn & Teresa Reimann (December 2004), Wiki products: a comparison (PDF), Athabasca University, archived (PDF) from the original on December 23, 2010, retrieved April 23, 2010
- ^ Newman, Aaron; Steinberg, Adam; Thomas, Jeremy (2008). Enterprise 2. 0 Implementation. McGraw-Hill Professional. p. 185. ISBN 978-0-07-159160-7.
- ^ Malcolm, Jeremy (2008). Multi-Stakeholder Governance and the Internet Governance Forum. Terminus Press. pp. 188, 280. ISBN 978-0-9805084-0-6.
- ^ Ebersbach, Anja; Glaser, Markus; Heigl, Richard; Dueck, Gunter (2006). Wiki. Springer. pp. 55, 80–82, 109, 120–121, 156. ISBN 978-3-540-25995-4.
- ^ "Help:Categories". MediaWiki. Archived from the original on June 25, 2010. Retrieved May 30, 2010.
- ^ Jakob Voss (April 27, 2006). "Collaborative thesaurus tagging the Wikipedia way". arXiv:cs.IR/0604036.
- ^ Lupin. "Wikipedia:Tools/Navigation popups". Archived from the original on July 18, 2006.
- ^ "Extension:Gadgets". MediaWiki. March 30, 2010. Archived from the original on June 25, 2010. Retrieved May 30, 2010.
- ^ Anderson, Mark; Carr, Leslie; Millard, David E. (July 4, 2017). There and Here: Patterns of Content Transclusion in Wikipedia. 28th ACM Conference on Hypertext and Social Media. Prague, Czech Republic: ACM. pp. 115–124. doi:10.1145/3078714.3078726. ISBN 978-1-4503-4708-2.
- ^ Česky (May 16, 2010). "Template:Welcome – Wikipedia, the free encyclopedia". En.wikipedia.org. Archived from the original on May 6, 2011. Retrieved May 30, 2010.
- ^ T Kriplean; I Beschastnikh; et al. (2008), "Articulations of wikiwork: Uncovering valued work in wikipedia through barnstars", Proceedings of the 2008 ACM conference on Computer supported cooperative work, Proceedings of the ACM, pp. 47–56, doi:10.1145/1460563.1460573, ISBN 9781605580074, S2CID 7164949
- ^ Česky. "Wikipedia:Barnstars – Wikipedia, the free encyclopedia". En.wikipedia.org. Archived from the original on June 24, 2009. Retrieved May 30, 2010.
- ^ Česky. "Template:Test – Wikipedia, the free encyclopedia". En.wikipedia.org. Archived from the original on November 11, 2009. Retrieved May 30, 2010.
- ^ "Template:Test5 – Wikipedia, the free encyclopedia". En.wikipedia.org. June 19, 2008. Archived from the original on April 24, 2009. Retrieved May 30, 2010.
- ^ "Manual:User rights management". MediaWiki. Archived from the original on June 25, 2010. Retrieved May 30, 2010.
- ^ H Zielke; W Boemke; M Kastrup; C Melzer (November 21, 2007), Operating Procedures in Clinical Practice (PDF), Royal College of Anaesthetists, archived (PDF) from the original on May 15, 2011, retrieved April 25, 2010
- ^ "Security issues with authorization extensions". MediaWiki. Archived from the original on June 26, 2010. Retrieved May 30, 2010.
- ^ "Manual:Hooks/ArticleSaveComplete". MediaWiki. May 26, 2010. Archived from the original on November 10, 2014. Retrieved May 30, 2010.
- ^ "Extension:Recent Activity Notify". MediaWiki. Archived from the original on September 27, 2014. Retrieved May 30, 2010.
- ^ "Manual:Tag extensions". MediaWiki. May 21, 2010. Archived from the original on October 12, 2014. Retrieved May 30, 2010.
- ^ "Manual:Parser functions". MediaWiki. March 22, 2010. Archived from the original on October 18, 2014. Retrieved May 30, 2010.
- ^ "Manual:Special pages". MediaWiki. Archived from the original on November 10, 2014. Retrieved May 30, 2010.
- ^ "Manual:Skins". MediaWiki. May 14, 2010. Archived from the original on November 25, 2014. Retrieved May 30, 2010.
- ^ "Manual:Integration with S3". MediaWiki. March 22, 2010. Archived from the original on November 27, 2014. Retrieved May 30, 2010.
- ^ "Extension:ParserFunctions". MediaWiki. December 25, 2009. Archived from the original on June 25, 2010. Retrieved May 30, 2010.
- ^ "Wikipedia:Miscellany for deletion/Template:Qif – Wikipedia, the free encyclopedia". En.wikipedia.org. Archived from the original on February 25, 2015. Retrieved May 30, 2010.
- ^ a b M Schindler; D Vrandecic (2009), Introducing new features to Wikipedia, Proceedings of WebSci, archived from the original on June 24, 2018, retrieved June 24, 2018
- ^ "Category:String manipulation templates – Wikipedia, the free encyclopedia". En.wikipedia.org. May 15, 2010. Archived from the original on May 6, 2011. Retrieved May 30, 2010.
- ^ "Bug 6455 – Enable StringFunctions on WMF wikis". bugzilla.wikimedia.org. Archived from the original on January 22, 2012. Retrieved October 9, 2010.
- ^ "Extension:StringFunctions". MediaWiki. Archived from the original on June 25, 2010. Retrieved May 30, 2010.
- ^ "r51497 – Code Review". MediaWiki. Archived from the original on November 27, 2014. Retrieved May 30, 2010.
- ^ "Lua performance". Archived from the original on August 24, 2018. Retrieved December 27, 2018.
- ^ "Extension:Cite". MediaWiki. May 3, 2010. Archived from the original on October 20, 2014. Retrieved May 30, 2010.
- ^ "Category:Math extensions". MediaWiki. December 26, 2009. Archived from the original on May 1, 2011. Retrieved May 30, 2010.
- ^ a b Marieke Guy (January 2007), Wikido: Exploiting the Potential of Wikis, Ariadne, archived from the original on April 7, 2010, retrieved April 23, 2010
- ^ "Extension:CategorySuggest". MediaWiki. Archived from the original on September 26, 2014. Retrieved May 30, 2010.
- ^ "Category:Flash Video extensions". MediaWiki. Archived from the original on September 15, 2014. Retrieved May 30, 2010.
- ^ "Category:YouTube extensions". MediaWiki. September 16, 2008. Archived from the original on May 1, 2011. Retrieved May 30, 2010.
- ^ "Category:RSS extensions". MediaWiki. Archived from the original on December 3, 2010. Retrieved May 30, 2010.
- ^ M Dale; A Stern; M Deckert; W Sack (2009), System demonstration: Metavid.org: a social website and open archive of congressional video, Proceedings of the 10th Annual International Conference on Digital Government Research: Social Networks: Making Connections between Citizens, Data and Government, pp. 309–310, ISBN 978-1-60558-535-2
- ^ "Wiki spam". Meta-Wiki. Archived from the original on November 7, 2014. Retrieved May 30, 2010.
- ^ Goldman, Eric, Wikipedia's Labor Squeeze and its Consequences, vol. 8, Journal on Telecommunications and High Technology Law
- ^ "Extension:ConfirmEdit". MediaWiki. May 5, 2010. Archived from the original on October 20, 2014. Retrieved May 30, 2010.
- ^ "Extension:SpamBlacklist". MediaWiki. March 24, 2010. Archived from the original on October 20, 2014. Retrieved May 30, 2010.
- ^ "Extension:Nuke". MediaWiki. May 19, 2010. Archived from the original on October 20, 2014. Retrieved May 30, 2010.
- ^ Lucene-search MediaWiki extension Archived June 2, 2012, at the Wayback Machine, mediawiki.org
- ^ SphinxSearch MediaWiki extension Archived October 22, 2014, at the Wayback Machine, mediawiki.org
- ^ Masanori Arita & Kazuhiro Suwa (September 17, 2008), "Search extension transforms Wiki into a relational system: A case for flavonoid metabolite database", BioData Min, 1 (1), BioData Mining: 7, doi:10.1186/1756-0381-1-7, PMC 2556319, PMID 18822113
- ^ Finn Arup Nielsen (October 15, 2009). "Lost in localization: a solution with neuroinformatics 2.0?". NeuroImage. 48 (1): 11–3. doi:10.1016/J.NEUROIMAGE.2009.05.073. ISSN 1053-8119. PMID 19497377. Wikidata Q21011200.
- ^ Eric Ras; Jörg Rech; Sebastian Weber (August 1, 2008), Collaborative Authoring of Learning Elements for Adaptive Learning Spaces (PDF), Fifth International Conference on Adaptive Hypermedia and Adaptive Web-Based Systems, archived (PDF) from the original on May 3, 2011, retrieved April 23, 2010
- ^ Hartung, Michael; et al. "A Platform for Collaborative Management of Semantic Grid Metadata". Intelligent distributed computing, systems and applications. p. 123.
- ^ "Extension:VisualEditor". MediaWiki. Archived from the original on February 21, 2021. Retrieved March 15, 2021.
- ^ "Category:WYSIWYG extensions". MediaWiki. April 10, 2008. Archived from the original on May 1, 2011. Retrieved May 30, 2010.
- ^ "Manual:Installation requirements". MediaWiki. Archived from the original on March 8, 2021. Retrieved March 14, 2021.
- ^ "Manual:Page table". MediaWiki. May 15, 2010. Archived from the original on November 25, 2014. Retrieved May 30, 2010.
- ^ "Manual:Revision table". MediaWiki. Archived from the original on November 24, 2014. Retrieved May 30, 2010.
- ^ Ortega, Felipe; González-Barahona, Jesus M.; Robles, Gregorio (2007), The Top-Ten Wikipedias: A Quantitative Analysis Using WikiXRay, CiteSeerX 10.1.1.107.1424
- ^ Curino, Carlo A.; Tanca, Letizia; Zaniolo, Carlo (2008), Information Systems Integration and Evolution: Ontologies at Rescue (PDF), Workshop on Semantic, archived (PDF) from the original on December 22, 2009, retrieved April 23, 2010
- ^ T Dumitras; P Narasimhan (2009), No downtime for data conversions: Rethinking hot upgrades (PDF), archived from the original (PDF) on June 16, 2010, retrieved April 29, 2010
- ^ a b "Wikipedia and MediaWiki". Presentation MediaWiki development (video). April 28, 2006. Archived from the original on April 14, 2011. Retrieved September 23, 2009.
- ^ a b Bergsma, Mark, Wikimedia Architecture (PDF), archived (PDF) from the original on March 5, 2016, retrieved October 21, 2015
- ^ "Manual:What is". MediaWiki. Archived from the original on July 22, 2018. Retrieved May 30, 2010.
- ^ "Extension:StructuredDiscussions". MediaWiki. Archived from the original on December 27, 2018. Retrieved December 27, 2018.
- ^ "Extension:Wikilog". MediaWiki. November 27, 2009. Archived from the original on September 22, 2014. Retrieved May 30, 2010.
- ^ "Help:Signatures". MediaWiki. Archived from the original on November 15, 2008. Retrieved May 30, 2010.
- ^ N Augar; R Raitman; W Zhou (2004), Teaching and learning online with wikis, Beyond the comfort zone, pp. 95–104, CiteSeerX 10.1.1.133.1456
- ^ Cubric, Marija (2007), Analysis of the use of Wiki-based collaborations in enhancing student learning, University of Hertfordshire, p. 11, archived from the original on May 15, 2011, retrieved April 24, 2010
- ^ Albertsen, Johannes & Bouvin, Niels Olof (2008), User defined structural searches in mediawiki, Proceedings of the nineteenth ACM conference on Hypertext and hypermedia, ISBN 978-1-59593-985-2
- ^ "Extension:Semantic MediaWiki – WikiApiary". Archived from the original on October 26, 2018. Retrieved October 12, 2019.
- ^ T Dumitraş; P Narasimhan (2009), Toward upgrades-as-a-service in distributed systems, Proceedings of the 10th ACM/IFIP/USENIX International Conference on Middleware, pp. 1–2
- ^ "Security for developers". MediaWiki. Archived from the original on November 25, 2014. Retrieved May 30, 2010.
- ^ Perrin, Chad (April 30, 2008), Five security tips from MediaWiki's lead developer, Tech Republic[permanent dead link]
- ^ "News". MediaWiki. Archived from the original on October 6, 2014. Retrieved May 30, 2010.
- ^ "Manual:Security". MediaWiki. March 22, 2010. Archived from the original on November 10, 2014. Retrieved May 30, 2010.
- ^ Books about MediaWiki Archived December 27, 2018, at the Wayback Machine, mediawiki.org
- ^ MediaWiki Administrator's Handbook. Wikibooks. Archived from the original on October 20, 2014. Retrieved October 20, 2014.
- ^ MediaWiki User Guide, Wikibooks, archived from the original on October 20, 2014, retrieved October 20, 2014
- ^ "MediaWiki.org Project:Copyrights". Archived from the original on August 23, 2023. Retrieved August 23, 2023.
- ^ "Project:PD help". MediaWiki. Archived from the original on October 29, 2020. Retrieved May 30, 2010.
- ^ Rafe Needleman (November 19, 2008), Wikipedia gears up for flood of video and photo files, C-Net, archived from the original on August 6, 2009, retrieved April 23, 2010
- ^ "Events". Mediawiki.org. Archived from the original on December 27, 2018. Retrieved December 27, 2018.
- ^ "Development policy". MediaWiki. July 19, 2013. Archived from the original on May 10, 2017. Retrieved August 4, 2013.
- ^ "Summer of Code". MediaWiki. March 26, 2013. Archived from the original on May 10, 2017. Retrieved August 4, 2013.
- ^ "Wikimedia". Open Hub. Archived from the original on September 14, 2017. Retrieved November 15, 2012. Approximate counts (not deduplicated) as of November 4, 2012: 139 for core, 155 for extensions supported by WMF, 190 and 42 for extensions only hosted on WMF's Git and SVN repositories respectively.
- ^ a b "Version lifecycle". MediaWiki. September 5, 2018. Archived from the original on June 17, 2020. Retrieved October 21, 2018.
- ^ Bartlett, Manning (November 14, 2001). "Magnus's new script..." Wikimedia Lists. Wikimedia Foundation. Archived from the original on October 2, 2019. Retrieved October 2, 2019.
- ^ Manske, Magnus (November 14, 2001). "Magnus's new script..." Wikimedia Lists. Wikimedia Foundation. Archived from the original on October 2, 2019. Retrieved October 2, 2019.
- ^ Mayer, Daniel (July 19, 2003). "Phase IV, Wikibooks.org/.com and WikimediaFoundation.org/.com (was Wikis and uniformity)". Wikipedia-L mailing list. Archived from the original on July 12, 2017. Retrieved January 18, 2015.
- ^ "Differences between Wikipedia, Wikimedia, MediaWiki, and wiki". MediaWiki. Archived from the original on July 1, 2009. Retrieved May 30, 2010.
- ^ "International logo contest". Meta-Wiki. Archived from the original on May 9, 2020. Retrieved April 9, 2020.
- ^ "International logo contest/results". Meta-wiki. Wikimedia Foundation. January 10, 2007. Archived from the original on November 4, 2015. Retrieved March 14, 2007.
- ^ "Historical/Logo history". Meta-wiki. Wikimedia Foundation. January 17, 2007. Archived from the original on November 4, 2015. Retrieved March 14, 2007.
- ^ Erik Möller (July 26, 2003). "File talk:EloquenceSunflowerNew-Small.png – Meta". Meta-wiki. Wikimedia Foundation. Archived from the original on January 30, 2016. Retrieved February 3, 2013.
- ^ David Weinberger (2007). Everything Is Miscellaneous: The Power of the New Digital Disorder. Times Books. p. 99. ISBN 978-0-8050-8043-8.
- ^ "MediaWiki history". MediaWiki website. Archived from the original on October 27, 2020. Retrieved August 4, 2013.
- ^ "MediaWiki ResourceLoader". Mediawiki.org. Archived from the original on March 8, 2013. Retrieved July 6, 2013.
- ^ "VisualEditor – MediaWiki". MediaWiki. Archived from the original on September 27, 2013. Retrieved September 15, 2013.
- ^ Sarabadani, Amir (March 31, 2021). "Logo of MediaWiki has changed". Wikimedia Foundation. Archived from the original on April 2, 2021. Retrieved April 2, 2021.
- ^ MediaWiki testimonials Archived January 11, 2012, at the Wayback Machine, mediawiki.org
- ^ "The story of Intelpedia: A model corporate wiki". Socialmedia.biz. Archived from the original on September 16, 2013. Retrieved August 16, 2013.
- ^ A. Maron; M. Maron (2007). "A stealth transformation: introducing wikis to the UN". Knowledge Management for Development Journal. Archived from the original on May 4, 2011. Retrieved October 9, 2010.
- ^ "LibrePlanet Homepage". Archived from the original on March 18, 2011. Retrieved December 10, 2018.
- ^ Bryant, Todd (2006), Social Software in Academia (PDF), Educause Quarterly, archived from the original (PDF) on December 22, 2009, retrieved April 23, 2010
- ^ Liang, M.; Chu, S.; Siu, F.; Zhou, A. (December 3–4, 2009), Comparing User Experiences in Using Twiki & Mediawiki to Facilitate Collaborative Learning (PDF), Proceedings of the 2009 International Conference on Knowledge Management, archived from the original (PDF) on May 14, 2011
- ^ Schulz, Judith (2009), Company-Wiki as a knowledge transfer instrument for reducing the shortage of skilled workers (PDF), Institute of Technology and Education, archived (PDF) from the original on March 4, 2016, retrieved April 25, 2010
- ^ Chu, S.; Kennedy, D.; Mak, M. (December 3–4, 2009), MediaWiki and Google Docs as online collaboration tools for group project co-construction (PDF), Proceedings of the 2009 International Conference on Knowledge Management, archived from the original (PDF) on May 14, 2011, retrieved April 23, 2010
- ^ a b Grecco, Claudio Henrique dos Santos; Augusto, Silas Cordeiro; Souza, Jaqueline Tavares Viana de; Carvalho, Paulo Victor Rodrigues; Davila, Adriana Loureiro (July 25, 2021). "A Method for the evaluation of knowledge management systems". Brazilian Journal of Radiation Sciences. 9 (2B). doi:10.15392/bjrs.v9i2B.1250. ISSN 2319-0612. S2CID 237733021. Archived from the original on November 12, 2021. Retrieved November 12, 2021.
External links
[edit]MediaWiki
View on GrokipediaOverview
History
MediaWiki originated in 2002 when Lee Daniel Crocker developed a new PHP-based wiki engine, known as "Phase III," to address performance issues with the existing UseModWiki (Phase I) and the interim Phase II software created by Magnus Manske for Wikipedia.[1] This rewrite improved scalability and features, marking the beginning of the software that would evolve into MediaWiki.[1] In June 2003, the Wikimedia Foundation was established by Jimmy Wales to oversee Wikipedia and its infrastructure, with MediaWiki quickly integrating as the foundational software for the foundation's projects.[1] The first stable numbered release, MediaWiki 1.1, arrived on December 8, 2003, introducing formalized versioning and core functionalities like improved editing and namespace support.[10] Development continued rapidly, with the project shifting from Subversion to Git for version control in 2012 to enhance collaboration among contributors.[11] Long-term support (LTS) versions began to emphasize stability for production environments; MediaWiki 1.35, released on September 25, 2020, provided extended security updates until 2023.[12] Subsequent LTS releases included 1.39 on November 30, 2022, focusing on auto-creation of temporary users and administrative tools, and 1.43 on December 23, 2024, which introduced enhanced password reset options requiring both username and email for security and deprecated legacy parser methods to improve template handling efficiency.[13][14] The current stable version is 1.44, released on July 2, 2025, with development for 1.45 beginning in November 2025.[15][16] Key milestones in community and development included the establishment of annual developer gatherings starting around 2006, such as hacking days at Wikimania and early MediaWiki-focused meetings, evolving into structured conferences like the MediaWiki Users and Developers Conference series from 2008 onward.[17] The most recent event, the MediaWiki Users and Developers Conference Fall 2025, took place October 28–30 in Hanover, Germany, hosted by the German National Library of Science and Technology, with discussions on advanced topics.[18] Significant evolution in core components enhanced MediaWiki's capabilities for structured and visual editing. The Wikibase extension, introduced in 2012, enabled support for structured data, powering projects like Wikidata by allowing storage and querying of linked information.[19] In 2013, VisualEditor was launched as a WYSIWYG editing interface, simplifying page creation without requiring markup knowledge.[20] This was complemented by the Parsoid parser in 2014, a bidirectional tool converting between wikitext and HTML to support VisualEditor's round-trip editing and improve output consistency.[21] These advancements have sustained MediaWiki's role in large-scale collaborative knowledge bases through 2025.Design principles
MediaWiki is fundamentally designed as free and open-source software, licensed under the GNU General Public License (GPL) version 2 or later, which ensures that the source code remains freely available for modification, distribution, and study by anyone. This licensing aligns with the broader free and open-source software (FOSS) principles, emphasizing community-driven development and the avoidance of proprietary restrictions to foster widespread adoption and contribution. The software's core goals include enabling the dissemination of free knowledge through collaborative platforms, as guided by the Wikimedia Foundation's mission to support accessible and equitable information sharing.[22] At its heart, MediaWiki embodies the wiki philosophy of openness and collective authorship, exemplified by the "anyone can edit" model that allows users to contribute content without barriers, provided they adhere to community guidelines. This approach is supported by reversion-friendly mechanisms, such as comprehensive edit histories that track all changes to pages, enabling easy reversal of edits and accountability in collaborative environments.[23] Community policies, facilitated by the software's discussion and revision tools, enforce a neutral point of view by encouraging balanced representation of perspectives through consensus-building rather than centralized control. Scalability is a key design tenet, allowing the software to handle large-scale deployments like Wikipedia, which serves millions of views daily, through features like multi-server load balancing and caching layers.[24] Architecturally, MediaWiki employs a layered design in PHP, separating concerns across components such as the parser, API, and resource loader to promote maintainability and modularity without strictly adhering to a traditional MVC pattern.[24] It operates in a stateless manner, storing session data externally (e.g., in memcached), which facilitates horizontal scaling across distributed servers.[24] Extensibility is achieved via a hook system, introduced in 2004, that allows developers to inject custom code at specific points without altering the core codebase, enabling seamless integration of extensions while preserving the separation of content from presentation through semantic markup and templating.[24][25] Over time, MediaWiki's principles have evolved to prioritize accessibility, with ongoing efforts to align with Web Content Accessibility Guidelines (WCAG) through improvements in navigation, contrast, and screen reader compatibility starting in the 2010s.[26] Internationalization has been integral since its inception, supporting over 300 languages via message localization and right-to-left text handling to serve global audiences.[27] More recently, there has been a focus on machine-readable structured content to enhance data interoperability, including support for formats like JSON-LD through core enhancements and extensions in versions such as 1.43.[28]Core Features
Markup and editing
MediaWiki employs Wikitext, a lightweight markup language designed for formatting and structuring content on wiki pages, allowing users to create richly formatted text without requiring HTML knowledge.[29] This syntax interprets plain text characters and keywords into rendered output, supporting elements such as headings, lists, links, emphasis, tables, and media embeds.[30] For instance, headings are defined using equals signs surrounding the title text, with the number of signs determining the level:= Level 1 = for the top-level heading, == Level 2 == for subsections, and so on up to six levels.[30] Unordered lists use asterisks (* Item) at the start of lines, while ordered lists employ hashes (# Item), enabling nested structures for hierarchical content.[31]
Links in Wikitext facilitate navigation between pages, with internal links formatted as [[Page name]] to reference other articles within the wiki, optionally including piped text like [[Page name|Display text]] for custom labels.[30] External links are created using square brackets around a URL and description, such as [](https://example.com Example site), which renders as a clickable phrase.[30] Text emphasis is achieved through apostrophes: three ('''bold''') for bold, two (''italics'') for italics, and combinations for both.[](https://www.mediawiki.org/wiki/Help:Wikitext_examples) Tables are constructed with pipe-delimited cells within a frame, starting with {|and ending with|}`, as in:
{| class="wikitable"
|+ Table caption
! Header 1 !! Header 2
|-
| Cell 1 || Cell 2
|}
{| class="wikitable"
|+ Table caption
! Header 1 !! Header 2
|-
| Cell 1 || Cell 2
|}
[[File:Filename.extension|options]], where options like thumb for thumbnails or alt=description for accessibility are specified; for example, [[File:Example.jpg|thumb|upright=1.2|alt=Sample image|Caption]].[30]
Wikitext also includes parser functions, which are predefined directives enclosed in double braces ({{ }}) that perform dynamic operations during page rendering. A common example is {{DISPLAYTITLE:Custom Title}}, which overrides the default page title display without altering the actual page name.
Editing in MediaWiki occurs through several interfaces tailored to different user preferences. The classic wikitext editor presents the raw markup in a textarea for direct modification, suitable for experienced users familiar with the syntax. Introduced in 2013, the VisualEditor provides a what-you-see-is-what-you-get (WYSIWYG) experience, rendering content visually while underlying Parsoid—a bidirectional parser—converts between HTML and Wikitext for seamless saving and round-tripping.[32][21] Users can switch to source editor mode within VisualEditor to view or tweak the underlying Wikitext if needed.[32]
Advanced editing tools enhance usability and precision. Section-specific editing allows folding and unfolding of page sections via clickable links, isolating changes to subsections without loading the entire page. Undo and redo functionalities are integrated into both editors, enabling quick reversal of actions, while diff views compare revisions side-by-side to highlight additions, deletions, and modifications. In MediaWiki 1.43, improvements include enhanced diff stability to prevent errors in content handling and better cleanup mechanisms for elements like table of contents via Remex HTML integration.[33] Smarter template insertion aids in placing parameterized content more intuitively during edits.
Change tracking features ensure collaborative oversight and accountability. Automatic edit summaries prompt users to describe their modifications upon saving, providing context for reviewers; these summaries appear in page histories and logs. Watchlists allow users to subscribe to specific pages or namespaces, delivering notifications of changes via email or the user interface. The Recent Changes special page lists all edits in reverse chronological order, including details like timestamp, editor, byte changes, and summary, with filters for namespaces or users.[34] Patrol features enable trusted users (patrollers) to mark edits as reviewed, flagging unchecked changes on watchlists and Recent Changes to prioritize quality control.
Navigation and organization
MediaWiki facilitates user navigation through a combination of hypertext links, structured namespaces, and organizational tools that enable efficient browsing and content discovery within a wiki. These mechanisms allow contributors and readers to traverse pages seamlessly, grouping related content and providing contextual access to discussions, histories, and searches. By integrating these elements, MediaWiki supports scalable organization for large-scale collaborative projects like encyclopedias. Linking in MediaWiki encompasses several types designed to connect content internally, across wikis, and externally. Internal wikilinks, the primary method for intra-wiki navigation, use double square brackets around the target page name, such as [[Page title]], which renders as a clickable hyperlink to that page; piped links allow customization of the display text, like [[Page title|Custom label]], enhancing readability without altering the underlying structure.[35] Interwiki links extend navigation to other wikis by prefixing the target with a project code, such as [[wikipedia:Article]], facilitating cross-project references while keeping users within the MediaWiki ecosystem.[35] Interlanguage links, often appearing in a sidebar language selector, connect equivalent pages across language versions of a wiki using magic words like {{int:}} or through dedicated langlinks sections, promoting multilingual exploration.[35] External URLs are linked via single square brackets, such as [36], or full syntax for inline citations, directing users outside the wiki for supplementary resources.[35] Namespaces provide a foundational layer for organizing pages by purpose, partitioning content to avoid overlap and improve discoverability. Core namespaces include the Main namespace (no prefix, for primary articles), Talk (suffixed with "Talk:", for page-specific discussions), User (prefixed with "User:", for personal user pages), Project (prefixed with "Project:" or wiki-specific alias like "Wikipedia:", for meta-content), and Help (prefixed with "Help:", for instructional pages).[37] Custom namespaces can be configured by administrators to suit specific needs, such as "Category" for organizational tags or specialized ones like "Template" for reusable elements.[38] Each content namespace pairs with a corresponding talk namespace for threaded discussions, enabling collaborative refinement without cluttering main content.[37] Subpages extend this structure hierarchically, allowing nested organization like [[Main Page/Subpage]], which aids in breaking down complex topics into manageable sections while maintaining navigational hierarchy.[39] Organizational tools further enhance content structuring and access. Categories group pages thematically by appending [[Category:Foo]] to a page's wikitext, generating an automatic list of categorized items at the page bottom and a category index page for browsing; this tagging system supports dynamic sorting and filtering, crucial for large wikis.[40] Page tabs, displayed at the top of every article, offer quick actions including "View" for reading, "Edit" for modifications, "History" for version tracking, and "Watch" to add pages to a personal watchlist for updates.[41] Special pages, accessed via the "Special:" prefix or toolbox links, include tools like Special:Search for full-text querying and Special:Categories for viewing all category hierarchies, streamlining administrative and exploratory navigation.[42] Recent enhancements have refined these navigation capabilities for broader accessibility. The CirrusSearch extension, which integrates Elasticsearch for advanced full-text search, became the default search backend on Wikimedia Foundation wikis by late 2014, offering faster indexing, relevance scoring, and features like phrase matching to improve content discovery over the prior Lucene-based system.[43] For mobile users, the Minerva Neue skin introduces structured navigation via a collapsible hamburger menu that adapts the sidebar and page tabs to touch interfaces, incorporating enhancements like nearby article suggestions and optimized search integration since its core inclusion in MediaWiki 1.38.[44]User management and access
MediaWiki supports user registration through a dedicated form accessible from the login page, where individuals provide a username, password, and optional email address to create an account.[45] Once registered, users log in with their credentials to gain persistent access to features like editing history and watchlists. Anonymous users, identified by their IP address, can view content and perform edits if site permissions allow, though their contributions are attributed to the IP rather than a username.[46] OAuth authentication is facilitated via the dedicated extension, enabling secure login through third-party providers, with support integrated since 2015 for enhanced external access.[47] Users manage personal settings through the preferences interface, including selection of interface skins for visual customization and adjustment of time zones to align display formats with local settings.[48] Permissions in MediaWiki are organized into groups, each assigned specific rights to control actions such as editing, deleting, or protecting pages. Predefined groups include '*' for anonymous users, 'user' for basic registered accounts, 'autoconfirmed' for established users after a period of activity, 'bot' for automated processes, and 'sysop' for administrators with elevated privileges like page deletion and protection.[49] Rights like 'edit' allow content modification, 'delete' enables page removal, and 'protect' permits restriction settings; these can overlap across groups for granular control. Administrators configure group permissions centrally using the $wgGroupPermissions array in the site's LocalSettings.php file, allowing custom assignments such as granting 'edit' to 'autoconfirmed' while restricting it from anonymous users. Access to content and features is further regulated through protection mechanisms applied to individual pages or namespaces. Protection levels include restrictions on 'edit' (preventing content changes) and 'move' (blocking renames), with cascading protection extending safeguards to all pages transcluded from a protected source, such as templates or images used across the site.[50] Only users in groups with matching rights, typically sysops, can modify protected pages, helping maintain stability on high-traffic or sensitive content. Rate limiting enforces quotas on actions like edits or API calls, configurable via $wgRateLimits to cap attempts per user or IP—such as 10 edits per minute for new accounts—to mitigate spam and overload. Destructive operations, including deletions and protections, require explicit confirmation through dialog prompts to verify user intent and prevent accidental changes.[51] Recent enhancements to user management emphasize security and privacy. Two-factor authentication (2FA) is supported via the OATHAuth extension, implementing time-based one-time passwords (TOTP) for added login verification, with improved integration and features in MediaWiki 1.39 and subsequent releases.[52] For GDPR compliance, privacy tools have been bolstered since 2018, including user-initiated data exports through Special:Export for contributions and extensions enabling comprehensive personal data retrieval in formats like XML or JSON to facilitate right-to-access requests._and_MediaWiki_software)Technical Implementation
Installation and setup
MediaWiki requires a compatible web server environment to operate effectively. The software demands PHP version 8.1 or later, with PHP 8.3 recommended for optimal performance in recent deployments as of 2025.[53] Supported databases include MySQL 5.7 or higher, MariaDB 10.3 or higher, PostgreSQL 10.0 or higher, or SQLite 3.24.0 or higher, though MySQL or MariaDB is the most commonly used and recommended option.[53] A web server such as Apache 2.4 or Nginx is necessary to handle HTTP requests, and Composer is required for managing PHP dependencies during setup and updates.[53] These components ensure the wiki can process dynamic content and store data reliably. The installation process begins with downloading the latest stable release from the official MediaWiki website at mediawiki.org.[54] After extraction, the files are uploaded to the web server's document root directory via FTP or similar tools.[54] A database must then be created, including a dedicated user with appropriate permissions for read/write access.[54] The web-based installer is launched by accessing the mw-config directory through a browser, which guides users through entering database credentials, site details, and generates the LocalSettings.php configuration file.[54] Alternatively, a command-line interface (CLI) installer named mw-installer.php can be run for automated setup in server environments.[54] Upon completion, an initial administrator account is created to manage the wiki. Basic configuration occurs primarily in the LocalSettings.php file, which is placed in the root directory and loaded on every page request.[55] Key settings include defining the site name and language with variables like wgLanguageCode, uploading a custom logo via wgEnotifUserTalk and SMTP details.[55] Features such as mathematical rendering can be enabled by installing and activating the Math extension in this file, for example, by adding wfLoadExtension( 'Math' );[55] These adjustments allow administrators to tailor the wiki's appearance and functionality without altering core code. Upgrading MediaWiki involves careful steps to maintain data integrity, starting with a full backup of the database and files.[56] For minor and patch releases, dependencies are updated using Composer with the command composer update in the installation directory.[56] Major upgrades, such as migrating from Long Term Support (LTS) versions like 1.39 to 1.43, require downloading the new release, replacing core files while preserving LocalSettings.php and customizations, and then running the update.php script via CLI (php maintenance/update.php) or web interface to apply schema changes.[56] Administrators should verify compatibility with extensions and themes beforehand, and test the upgrade in a staging environment to minimize disruptions.[56]Database and storage
MediaWiki employs a relational database schema, primarily designed for MySQL or MariaDB, to manage wiki content, revisions, and associated metadata. The core structure revolves around several key tables that form the foundation of page storage and history tracking. Thepage table serves as the central registry for all pages, containing essential fields such as page_id (an auto-incrementing primary key), page_namespace (an integer indicating the page's namespace, like 0 for main articles), page_title (the page title as a varbinary string), page_latest (referencing the most recent revision ID), and page_is_redirect (a boolean flag). This table enables efficient lookups and navigation without storing the full content directly.[57][58]
Revisions are managed through the revision table, which links to the page table and records changes over time. Key fields include rev_id (primary key), rev_page (foreign key to page_id), rev_actor (foreign key to the actor table for the editing user, introduced in 1.31), rev_timestamp (the edit time in binary format), rev_comment (edit summary), and rev_text_id (referencing the content in the text table). Multiple revisions can share the same text if only metadata changes, promoting storage efficiency. The text table holds the actual page content in the old_text field (a longtext or mediumblob type), alongside old_id (primary key) and old_flags (a set of flags indicating compression or serialization methods applied to the text). This separation allows revisions to reference shared content blobs.[59][58][58]
Tracking recent activity occurs via the recentchanges table, which logs edits, uploads, and other modifications for features like watchlists and recent changes pages. Notable fields are rc_id (primary key), rc_this_oldid (the revision ID of the change), rc_user (user ID, deprecated in favor of rc_actor since 1.31), rc_timestamp (change time), rc_type (integer for edit type, e.g., 0 for new, 1 for edit), and rc_title (the affected page title). This table supports real-time monitoring but is not the primary storage for historical data.[60][58]
To handle large-scale wikis, MediaWiki implements advanced storage strategies for text content. Large texts are offloaded to external storage via the blobs table in a dedicated database, configured through the $wgExternalSharedDB setting in LocalSettings.php. This table uses blob_id (primary key, often a hash) and blob_data (longblob) to store raw content, reducing load on the main wiki database and enabling sharding across servers. Content is referenced by IDs in the text or slots structures rather than inline storage. Additionally, text compression is applied using flags in old_flags to minimize database size; Wikimedia productions achieve near 98% compression ratios through optimized methods like internal serialization and zlib where available.[61][62][24]
Introduced in MediaWiki 1.32, multi-content revisions (MCR) extend the model to support multiple content types per page via slots, allowing diverse formats like wikitext, JSON, or custom models in a single revision. The slots table (new in MCR) includes fields like slot_revision_id (foreign key to rev_id), slot_role_id (role such as 'main' or 'aux'), slot_content_model (integer for model ID), and slot_content_id (referencing content in content or content_models tables). The content table stores model-specific data with content_id, content_model, content_address (blob location), and content_size. This slot-based approach enables granular updates to specific content parts without rewriting the entire revision, enhancing flexibility for extensions handling structured or multilingual content. Legacy single-content pages are migrated to use a single 'main' slot.[63][64][65]
Metadata for relationships and organization is stored in dedicated tables to facilitate queries and features like "what links here." The categorylinks table records category memberships with cl_from (page_id), cl_to (category title in normalized form), cl_sortkey (custom sort key), cl_timestamp (addition time), and cl_collation (sorting rules since 1.17). Similarly, the imagelinks table tracks image usages with il_from (page_id), il_to (image filename), and il_caption (caption if present). Other link types use analogous tables like pagelinks for inter-page links and templatelinks for template inclusions. These denormalized structures optimize common operations but require updates during edits. For structured data, MediaWiki supports JSON storage in dedicated slots (e.g., via the JSON content model) or as JSON fields in tables like page_props (key-value pairs since 1.21), enabling extensions to manage machine-readable metadata without altering core content storage.[66][67][68]
Maintenance of the database involves mechanisms for deferred processing and cache rebuilding to ensure consistency and performance. The job queue, implemented via tables like job (with fields job_cmd, job_namespace, job_title, job_params as blob), manages asynchronous tasks such as updating link tables, refreshing caches, or processing uploads after an edit. Deferred updates are enqueued during page saves to avoid blocking user requests; jobs are executed by the runJobs.php maintenance script or incrementally during web requests. For localization, the rebuildLocalisationCache.php script regenerates the cache of interface messages and translations from extension files and wiki pages, invoked after upgrades or customizations to resolve missing keys or outdated strings.[69][70][71]
Performance and scalability
MediaWiki employs a multi-layered caching strategy to enhance performance, particularly for high-traffic installations. The object cache serves as a key component, storing transient data such as database query results and session information in distributed systems like Memcached or Redis, thereby reducing database load and improving response times for repeated operations.[72] The parser cache complements this by retaining the fully rendered HTML output of wiki pages, avoiding the computationally intensive re-parsing of wikitext, templates, and extensions on subsequent requests.[73] For full-page caching, MediaWiki integrates with reverse proxies such as Varnish, which stores complete HTTP responses at the edge, significantly decreasing server-side processing for anonymous users and static content delivery.[74] To handle large-scale deployments, MediaWiki leverages horizontal scaling techniques enabled by its stateless architecture, where application state is externalized to shared caches or databases, allowing multiple PHP application servers to process requests interchangeably without session affinity requirements.[24] Load balancers, such as Linux Virtual Server (LVS) combined with PyBal in Wikimedia's setup, distribute traffic across these servers to ensure even utilization and fault tolerance.[24] On the database side, read replication—using master-slave configurations in MariaDB—scales query handling by directing reads to replicas, while write operations remain on the primary; sharding is explored for extreme scales but typically involves custom partitioning of tables like revisions or external storage to distribute load across clusters.[75][76] Optimization tools further support efficient operation in demanding environments. Purge mechanisms allow targeted cache invalidation, either via the API for individual pages or maintenance scripts like PurgeList.php for bulk operations, ensuring updated content is promptly reflected without manual intervention across caches.[77] The job queue system defers resource-intensive tasks, such as thumbnail generation or link updates, to background processes executed by runners like the maintenance script runJobs.php or dedicated services such as mediawiki-job-runner, which process queues asynchronously to prevent web request delays.[69][78] Profiling capabilities, integrated through extensions or PHP tools like Xdebug for detailed function-level tracing and Tideways for low-overhead production monitoring, help identify bottlenecks in code execution and query patterns.[79] Recent enhancements in MediaWiki 1.43, a long-term support release, include improved namespace management that streamlines page resolution and reduces associated database query overhead.[80] The version also bolsters compatibility with PHP 8.1 and later, enabling just-in-time (JIT) compilation for faster script execution, and expands asynchronous handling through refined job queue integrations for better concurrency in maintenance tasks.[14][81]Extensibility and Customization
Extension system
MediaWiki's extension system provides a modular framework for extending the software's functionality without modifying the core codebase. Extensions integrate through a hook-based architecture that allows developers to inject custom code at specific points during MediaWiki's execution, such as page rendering or user authentication. This design promotes reusability and maintainability, enabling extensions to alter behavior in a targeted manner.[82] Central to the architecture are hooks, which are predefined events in the MediaWiki lifecycle where extensions can register callback functions. For instance, the BeforePageDisplay hook permits extensions to make final adjustments to the output page, such as injecting CSS or JavaScript, just before it is sent to the user's browser. Extensions declare their hooks and other metadata in an extension.json file, which is processed by MediaWiki's ExtensionRegistry during initialization; this includes validation via the ExtensionRegistrar to ensure proper loading and compatibility. Since MediaWiki 1.25, extensions have supported Composer integration for dependency management, allowing seamless inclusion of PHP libraries while maintaining a skin-independent design that operates on core processes rather than UI-specific elements.[82][83][84][85] Installing extensions typically involves downloading the extension files and placing them in the extensions/ directory of a MediaWiki installation. For extensions supporting Composer, administrators can use the commandcomposer require mediawiki/extension-name --no-update followed by composer update to handle dependencies automatically. Activation occurs by adding wfLoadExtension( 'ExtensionName' ); to the LocalSettings.php configuration file. If the extension requires database schema changes, such as adding tables, running the maintenance script php maintenance/update.php is necessary to apply updates safely.[86][87][88][89]
Over 1,500 extensions are available through the official repository at mediawiki.org, categorized into core-like utilities that enhance fundamental features—such as the Cite extension for reference management—and optional add-ons for specialized tasks like multimedia integration or workflow automation. These extensions undergo validation during registration to confirm adherence to MediaWiki's standards, ensuring broad compatibility across installations.[90]
Extension development emphasizes best practices to ensure reliability and internationalization (i18n). Developers must use MediaWiki's localization system, including wfMessage() for message handling and submission to Translatewiki.net for translations, with unique prefixes to avoid conflicts. Comprehensive unit testing is recommended using PHPUnit, with tests placed in tests/phpunit/unit/ for isolated logic or tests/phpunit/integration/ for database interactions via MediaWikiUnitTestCase and MediaWikiIntegrationTestCase. Development incorporates modular architectures, dependency injection, PSR-4 autoloading, and the Wikimedia\Rdbms library to support multiple database backends without relying on global state.[91]
Templates and Lua integration
MediaWiki's templating system enables the reuse of content across pages through transclusion, where templates—pages in the Template namespace—are included via the syntax{{Template name|param1=value1|param2=value2}}. This mechanism supports parameterized content, allowing values to be passed and substituted dynamically during page rendering.[92]
Templates integrate parser functions for conditional and branching logic, including #if for simple true/false evaluations and #switch for multi-case selections based on input parameters. Magic words, such as {{CURRENTTIME}} for inserting the current server time or {{PAGENAME}} for the current page title, further enhance dynamism by providing access to runtime variables without additional scripting. To mitigate risks of infinite recursion or performance degradation from deep nesting, MediaWiki enforces limits: the expansion depth is capped at 100 levels (since version 1.38), with each template inclusion counting as two units and each parser function as one; exceeding this triggers an "Expansion depth limit exceeded" error and categorizes the page accordingly.[93][94]
Lua integration arrives via the Scribunto extension, introduced in MediaWiki 1.20, which embeds Lua as a scripting language for executing complex operations directly in wiki content. Lua code resides in pages under the Module namespace and is invoked using the parser function {{#invoke:Module name|function name|arg1|arg2}}, allowing modules to return wikitext or HTML for seamless inclusion. Execution occurs in a sandboxed environment, isolated per invocation with configurable resource constraints—defaulting to 50 MB memory and 7 seconds of CPU time—to prevent resource exhaustion or security vulnerabilities from untrusted code.[95]
Within Lua modules, the frame object serves as the primary interface to the calling context, with frame:arguments providing a table of all passed parameters, including positional and named ones, for programmatic manipulation akin to template substitution but with full scripting capabilities like loops, conditionals, and data structures. Parent frames can be accessed via frame:getParent() to inherit arguments from enclosing templates, supporting hierarchical logic.[96]
These features power practical applications such as infoboxes for standardized article layouts, automated citation formatting to ensure compliance with style guides, and data processing for generating dynamic tables from structured inputs. Templates and modules offer wiki-specific customization, where local overrides replace shared or imported versions by simply creating identically named pages in the Template or Module namespaces, allowing site administrators to tailor behavior without altering core code. Integration with CSS occurs through the TemplateStyles extension for scoped styling of template output, while JavaScript in skins or gadgets can extend interactivity, such as expanding collapsible sections within templated content.[97][25]
Specialized extensions
MediaWiki's specialized extensions extend its core functionality to support advanced content creation, data management, and user protection through modular plugins. These extensions leverage MediaWiki's extension system to integrate specialized tools without altering the base software. They are particularly valuable for wikis handling academic, multimedia, or collaborative data projects, enabling features like structured querying and enhanced editing interfaces.Text and Academic Extensions
The Cite extension facilitates the creation of footnotes and references using parser hooks such as<ref> for inline citations and <references> for rendering them at the page bottom, supporting academic and encyclopedic writing standards.[98] SyntaxHighlight, previously known as SyntaxHighlight_GeSHi, enables syntax highlighting for source code snippets via the <syntaxhighlight> tag, utilizing Pygments for over 500 languages to aid technical documentation.[99] For mathematical content, the Math extension incorporates MathJax as a JavaScript-based renderer to typeset TeX and LaTeX formulas within math environments like <math>, offering an accessible alternative to server-side rendering and improving browser compatibility.[100]
Search and Queries
CirrusSearch enhances MediaWiki's search capabilities by integrating Elasticsearch (with a planned migration to OpenSearch), providing full-text search, relevance ranking, and features like search-as-you-type suggestions as the default engine for many installations.[101] Semantic MediaWiki adds structured data management, allowing users to annotate pages with properties and perform queries resembling SPARQL to generate dynamic reports, tables, and maps from wiki content.[102]Rich Content and Integration
VisualEditor introduces a what-you-see-is-what-you-get (WYSIWYG) editing interface powered by a JavaScript library, enabling rich-text manipulation of content, templates, and citations without requiring wikitext knowledge.[32] MultimediaViewer improves media handling by overlaying full- or near-full-size images and videos directly in the browser, displaying metadata and navigation controls for better user engagement with visual assets.[103] The OAuth extension implements an OAuth server supporting versions 1.0a and 2.0, allowing secure authentication and API access for third-party applications.[47] Wikibase provides a framework for structured data repositories, enabling the storage, querying, and linking of entities and properties, as prominently used in Wikidata for collaborative knowledge bases.[104]Search Engine Optimization Extensions
MediaWiki supports search engine optimization (SEO) through various extensions that enhance the visibility of wiki content in search engine results. A dedicated category on MediaWiki.org lists 15 such extensions.[105] One example is the RichResults extension, which adds JSON-LD structured data to article pages based on Schema.org standards, improving search engine understanding of content and enabling rich snippets in search results.[106]Anti-Spam and Other
ConfirmEdit integrates CAPTCHA mechanisms, including image recognition and simple math challenges, to deter automated spam edits and registrations on public wikis.[107] AbuseFilter empowers administrators to define conditional rules based on edit patterns, triggering actions like warnings, blocks, or reverts to mitigate vandalism proactively.[108] Recent developments in 2025, such as the Moderator Tools project, introduce enhancements for recent changes review, including automoderator for AI-assisted reverts and improved filtering interfaces to streamline moderation workflows.[109]Security and Reliability
Security features
MediaWiki implements several built-in mechanisms for authentication and authorization to safeguard user sessions and prevent unauthorized actions. Session management is coordinated by the SessionManager and AuthManager frameworks, introduced in version 1.27, which handle authentication providers, session creation, and renewal while supporting multiple authentication methods without exposing sensitive credentials.[110] Cross-site request forgery (CSRF) attacks are countered through the use of edit tokens, random strings generated for each session and required for data-modifying actions like edits or deletions, ensuring requests cannot be forged from external sites.[111] Brute-force login attempts are limited by the $wgPasswordAttemptThrottle configuration variable, which restricts the number of failed password tries per IP address over a specified period to thwart automated attacks.[112] For added protection, two-factor authentication (2FA) is available via the OATHAuth extension, which integrates time-based one-time passwords (TOTP) compliant with RFC 6238, requiring users to enter a code from an authenticator app alongside their password.[52] Content security in MediaWiki focuses on neutralizing threats from untrusted input through rigorous sanitization and validation processes. User-supplied content, including wiki markup and HTML, is processed by the core Sanitizer class, which escapes potentially malicious code to prevent cross-site scripting (XSS) vulnerabilities during output rendering by the parser.[24][113] This includes stripping or encoding dangerous elements like JavaScript in attributes or scripts, while allowing safe HTML tags defined in $wgAllowedHtmlTagsByNamespace. For file uploads, MediaWiki enforces MIME type verification, size limits, and basic integrity checks to block executable content; advanced malware scanning, such as integration with VirusTotal for image analysis, can be achieved through third-party extensions or custom hooks like UploadVerifyUpload for external API calls.[114] Audit and response capabilities enable administrators to monitor and react to potential threats effectively. Detailed logging of actions such as edits, uploads, and user changes is provided via the LogFormatter class, which structures entries for display on Special:Log, supporting custom formatting through wgRateLimits, an array defining thresholds for actions like API calls or edits per user or IP, helping to curb denial-of-service attempts and spam floods by temporarily blocking excessive requests.[115] The project maintains security through regular releases addressing identified vulnerabilities; for instance, MediaWiki 1.43 included patches for multiple CVEs, such as CVE-2025-32699 related to Parsoid denial-of-service issues.[33] Adhering to security best practices is essential for MediaWiki deployments, particularly for protecting data in transit and at rest. HTTPS enforcement is facilitated by wgSecretKey, a site-specific random string used for hashing session IDs and tokens, which must be generated securely (e.g., via wfGenerateSecretKey()) and stored outside version control to prevent token forgery or session hijacking.[55] To support GDPR compliance, MediaWiki offers tools for data retention policies, including Special:UserRights for managing user data access, revision deletion for sensitive content removal, and export features via Special:Export or the DataDump extension, enabling right-to-be-forgotten requests and audit trails for personal data processing.[116]Limitations and workarounds
MediaWiki faces scalability challenges primarily due to parser overhead when rendering complex pages with numerous transclusions or templates, which can significantly increase processing time during page loads.[117] In high-write environments, database lock contention arises from the software's transaction model, where concurrent edits lead to bottlenecks as MediaWiki prioritizes consistency, potentially crippling performance on large wikis.[118] To mitigate these, administrators commonly implement parser caching to store rendered HTML output, reducing recomputation for subsequent views, and object caching layers like Memcached for session and query data.[73] Additionally, offloading non-critical operations to asynchronous job queues helps alleviate database pressure by deferring tasks such as email notifications or image processing.[119] The software has inherent feature gaps, including limited native support for real-time collaborative editing, where simultaneous changes by multiple users are not seamlessly synchronized without external tools.[120] This is partially addressed through extensions like DiscussionTools, which succeeded the earlier Flow (Structured Discussions) extension and provides structured threading, reply widgets, and better readability on talk pages, though it focuses on asynchronous discussions rather than live co-editing.[121] Mobile editing remains frictional, with challenges such as complex interfaces for unregistered users and limitations in advanced features like visual editing on smaller screens, despite ongoing improvements in responsive design and tools like Edit Check for previewing changes.[122][123] Compatibility issues persist with legacy PHP versions, as MediaWiki 1.42 and later require PHP 8.1 or higher, ending support for PHP versions below 8.1 in earlier releases such as 1.39–1.41 that could run on PHP 7.4 or higher, and much older installations like 1.31 on PHP 7.0 or higher.[124][125] Extension conflicts often stem from overlapping hooks, database schema mismatches, or PHP version incompatibilities, leading to errors during updates or activations.[126] Workarounds include containerization via official Docker images, available since MediaWiki 1.31 for easier dependency management and isolated environments, alongside detailed migration guides that outline backups, job clearing, and stepwise upgrades.[56][127] As of 2025, critiques highlight challenges in integrating AI-generated content, such as ensuring accuracy, attribution, and alignment with editorial policies in wiki environments, which can introduce biases or low-quality additions without robust moderation.[128] Experimental extensions like Content Translation address this by leveraging machine translation AI to assist multilingual content creation, providing suggestions while requiring human review, though full AI content generation remains cautiously experimental to maintain reliability.[129][130]Deployment and Ecosystem
Notable uses
MediaWiki powers the Wikimedia Foundation's suite of projects, including Wikipedia across over 300 language editions, Wiktionary, Wikibooks, Wikidata, Wikimedia Commons, and MediaWiki itself.[131] These sites collectively handle approximately 24 billion pageviews per month as of October 2025, demonstrating MediaWiki's capacity for massive-scale collaborative editing and content delivery.[132] Wikipedia alone, with its 338 active language versions, exemplifies how MediaWiki supports multilingual content creation, where non-English editions have seen steady growth, contributing to over 80% of the total article count in recent years.[132] Beyond Wikimedia, Fandom (formerly Wikia) operates a large network of fan-hosted wikis using MediaWiki version 1.43.1, upgraded in late 2025 to enhance performance and features like interactive maps.[133][134] Other prominent public installations include community-driven sites like the Arch Linux wiki for technical documentation and Appropedia for sustainable technology resources.[135] In government and research sectors, MediaWiki facilitates knowledge sharing in secure environments. NASA employs it for quality work instructions, engineering documentation, and avoiding operational mishaps at facilities like the Glenn Research Center, with installations dating back over a decade and ongoing enhancements as of 2025.[136][137] CERN maintains CERNipedia, a local MediaWiki instance for internal documentation and workflows, integrating scraped data from organizational sources.[138] The U.S. Department of State uses Diplopedia, an internal wiki for diplomatic knowledge management since 2008.[139] Enterprise adaptations leverage distributions like BlueSpice, which extends MediaWiki for private intranets in mid-sized companies, supporting features such as WYSIWYG editing, Elasticsearch search, and collaborative documentation in over 150 countries.[140] Academic and non-profit platforms, including legal wikis like Clicklaw for public access to Canadian law resources, highlight MediaWiki's versatility for specialized content.[135] As of 2025, approximately 30,000 live websites worldwide use MediaWiki, with roughly 30,000 public wikis tracked across directories, underscoring its broad adoption.[141] Wikipedia's scalability strategies, such as sharding and caching, have informed adaptations in these uses, enabling high-traffic non-English installations to handle growing user bases without proportional infrastructure increases.[132]Development and support
MediaWiki follows an open-source development model centered on collaborative code review and regular releases. Since its migration to Git in 2012, the project has utilized Gerrit as the primary code review platform, where proposed changes are scrutinized for quality, security, and adherence to coding standards before merging into the core codebase.[142][11] Development is driven by a mix of volunteer contributors and those funded by the Wikimedia Foundation, with approximately 200 active participants contributing to the core and extensions.[143] The release cycle includes minor updates every quarter for security patches and bug fixes, major versions every six months, and long-term support (LTS) branches every two years, ensuring a one-year overlap for stable upgrades.[144] Support for MediaWiki is provided through a robust ecosystem of community-driven resources. Comprehensive documentation is hosted on MediaWiki.org, covering installation, configuration, and troubleshooting. Bug reports and feature requests are managed via Phabricator, an open-source task tracking system used by the Wikimedia Foundation.[145] Real-time discussions occur on IRC channels via Libera.Chat and internal Slack workspaces for Wikimedia staff and select collaborators.[146][147] Annual events, such as the MediaWiki Users & Developers Conference, facilitate in-person collaboration and knowledge sharing among developers and users.[148] For enterprise needs, professional vendor support is available from firms like WikiTeq, offering managed hosting, customization, and maintenance services.[149] MediaWiki has been licensed under the GNU General Public License version 2 or later (GPL v2+) since its inception, enforcing copyleft requirements that mandate derivative works to adopt the same license, thereby promoting open-source reuse while restricting proprietary modifications.[150] Compared to alternatives, MediaWiki stands out for its scalability in large-scale collaborative environments but may require more setup than simpler options. DokuWiki, for instance, uses a file-based storage system without a database, making it lighter and easier for small teams or personal use.[151] Confluence, a proprietary Atlassian product, targets enterprise settings with integrated project management but lacks MediaWiki's open extensibility.[152] Modern tools like Outline emphasize markdown editing and intuitive interfaces for quick documentation, though they fall short of MediaWiki's depth in handling massive, multilingual content repositories.[153]References
- https://www.mediawiki.org/wiki/MediaWiki_history
- https://www.mediawiki.org/wiki/Manual:MediaWiki_feature_list
- https://www.mediawiki.org/wiki/MediaWiki
- https://www.mediawiki.org/wiki/Developer_hub
- https://www.mediawiki.org/wiki/MediaWiki_1.35
- https://www.mediawiki.org/wiki/MediaWiki_1.39
- https://www.mediawiki.org/wiki/MediaWiki_1.43
- https://www.mediawiki.org/wiki/MediaWiki_1.44
- https://www.mediawiki.org/wiki/Release_notes
- https://www.mediawiki.org/wiki/Events
- https://www.mediawiki.org/wiki/MediaWiki_Users_and_Developers_Conference_Fall_2025
- https://www.mediawiki.org/wiki/VisualEditor
- https://www.mediawiki.org/wiki/Parsoid
- https://www.mediawiki.org/wiki/Design_and_development_principles
- https://www.mediawiki.org/wiki/Help:History
- https://www.mediawiki.org/wiki/Manual:MediaWiki_architecture
- https://www.mediawiki.org/wiki/Help:TemplateStyles
- https://www.mediawiki.org/wiki/Accessibility
- https://www.mediawiki.org/wiki/Localisation
- https://www.mediawiki.org/wiki/Readers/Structured_Content
- https://www.mediawiki.org/wiki/Wikitext
- https://www.mediawiki.org/wiki/Help:Formatting
- https://www.mediawiki.org/wiki/Help:Wikitext_examples
- https://www.mediawiki.org/wiki/Extension:VisualEditor
- https://www.mediawiki.org/wiki/Release_notes/1.43
- https://www.mediawiki.org/wiki/Help:Recent_changes
- https://www.mediawiki.org/wiki/Help:Links
- https://www.mediawiki.org/wiki/Help:Namespaces
- https://www.mediawiki.org/wiki/Manual:Using_custom_namespaces
- https://www.mediawiki.org/wiki/Manual:Namespace
- https://www.mediawiki.org/wiki/Help:Categories
- https://www.mediawiki.org/wiki/Special:AllPages
- https://www.mediawiki.org/wiki/User:Cpiral/CirrusSearch
- https://www.mediawiki.org/wiki/Skin:Minerva_Neue
- https://www.mediawiki.org/wiki/Help:Logging_in
- https://www.mediawiki.org/wiki/Manual:Preventing_access
- https://www.mediawiki.org/wiki/Extension:OAuth
- https://www.mediawiki.org/wiki/Help:Preferences
- https://www.mediawiki.org/wiki/Manual:User_rights
- https://www.mediawiki.org/wiki/Help:Protected_pages
- https://www.mediawiki.org/wiki/OOUI/Windows/Process_Dialogs
- https://www.mediawiki.org/wiki/Extension:OATHAuth
- https://www.mediawiki.org/wiki/Manual:Installation_requirements
- https://www.mediawiki.org/wiki/Manual:Installing_MediaWiki
- https://www.mediawiki.org/wiki/Manual:Configuration_settings
- https://www.mediawiki.org/wiki/Manual:Upgrading
- https://www.mediawiki.org/wiki/Manual:Page_table
- https://www.mediawiki.org/wiki/Manual:Database_layout
- https://www.mediawiki.org/wiki/Manual:Revision_table
- https://www.mediawiki.org/wiki/Manual:Recentchanges_table
- https://www.mediawiki.org/wiki/Manual:External_storage
- https://www.mediawiki.org/wiki/Manual:Blobs_table
- https://www.mediawiki.org/wiki/Multi-Content_Revisions
- https://www.mediawiki.org/wiki/Manual:Slot
- https://www.mediawiki.org/wiki/Multi-Content_Revisions/Database_Schema
- https://www.mediawiki.org/wiki/Manual:Categorylinks_table
- https://www.mediawiki.org/wiki/Manual:Imagelinks_table
- https://www.mediawiki.org/wiki/Manual:Managing_data_in_MediaWiki
- https://www.mediawiki.org/wiki/Manual:Job_queue
- https://www.mediawiki.org/wiki/Manual:Job_queue/For_developers
- https://www.mediawiki.org/wiki/Manual:Common_errors_and_symptoms
- https://www.mediawiki.org/wiki/Object_cache
- https://www.mediawiki.org/wiki/Manual:Parser_cache
- https://www.mediawiki.org/wiki/Manual:Varnish_caching
- https://wikitech.wikimedia.org/wiki/Data_Platform/Systems/MediaWiki_replicas
- https://www.mediawiki.org/wiki/Wikimedia_Developer_Summit/2017/Scaling_the_Wikimedia_database_schema
- https://www.mediawiki.org/wiki/API:Purge
- https://wikitech.wikimedia.org/wiki/History_of_job_queue_runners_at_WMF
- https://www.mediawiki.org/wiki/Manual:Profiling
- https://www.mediawiki.org/wiki/Manual:Hooks
- https://www.mediawiki.org/wiki/Manual:Hooks/BeforePageDisplay
- https://www.mediawiki.org/wiki/Manual:Extension_registration
- https://www.mediawiki.org/wiki/Composer
- https://www.mediawiki.org/wiki/Manual:Extensions/Installation_and_upgrade
- https://www.mediawiki.org/wiki/Composer/For_extensions
- https://www.mediawiki.org/wiki/Manual:LocalSettings.php
- https://www.mediawiki.org/wiki/Manual:update.php
- https://www.mediawiki.org/wiki/Category:All_extensions
- https://www.mediawiki.org/wiki/Best_practices_for_extensions
- https://www.mediawiki.org/wiki/Help:Transclusion
- https://www.mediawiki.org/wiki/Help:Magic_words
- https://www.mediawiki.org/wiki/Manual:Template_limits
- https://www.mediawiki.org/wiki/Extension:Scribunto
- https://www.mediawiki.org/wiki/Extension:Scribunto/Lua_reference_manual
- https://www.mediawiki.org/wiki/Help:Templates
- https://www.mediawiki.org/wiki/Extension:Cite
- https://www.mediawiki.org/wiki/Extension:SyntaxHighlight
- https://www.mediawiki.org/wiki/Extension:Math
- https://www.mediawiki.org/wiki/Extension:CirrusSearch
- https://www.mediawiki.org/wiki/Extension:Semantic_MediaWiki
- https://www.mediawiki.org/wiki/Extension:MultimediaViewer
- https://www.mediawiki.org/wiki/Extension:Wikibase
- https://www.mediawiki.org/wiki/Category:Search_engine_optimization_extensions
- https://www.mediawiki.org/wiki/Extension:RichResults
- https://www.mediawiki.org/wiki/Extension:ConfirmEdit
- https://www.mediawiki.org/wiki/Extension:AbuseFilter
- https://www.mediawiki.org/wiki/Moderator_Tools
- https://www.mediawiki.org/wiki/Manual:SessionManager_and_AuthManager
- https://www.mediawiki.org/wiki/Manual:Edit_token
- https://www.mediawiki.org/wiki/Manual:%24wgPasswordAttemptThrottle
- https://www.mediawiki.org/wiki/Cross-site_scripting
- https://www.mediawiki.org/wiki/Manual:Configuring_file_uploads
- https://www.mediawiki.org/wiki/Manual:%24wgRateLimits
- https://www.mediawiki.org/wiki/Manual:FAQ
- https://www.mediawiki.org/wiki/Manual:Database_access
- https://wikitech.wikimedia.org/wiki/MediaWiki_Engineering/Guides/Backend_performance_practices
- https://www.mediawiki.org/wiki/VisualEditor/Real-time_collaboration
- https://www.mediawiki.org/wiki/Extension:DiscussionTools
- https://www.mediawiki.org/wiki/Reading/Web/Advanced_mobile_contributions
- https://www.mediawiki.org/wiki/Download
- https://www.mediawiki.org/wiki/Release_notes/1.42
- https://www.mediawiki.org/wiki/Extension:ContentTranslation
- https://meta.wikimedia.org/wiki/Artificial_intelligence
- https://meta.wikimedia.org/wiki/Our_projects
- https://www.mediawiki.org/wiki/Fandom
- https://www.mediawiki.org/wiki/Sites_using_MediaWiki/en
- https://en.wikinews.org/wiki/Wikimania_2008:_MediaWiki_use_in_the_U.S._Department_of_State
- https://www.mediawiki.org/wiki/Gerrit
- https://www.mediawiki.org/wiki/Version_lifecycle
- https://www.mediawiki.org/wiki/Phabricator
- https://www.mediawiki.org/wiki/MediaWiki_on_IRC
- https://www.mediawiki.org/wiki/Editing_team
- https://www.mediawiki.org/wiki/Copyright