Table of Contents
Apache Lucene is a high-performance, full-featured text search engine library written entirely in Java. It is a technology suitable for nearly any application that requires full-text search, especially cross-platform.
This Java server has been tested with Open JDK Java Runtime 17. To be able to index and search for non-ASCII characters your system should support UTF-8 encodings.
PHP curl and xmlrpc are required for using the Java server features.
On Debian-based systems try:
> apt-get install php-curl php-xmlrpc openjdk-17-jdk-headless
Dependencies and the build process is managed via maven
> apt-get install maven
> cd Services/WebServervices/RPC/lib
> mvn clean install
To build/compile the jar file for older LTS release than v17, start the maven build process with the following parameters:
# java 11
> mvn clean install -Dmaven.compiler.release=11
# java 21
> mvn clean install -Dmaven.compiler.source=21 -Dmaven.compiler.target=21
The newly generated ilServer.jar has been created in the target-directory. Now move the target directory to any other location and grant read/write permission to the webserver user
> mv target /foo/bar
> chown -R www-data:www-data /foo/bar/target
Create a config file readable by the webserver user/group with following contents. E.g in the external data directory
> vi /foo/bar/ilServer.ini
[Server]
IpAddress = 127.0.0.1
Port = 11111
IndexPath = /var/www/files/lucene
LogFile = /var/www/logs/ilServer.log
LogLevel = INFO
NumThreads = 2
RamBufferSize = 256
IndexMaxFileSizeMB = 500
[Client1]
ClientId = ACMECorp
NicId = 0
IliasIniPath = /var/www/html/ilias/ilias.ini.php
-
IpAddress: normally localhost is sufficient
-
Port: any free non pivileged port
-
IndexPath: any directory with read/write access for the webserver user
-
LogFile: Directory must exist. Read/write access for the webserver is required
-
LogLevel: one of INFO, DEBUG, WARN, ERROR, FATAL
-
NumThreads: The larger the number of NumThreads, the shorter the indexing time, at the expense of the overall CPU load.
-
RamBufferSize: The maximum amount of memory in MB before index data is written to the file system
-
IndexMaxFileSize: The maximum file size of ILIAS files that can be included in the index.
-
ClientId: ClientId of ILIAS installation
-
NicId: NicID of ILIAS installation
-
IliasIniPath: absolute path to ilias.ini.php
Adapt the ILIAS setup config file variables (rpc_server_host and rpc_server_port) according to documentation of the command line setup
> vi /etc/systemd/system/ilserver.service
[Unit]
Description=ILIAS Java-Server
After=network.target
[Service]
User=www-data
Group=www-data
ExecStart=/usr/bin/java -jar /foo/bar/target/ilServer.jar /foo/bar/ilServer.ini start
ExecStop=/usr/bin/java -jar /foo/bar/target/ilServer.jar /foo/bar/ilServer.ini stop
TimeoutStopSec=10
[Install]
WantedBy=multi-user.target
> systemctl enable ilserver.service
> systemctl start ilserver.service
> java -jar {PATH_TO_EXTERNAL_DATA}/target/ilServer.jar {PATH_TO_EXTERNAL_DATA}/ilServer.ini status
Possible return values are:
Running
Stopped
Indexing
> java -jar /foo/bar/target/ilServer.jar /foo/bar/ilServer.ini createIndex <CLIENT_INFO>
The <CLIENT_INFO>
is a combination of the client id and the installation id.
You find these values with the setup status command:
> cd <ILIAS_ROOT_DIRECTORY>
> php setup/cli.php status
...
config:
common:
client_id: default
inst_id: 12345678
...
Example:
> java -jar /foo/bar/target/ilServer.jar /foo/bar/ilServer.ini createIndex default_12345678
or
> java -jar /foo/bar/target/ilServer.jar /foo/bar/ilServer.ini createIndex default_0
if no installation id is given.
> java -jar /foo/bar/target/ilServer.jar /foo/bar/ilServer.ini updateIndex <CLIENT_INFO>
> java -jar /foo/bar/target/ilServer.jar /foo/bar/ilServer.ini search <CLIENT_INFO> "ilias"