Difference between revisions of "Mediawiki Install FC6"

From Aktivix
Jump to: navigation, search
(apache conf)
(apache conf)
Line 237: Line 237:
 
</pre>
 
</pre>
  
The the whole VirtualHost in /etc/httpd/conf.d/ssl.conf
+
Create a new file that can be included for error documents, /etc/httpd/conf/error-docs.conf
 +
 
 +
<pre>
 +
# Editor: vim:syn=apache
 +
 
 +
Alias /error/ "/var/www/error/"
 +
<IfModule mod_negotiation.c>
 +
  <IfModule mod_include.c>
 +
    <Directory "/var/www/error">
 +
        AllowOverride None
 +
        Options IncludesNoExec
 +
        AddOutputFilter Includes html
 +
        AddHandler type-map var
 +
        Order allow,deny
 +
        Allow from all
 +
        LanguagePriority en es de fr
 +
        ForceLanguagePriority Prefer Fallback
 +
    </Directory>
 +
    ErrorDocument 400 /error/HTTP_BAD_REQUEST.html.var
 +
    ErrorDocument 401 /error/HTTP_UNAUTHORIZED.html.var
 +
    ErrorDocument 403 /error/HTTP_FORBIDDEN.html.var
 +
    ErrorDocument 404 /error/HTTP_NOT_FOUND.html.var
 +
    ErrorDocument 405 /error/HTTP_METHOD_NOT_ALLOWED.html.var
 +
    ErrorDocument 408 /error/HTTP_REQUEST_TIME_OUT.html.var
 +
    ErrorDocument 410 /error/HTTP_GONE.html.var
 +
    ErrorDocument 411 /error/HTTP_LENGTH_REQUIRED.html.var
 +
    ErrorDocument 412 /error/HTTP_PRECONDITION_FAILED.html.var
 +
    ErrorDocument 413 /error/HTTP_REQUEST_ENTITY_TOO_LARGE.html.var
 +
    ErrorDocument 414 /error/HTTP_REQUEST_URI_TOO_LARGE.html.var
 +
    ErrorDocument 415 /error/HTTP_UNSUPPORTED_MEDIA_TYPE.html.var
 +
    ErrorDocument 500 /error/HTTP_INTERNAL_SERVER_ERROR.html.var
 +
    ErrorDocument 501 /error/HTTP_NOT_IMPLEMENTED.html.var
 +
    ErrorDocument 502 /error/HTTP_BAD_GATEWAY.html.var
 +
    ErrorDocument 503 /error/HTTP_SERVICE_UNAVAILABLE.html.var
 +
    ErrorDocument 506 /error/HTTP_VARIANT_ALSO_VARIES.html.var
 +
  </IfModule>
 +
</IfModule>
 +
</pre>
 +
 
 +
And the whole VirtualHost in /etc/httpd/conf.d/ssl.conf was commented out.
  
 
== General FC6 configuration ==
 
== General FC6 configuration ==

Revision as of 02:52, 21 January 2007

See also MediaWiki_Install

The documention here is based on the FC6 mediawiki and having multiple wiki's running all on the same ip address, on different domain names, with all http port 80 requests redirected to port 443 and a CAcert cert with all the domain names.

Install

Fedora Core six has packaged mediawiki, and also seems to come with more apache packages that needed:

rpm -e mod_python mod_perl
yum install mediawiki mysql-server php-eaccelerator
chkconfig mysqld on
chkconfig httpd on
service mysqld start
service httpd start
mysqladmin -u root password 'new-password'

Then, following the wiki farm notes

elinks http://localhost/mediawiki/config/index.php

The fill in the following values (the rest can be the defaults):

Wiki name:             TestWiki1
Contact e-mail:        mediawiki @ aktivix.org
Admin username:        WikiSysop
Password:              *****
Password cobfirm:      *****
Shared memory caching: 
  * (X) eAccelerator
Database name:         testwiki1
DB username:           testwiki1user
DB password:           *****
DB password confirm:   *****
Superuser account:     root
Superuser password:    *****

Create a MySQL account for AdminSettings.php:

mysql -uroot -p mysql
mysql> GRANT ALL PRIVILEGES ON *.* TO 'wikiadmin'@'localhost'
  -> IDENTIFIED BY '****' WITH GRANT OPTION;
Query OK, 0 rows affected (0.00 sec)

And move the sample file and then add the password to it:

cd /var/www/mediawiki
mv AdminSettings.sample AdminSettings.php

