Linux - Applications: Difference between revisions

From Smithnet Wiki
Jump to navigation Jump to search
m (5 revisions imported)
(5 intermediate revisions by the same user not shown)
Line 8: Line 8:
   php php-mbstring php-pear php-fpm
   php php-mbstring php-pear php-fpm


* User directories
User directories:


  setsebool -P httpd_enable_homedirs 1
  setsebool -P httpd_enable_homedirs 1
Line 19: Line 19:
=== HTTP/2 ===
=== HTTP/2 ===


Enable in httpd.conf (globally or in a virtual host):
Enable (globally or in a virtual host):
  Protocols h2 h2c http/1.1
  Protocols h2 h2c http/1.1


Line 46: Line 46:
  setsebool -P httpd_can_network_connect_db 1
  setsebool -P httpd_can_network_connect_db 1


* Unpack [https://www.mediawiki.org/wiki/Extension:Math Math] under /usr/share/mediawiki/extensions/Math
* Run setup http://hostname/wiki
* Run setup http://hostname/wiki
** Allow it to create DB user/schema
** Allow it to create DB user/schema
** Tick Math option
* Configuration: /var/www/wiki/LocalSettings.php
* Configuration: /usr/share/mediawiki/LocalSettings.php


Customisations:
Customisations:
Line 56: Line 54:
  $wgEmergencyContact = "webmaster@smithnet.org.uk";
  $wgEmergencyContact = "webmaster@smithnet.org.uk";
  $wgPasswordSender  = "webmaster@smithnet.org.uk";
  $wgPasswordSender  = "webmaster@smithnet.org.uk";
  $wgLogo            = "/images/smithnet_wiki.png";
  $wgLogos = [
        '1x' => "/images/smithnet_wiki.png",
        'icon' => "/images/smithnet_wiki.png",
];
 
Icon is nominally 50×50 pixels if SVG, or 100×100 pixels if raster. The 1x version hould be 135px wide by up to ~155px tall.


Add new file types for upload, and enable uploads:
Add new file types for upload, and enable uploads:
Line 64: Line 67:
Extra Logging:
Extra Logging:
  $wgShowExceptionDetails = true;
  $wgShowExceptionDetails = true;
The [https://www.mediawiki.org/wiki/Extension:Math Math] extension is now distributed in:
/var/www/wiki/extensions/Math
Add to configuration:
wfLoadExtension( 'Math' );
=== Access Control ===
Prevent anonymous users creating accounts:
$wgGroupPermissions['*']['createaccount'] = false;
Prevent anonymous editing:
$wgGroupPermissions['*']['edit'] = false;
Allow anonymous reading:
$wgGroupPermissions['*']['read'] = true;


=== Export/Import ===
=== Export/Import ===
Line 69: Line 89:
Export all content as XML:
Export all content as XML:
  php /usr/share/mediawiki/maintenance/dumpBackup.php --full --conf /var/www/wiki/LocalSettings.php > dump.xml
  php /usr/share/mediawiki/maintenance/dumpBackup.php --full --conf /var/www/wiki/LocalSettings.php > dump.xml
or use the UI: Special pages -> Export pages.


After RPM upgrade, may need to update database schema:
After RPM upgrade, may need to update database schema:
  /usr/share/mediawiki/maintenance/update.php
  /usr/share/mediawiki/maintenance/update.php
Or use the UI: Special pages -> Import pages. File uploading may be limited by PHP (/etc/php.ini):
upload_max_filesize = 25M
or HTTPD (0 is unlimited):
LimitRequestBody 0


== Tomcat ==
== Tomcat ==

Revision as of 19:56, 8 May 2024

Apache

  • /etc/httpd/conf/httpd.conf
  • /etc/httpd/conf.d/ssl.conf
  • /etc/httpd/conf.d/proxy_ajp.conf to connect to Tomcat over AJP

PHP packages:

 php php-mbstring php-pear php-fpm

User directories:

setsebool -P httpd_enable_homedirs 1
chmod 711 /home/someuser
chmod 755 /home/someuser/public_html

After updating certificate (and key) SELinux may not allow access. Fix with:

restorecon -v /etc/pki/tls/certs/www.smithnet.org.uk.cert.pem

HTTP/2

Enable (globally or in a virtual host):

Protocols h2 h2c http/1.1

Use curl to check protocol switching:

curl --http2 -v localhost
...
< HTTP/1.1 101 Switching Protocols
< Upgrade: h2c
< Connection: Upgrade
* Received 101
* Using HTTP2, server supports multi-use
* Connection state changed (HTTP/2 confirmed)
* Copying HTTP/2 data in stream buffer to connection buffer after upgrade: len=0
* Connection state changed (MAX_CONCURRENT_STREAMS == 100)!
< HTTP/2 200
...

Mediawiki

  • Install PHP, including php-pgsql driver and php-pecl-apcu object caching.
  • Uncomment in /etc/httpd/conf.d/mediawiki.conf

Set SELinux:

setsebool -P httpd_read_user_content 1
setsebool -P httpd_can_network_connect 1
setsebool -P httpd_can_network_connect_db 1
  • Run setup http://hostname/wiki
    • Allow it to create DB user/schema
  • Configuration: /var/www/wiki/LocalSettings.php

Customisations:

$wgServer           = "http://www.smithnet.org.uk";
$wgEmergencyContact = "webmaster@smithnet.org.uk";
$wgPasswordSender   = "webmaster@smithnet.org.uk";
$wgLogos = [
        '1x' => "/images/smithnet_wiki.png",
        'icon' => "/images/smithnet_wiki.png",
];

Icon is nominally 50×50 pixels if SVG, or 100×100 pixels if raster. The 1x version hould be 135px wide by up to ~155px tall.

Add new file types for upload, and enable uploads:

$wgFileExtensions[] = 'pdf';
$wgEnableUploads = true;

Extra Logging:

$wgShowExceptionDetails = true;

The Math extension is now distributed in:

/var/www/wiki/extensions/Math

Add to configuration:

wfLoadExtension( 'Math' );

Access Control

Prevent anonymous users creating accounts:

$wgGroupPermissions['*']['createaccount'] = false;

Prevent anonymous editing:

$wgGroupPermissions['*']['edit'] = false;

Allow anonymous reading:

$wgGroupPermissions['*']['read'] = true;

Export/Import

Export all content as XML:

php /usr/share/mediawiki/maintenance/dumpBackup.php --full --conf /var/www/wiki/LocalSettings.php > dump.xml

or use the UI: Special pages -> Export pages.

After RPM upgrade, may need to update database schema:

/usr/share/mediawiki/maintenance/update.php

Or use the UI: Special pages -> Import pages. File uploading may be limited by PHP (/etc/php.ini):

upload_max_filesize = 25M

or HTTPD (0 is unlimited):

LimitRequestBody 0

Tomcat

  • /etc/tomcat/conf/server.xml (define required connectors)
  • /etc/tomcat/conf/tomcat-users.xml
  • Webapps deplyed to: /var/lib/tomcat/webapps
    • tomcat-webapps
    • tomcat-docs-webapps
    • tomcat-admin-webapps