Skip to content

Latest commit

 

History

History
181 lines (152 loc) · 5.15 KB

README.md

File metadata and controls

181 lines (152 loc) · 5.15 KB

Lucene RPC-Server

Table of Contents

Apache Lucene

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.

Requirements

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

Installation

Build the Java RPC Server

> 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

Configure the Java RPC Server

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

Configure the ILIAS RPC connection settings

Adapt the ILIAS setup config file variables (rpc_server_host and rpc_server_port) according to documentation of the command line setup

Manage Startup using systemd

> 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

Start the Server

> systemctl start ilserver.service

Show Additional Status Info

> java -jar {PATH_TO_EXTERNAL_DATA}/target/ilServer.jar {PATH_TO_EXTERNAL_DATA}/ilServer.ini status

Possible return values are:

Running
Stopped
Indexing

Creating a new Lucene index:

> 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.

Updating an existing index:

> java -jar /foo/bar/target/ilServer.jar /foo/bar/ilServer.ini updateIndex <CLIENT_INFO>

Performing a query

> java -jar /foo/bar/target/ilServer.jar /foo/bar/ilServer.ini search <CLIENT_INFO> "ilias"