A short guide to install Mediawiki on Debian with PostgreSQL 9.1.With a fix for this error:
"Attempting to connect to database "postgres" as superuser "postgres"... error: No database connection"
Installing packages
The server is still using Debian Squeeze, but I expect it would quite the same for the new Debian Wheezy. Here I used squeeze-backports.
Add the backports repository if needed:
echo "deb http://backports.debian.org/debian-backports squeeze-backports main contrib non-free" >> /etc/apt/sources.list
Install everything:
apt-get update
apt-get -t squeeze-backports install apache2 postgresql-9.1 postgresql-contrib php5-pgsql
apt-get -t squeeze-backports install imagemagick libdbd-pg-perl
apt-get -t squeeze-backports install mediawiki
I use a separate IP for the wiki, so need to add it to the interface:
mcedit /etc/network/interfaces
# wiki on it's own IP
auto eth0:3
iface eth0:3 inet static
address 192.168.10.4
netmask 255.255.255.0
/etc/init.d/networking restart
Apache configuration
# I use the mod_rewrite module in Apache
a2enmod rewrite
# I prefer the config file in sites-enabled
# (but it's really just a symlink to /etc/mediawiki/apache.conf):
mv /etc/apache2/conf.d/mediawiki.conf /etc/apache2/sites-enabled
My virtual host config:
<VirtualHost *:80>
ServerName wiki.example.lan
ServerAlias wiki.example.lan
ServerAdmin webmaster@example.com
DocumentRoot /docs/www-wiki
ErrorLog /var/log/apache2/wiki-error.log
CustomLog /var/log/apache2/wiki-access.log combined
ServerSignature On
Alias /icons/ "/usr/share/apache2/icons/"
RewriteEngine On
RewriteRule ^/w(iki)?/(.*)$ http://%{HTTP_HOST}/index.php/$2 [L,NC]
<Directory /docs/www-wiki/>
Options +FollowSymLinks
AllowOverride All
# Default is Deny. Exceptions listed below with "Allow ...":
Order Deny,Allow
Deny from All
Satisfy any
# LAN
Allow from 192.168.10.0/24
# VPN
Allow from 10.0.10.0/24
# If using LDAP
# AuthType Basic
# AuthName "Example Wiki. Requires user name and password"
# AuthBasicProvider ldap
# AuthzLDAPAuthoritative on
# AuthLDAPURL ldap://localhost:389/ou=People,dc=example,dc=lan?uid
# AuthLDAPGroupAttribute memberUid
# AuthLDAPGroupAttributeIsDN off
# Require ldap-group cn=users,ou=Groups,dc=example,dc=lan
</Directory>
# some directories must be protected
<Directory /docs/www-wiki/config>
Options -FollowSymLinks
AllowOverride None
</Directory>
<Directory /docs/www-wiki/upload>
Options -FollowSymLinks
AllowOverride None
</Directory>
<Directory "/usr/share/apache2/icons">
Options Indexes MultiViews
AllowOverride None
Order allow,deny
Allow from all
</Directory>
</VirtualHost>
Moving files
I used a directory other than the default /var/lib/mediawiki. So I had to move things over:
cp -rp /var/lib/mediawiki /docs/www-wiki
The only tricky part, with the fix:
Before starting the web configurator in http://wiki.example.lan/config/ you need to define a password for the "postgres" database user. Mediawiki will start the psql
client as the www-data system user, but with the -U argument to set the user to "postgres". Even if you defined a password for the system user "postgres", this is not the password of the database user "postgres".
So you need to start psql as the postgres system user, which you can do as root using sudo -c
, and then set the password inside the psql client:
sudo -u postgres psql
psql (9.1.9)
Type "help" for help.
postgres=# \password
Enter new password:
Enter it again:
postgres=# \q
If you don't do this, the Mediawiki config will end with this error:
Attempting to connect to database "postgres" as superuser "postgres"... error: No database connection
And a big pink and unhelpful error box below.
The Postgresql log (tail /var/log/postgresql/postgresql-9.1-main.log
) will show:
FATAL: password authentication failed for user "postgres"
Finally
Now you just have to move LocalSettings.php to /etc/mediawiki/.
And if you used a different install root, you have to edit it to change the MW_INSTALL_PATH:
define('MW_INSTALL_PATH','/docs/www-wiki');
Labels: code, computers, databases, debian, en, ldap, linux, postgres, sysadmin