|Requirements in short|
In addition to the software itself, a standard MediaWiki installation has the following requirements:
- A web server is required to serve the requested pages to the client browser.
- PHP is required to run the software.
- A database server is required to store the pages and site data.
In addition, there are various optional dependencies which are required if you want to use certain advanced features (see below).
If your website is hosted (i.e. you don't have direct control over it) then contact your server administrator or hosting company to ensure these software packages are installed and available.
Simple one-download installation
If you are using Linux, its best to install apache, php and MariaDB using your package manager. On Debian and Ubuntu, do
sudo apt-get install php php-apc php-intl mariadb-server apache2.
On other operating systems, use XAMPP from http://www.apachefriends.org to install and configure all of the important packages – Apache web server, PHP, and MariaDB – with only one download. It is available for Linux, Windows, Mac and Solaris. As of August 2016, the latest version of XAMPP includes PHP 7.0 (MediaWiki requires at least 5.5.9).
Alternatively, if you have an Apple computer, you can use MAMP, which is the equivalent to XAMPP. MAMP currently includes the ability to run the Apache web server and a MySQL database. It is available for both Windows and Mac, but is generally used on Mac instead of Windows. It is currently running the latest versions of php and MySQL.
In order to serve wiki pages to browsers, MediaWiki requires some web server software. Often you will not have a choice of which software to use – it will be the one provided by your hosting provider.
Most installations use the Apache web server, available at the official download page. However, MediaWiki has also been tested under IIS 7.0, Cherokee, Hiawatha, LiteSpeed, nginx (configuration example), and lighttpd.
PHP is the programming language in which MediaWiki is written, and is required in order to run the software.
Note that although MediaWiki ships with an installation script which provides web-based configuration of the most important elements, some knowledge of PHP is required for more detailed customizations.
- For the latest stable version of MediaWiki, PHP version 5.5.9 or later is required. PHP 7 is generally supported, but PHP 7.1 causes various warnings for MediaWiki 1.28 when some extensions are enabled, see task T153505.
- If you are unable to upgrade to PHP 5.5.9, then you can use MediaWiki 1.23.13, which requires PHP version 5.3.2 or later
- The following extensions are required:
- Note that all of these are enabled in PHP by default.
- MediaWiki's installer will warn if you don't have the optional PHP intl extension "to handle Unicode normalization".
- In most Debian/Ubuntu-based distros, this is in the php5-intl package.
- PHP OpenSSL extension is also recommended. See Manual:$wgSessionInsecureSecrets.
- On most Debian/Ubuntu-based distros, either the php5-mysql or php5-mysqlnd package is required if you want MediaWiki to use MySQL.
- If you are installing MediaWiki on CentOS 5.6, use the
php53package instead of
phppackage contains PHP 5.1.x, which is not compatible with the latest version of MediaWiki.
- If you are installing MediaWiki on Red Hat Enterprise Linux 6.4 (CentOS 6.4), you will need to install the
php-xmlpackage in addition to the normal
- Some features of MediaWiki may require PHP functions that execute external processes, like image thumbnailing, that some cheap hosts usually disable. This has surfaced specially in MediaWiki 1.23 on file uploads (task T68467). Please take this into consideration if you plan to install MediaWiki on a shared host.
- MediaWiki extensions may require additional PHP features, e.g. VisualEditor requires libcurl support (php5-curl on Debian/Ubuntu-based distros).
If you need to compile PHP from source, then see PHP configuration for compilation options that affect MediaWiki.
MediaWiki stores all the text and data (content pages, user details, system messages, etc.) in a database, which it is capable of sharing with other web-based applications (phpBB, etc.). You will need one of the following database servers to run the latest version of MediaWiki:
- MySQL 5.0.2 or later* or MariaDB 5.1+
- PostgreSQL 8.3 or later (supported since MediaWiki 1.8). See Manual:Installing MediaWiki#PostgreSQL for more detail.
- SQLite 3
- Microsoft SQL Server 2008 R2 or later is supported for LTS releases and is not guaranteed to work for non-LTS releases (requires Microsoft Windows as Operating System because it uses the SQLSRV driver)
Supported in the past, currently unsupported:
- Oracle (unsupported on the latest MediaWiki versions due to open blocking bugs)
Note: MySQL 5 has been required since MediaWiki 1.19. MySQL 4 was required starting with MediaWiki 1.6. (If you are using an ancient version of MySQL and cannot upgrade then you need to use MediaWiki 1.5.8, but this version is not supported.)
The recommended minimum requirements are 256MB of RAM for a single-computer website and 85MB of storage, although this will not suffice for a busy public site or a site with uploading enabled. Some users have reported running MediaWiki on computers with as little as 48MB of RAM.
The install size can be reduced to around 50Mb for a developer install and to around 26Mb for a non-developer, end-user install. See Manual:Reduce size of the installation
- ImageMagick or GD is required for image thumbnailing.
- TeX is required for inline display of mathematical formulae. In most Debian/Ubuntu-based distros, this is in the
- Sendmail is required in order for the system to be able to send e-mails.
- Shell access is required to run maintenance scripts; upgrading MediaWiki may be more difficult without it.
For further information about the above items, see Manual:Installing third-party tools.
The VisualEditor extension (and also the Flow extension) requires the Parsoid web service, which is implemented using Node.js. Node.js is not provided by most shared-hosting companies (HostGator, Bluehost, Dreamhost, etc.). For performance and security reasons, it is better to use a dedicated hosting solution such as a Virtual private server ("VPS").
- Software bundles