Then

cd /var/www/mediawiki
mv config/LocalSettings.php LocalSettings.php
chown root.root LocalSettings.php 
chmod 644 LocalSettings.php 

Then restart apache and the wiki should be working at http://localhost/mediawiki/

Next add a new wiki site.

Create this script, which is based on this document:

 #!/bin/bash
 
 if [[ -z $1 ]]; then
   echo "The first argument should be the new wiki name"
 fi
 
 BASE_DIR="/var/www"
 WIKI_NAME="$1"
 
 if [[ -d $BASE_DIR/$WIKI_NAME ]]; then
   echo "$WIKI_NAME appears to be in use"
   exit
 fi
 
 # make the directory for the site
 mkdir $BASE_DIR/$WIKI_NAME
 
 # change to the sites directory
 cd $BASE_DIR/$WIKI_NAME
 
 #make some dirs 
 mkdir {images,config}
 
 # fix the ownership
 chown -R apache.apache {images,config}
 
 # create the sym link tree
 for name in `ls ../mediawiki`
 do
   if [[ -e $name ]]; then
     echo "$name exists already, skipping" 
   else
     ln -s ../mediawiki/$name
   fi
 done
 
 # remove the LocalSettings.php sym link
 if [[ -L LocalSettings.php ]]; then
   rm LocalSettings.php
 else
   if [[ -f LocalSettings.php ]]; then
     echo "LocalSettings.php already exists"
   else
     echo "LocalSettings.php doesn't exist"
   fi
 fi

Redirecting port 80 to 443, create /var/www/cgi-bin/index.pl

#!/usr/bin/perl -wT 

# Redirect all http requests to https
my $server_name = "$ENV{'SERVER_NAME'}";
my $location = "";
my $path_info = "$ENV{'PATH_INFO'}";

# for some sites we need an extra redirect if www is missed off
if ($server_name eq "sheffieldagainstwar.org.uk") {
  $server_name = "https://www.sheffieldagainstwar.org.uk";
}
else {
  $server_name = "$ENV{'SERVER_NAME'}";
}

# construct the url and redirect
$location = "https://" . "$server_name" . "$path_info";
print qq~Location: $location

~;

1;

And an apache conf file, /etc/httpd/conf.d/vhosts.conf

# Editor: vim:syn=apache

NameVirtualHost *:80
<VirtualHost>
  ServerName wiki.aktivix.org
  ServerSignature Off
  UseCanonicalName Off
  AddDefaultCharset UTF-8
  ScriptAlias / "/var/www/cgi-bin/index.pl/"
  <Directory "/var/www/cgi-bin">
    AllowOverride None
    Options ExecCGI
    Order allow,deny
    Allow from all
  </Directory>
</VirtualHost>

NameVirtualHost *:443
Include vhosts.d/*

apache conf

The following things were changed from the defaults in /etc/httpd/conf/httpd.conf

# remove some modules
LoadModule auth_basic_module modules/mod_auth_basic.so
LoadModule auth_digest_module modules/mod_auth_digest.so
#LoadModule authn_file_module modules/mod_authn_file.so
#LoadModule authn_alias_module modules/mod_authn_alias.so
#LoadModule authn_anon_module modules/mod_authn_anon.so
#LoadModule authn_dbm_module modules/mod_authn_dbm.so
#LoadModule authn_default_module modules/mod_authn_default.so
LoadModule authz_host_module modules/mod_authz_host.so
LoadModule authz_user_module modules/mod_authz_user.so
LoadModule authz_owner_module modules/mod_authz_owner.so
#LoadModule authz_groupfile_module modules/mod_authz_groupfile.so
#LoadModule authz_dbm_module modules/mod_authz_dbm.so
#LoadModule authz_default_module modules/mod_authz_default.so
#LoadModule ldap_module modules/mod_ldap.so
#LoadModule authnz_ldap_module modules/mod_authnz_ldap.so
#LoadModule include_module modules/mod_include.so
LoadModule log_config_module modules/mod_log_config.so
#LoadModule logio_module modules/mod_logio.so
LoadModule env_module modules/mod_env.so
#LoadModule ext_filter_module modules/mod_ext_filter.so
LoadModule mime_magic_module modules/mod_mime_magic.so
LoadModule expires_module modules/mod_expires.so
LoadModule deflate_module modules/mod_deflate.so
LoadModule headers_module modules/mod_headers.so
#LoadModule usertrack_module modules/mod_usertrack.so
LoadModule setenvif_module modules/mod_setenvif.so
LoadModule mime_module modules/mod_mime.so
#LoadModule dav_module modules/mod_dav.so
LoadModule status_module modules/mod_status.so
LoadModule autoindex_module modules/mod_autoindex.so
#LoadModule info_module modules/mod_info.so
#LoadModule dav_fs_module modules/mod_dav_fs.so
LoadModule vhost_alias_module modules/mod_vhost_alias.so
LoadModule negotiation_module modules/mod_negotiation.so
LoadModule dir_module modules/mod_dir.so
#LoadModule actions_module modules/mod_actions.so
#LoadModule speling_module modules/mod_speling.so
#LoadModule userdir_module modules/mod_userdir.so
LoadModule alias_module modules/mod_alias.so
LoadModule rewrite_module modules/mod_rewrite.so
LoadModule proxy_module modules/mod_proxy.so
#LoadModule proxy_balancer_module modules/mod_proxy_balancer.so
#LoadModule proxy_ftp_module modules/mod_proxy_ftp.so
LoadModule proxy_http_module modules/mod_proxy_http.so
LoadModule proxy_connect_module modules/mod_proxy_connect.so
LoadModule cache_module modules/mod_cache.so
#LoadModule suexec_module modules/mod_suexec.so
#LoadModule disk_cache_module modules/mod_disk_cache.so
#LoadModule file_cache_module modules/mod_file_cache.so
#LoadModule mem_cache_module modules/mod_mem_cache.so
LoadModule cgi_module modules/mod_cgi.so

UseCanonicalName On 

# don't log ip's
#LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined
LogFormat "0.0.0.0 %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined

And in /etc/httpd/conf.d/php.conf

#AddHandler php5-script .php
#AddType text/html .php

#DirectoryIndex index.php

Create a new file that can be included for error documents, /etc/httpd/conf/error-docs.conf

# Editor: vim:syn=apache

Alias /error/ "/var/www/error/"
<IfModule mod_negotiation.c>
  <IfModule mod_include.c>
    <Directory "/var/www/error">
        AllowOverride None
        Options IncludesNoExec
        AddOutputFilter Includes html
        AddHandler type-map var
        Order allow,deny
        Allow from all
        LanguagePriority en es de fr
        ForceLanguagePriority Prefer Fallback
    </Directory>
    ErrorDocument 400 /error/HTTP_BAD_REQUEST.html.var
    ErrorDocument 401 /error/HTTP_UNAUTHORIZED.html.var
    ErrorDocument 403 /error/HTTP_FORBIDDEN.html.var
    ErrorDocument 404 /error/HTTP_NOT_FOUND.html.var
    ErrorDocument 405 /error/HTTP_METHOD_NOT_ALLOWED.html.var
    ErrorDocument 408 /error/HTTP_REQUEST_TIME_OUT.html.var
    ErrorDocument 410 /error/HTTP_GONE.html.var
    ErrorDocument 411 /error/HTTP_LENGTH_REQUIRED.html.var
    ErrorDocument 412 /error/HTTP_PRECONDITION_FAILED.html.var
    ErrorDocument 413 /error/HTTP_REQUEST_ENTITY_TOO_LARGE.html.var
    ErrorDocument 414 /error/HTTP_REQUEST_URI_TOO_LARGE.html.var
    ErrorDocument 415 /error/HTTP_UNSUPPORTED_MEDIA_TYPE.html.var
    ErrorDocument 500 /error/HTTP_INTERNAL_SERVER_ERROR.html.var
    ErrorDocument 501 /error/HTTP_NOT_IMPLEMENTED.html.var
    ErrorDocument 502 /error/HTTP_BAD_GATEWAY.html.var
    ErrorDocument 503 /error/HTTP_SERVICE_UNAVAILABLE.html.var
    ErrorDocument 506 /error/HTTP_VARIANT_ALSO_VARIES.html.var
  </IfModule>
</IfModule>

And the whole VirtualHost in /etc/httpd/conf.d/ssl.conf was commented out.

General FC6 configuration

This server isn't doing anything apart from media wiki so some things can be turned off:

/sbin/chkconfig bluetooth off
/sbin/chkconfig cups off
/sbin/chkconfig firstboot off
/sbin/chkconfig isdn off
/sbin/chkconfig netfs off
/sbin/chkconfig nfslock off
/sbin/chkconfig portmap off