Configuration

Note

All the logs are present in this folder $LIKPI_HOME/log

ObsAgent

Using a text editor, edit the configuration file and customize it for ObsAgent service.

Path: $LIKPI_HOME/conf/likpi-obsagent.properties

# Request Handler target url i.e: vps-rh-myserver:6666
RequestHandler.url=tcp://<hostname>:<port>

# ObasAgent identifier i.e: vps-obs-server#obsagent
RequestHandler.id=<obsagent_id>

# Hostname of ObsAgent i.e: vps-obs-server
Host.name = <hostname>

# Read the log file from the end or from the beginig
reading.mode = <end|start>

# Line log separator default 10
lineSeparatorChar=<value>

# AIOpsCell target url i.e: vps-aiops-myserver:4001
aiopscell.1.url  = tcp://<hostname>:<port>

# Buffer size default 16000
byteReadSize = <value>

LogFile.count = 1

# Log file path i.e: D:\\myapp\\applog1 (Windows)
LogFileName.0 = /opt/myapp/applog1
LogFileName.1 = /opt/myapp/other-applog

# For furure usage
sensors.enable = False

# No pass rules
nopass.pattern.1 = this message should be ignored
nopass.pattern.2 = other message should be ignored

Note

To enable debug tracing, udpate file $LIKPI_HOME/conf/likpi-obsagent_logback.xml configuration file

level=”WARN” to level=”TRACE”

AIOpsCell and HSQL databse

Using a text editor, edit the configuration file and customize it for AIOpsCell service.

Path: $LIKPI_HOME/conf/likpi-aiopscell.properties

# Request Handler target url i.e: vps-rh-myserver:6666
RequestHandler.url=tcp://<hostname>:<port>

# Request Handler identifier i.e: vps-rh-server#rh
RequestHandler.id=<rh_id>

# Hostname of AIOpsCell i.e: vps-aiops-server
Host.name = <hostname>

# Central server database credentials (default port:5432)
main.dbdriver=org.postgresql.Driver
main.dburl=jdbc:postgresql://<vps-central-hostname>:<port>/<mydb>
main.dbuser=<postgresql-admin-user>
main.dbpwd=<password>

# AIOpsCell database credentials (default port:9001 for HSQL)
im.dburl=jdbc:hsqldb:hsql://<hostname>:<port>/<mydb>
im.dbuser=<user>
im.dbpwd=<password>

# Default port:4001
ReceiverUrl = tcp://*:<port>

# this attribute is for test and debug purposes only. Default value is "true"
patternmatching.enable = true
dbwrites.enable = true

# Performance tuning
aiopscell.threads.count = 7
batch.size = 100
sql.exec.threads.count = 2
aiopscell.zmq.rcv.hwm = 10000000

# Policy for unmatched log messages
keepUnmatched.enabled = false
keepUnmatched.rule = size
keepUnmatched.limit = 10000
keepUnmatched.age = 30d
keepUnmatched.cleanupinterval = 1h

# Policy for log events
keepEvents.enabled = false
keepEvents.rule = size
keepEvents.limit = 1000000
keepEvents.age = 30d
keepEvents.cleanupinterval = 1h

# Delimiter for log messages
delimiterChar=\n

# Severity inference rules
severitysetter.critical.patterns.1 = error
severitysetter.critical.patterns.2 = critical
severitysetter.warning.patterns.1 = warning
severitysetter.warning.patterns.2 = fails
severitysetter.warning.patterns.3 = failure
severitysetter.warning.patterns.4 = failed
severitysetter.warning.patterns.5 = exception
severitysetter.warning.patterns.6 = incorrect
severitysetter.warning.patterns.7 = invalid
severitysetter.warning.patterns.8 = unable
severitysetter.warning.patterns.9 = too many
severitysetter.warning.patterns.10 = attack
severitysetter.critical.patterns.11 = fatal
severitysetter.warning.patterns.12 = wrong
severitysetter.warning.patterns.13 = did not match
severitysetter.warning.patterns.14 = unknown
severitysetter.major.patterns.1 = major
severitysetter.ok.patterns.1 = succeed
severitysetter.default = INFO

Note

To enable debug tracing, udpate file $LIKPI_HOME/conf/likpi-aiopscell_logback.xml configuration file

i.e: level=”WARN” to level=”TRACE”

Using a text editor, edit the configuration file and customize it for IMDB service.

Path: $LIKPI_HOME/conf/likpi-imdb.properties

# Database target url i.e: jdbc:hsqldb:hsql://localhost:9001/likpi
im.dburl=jdbc:hsqldb:hsql://<database_hostname>:<port>/<mydb>

# Database hostname i.e: localhost
im.dbhost=<hostname>

# Database administrator user i.e: likpiadm
im.dbuser=<user>

# Database administrator user password
im.dbpwd=<password>

# ??
repair.enable_merge_severities=false

# Persistence mode i.e: file
im.dbmode=<file|memory>

# Path database file i.e: F:\\test\\mydb\\likpi.db
im.dbfile=<database_file_path>

# ??
im.dbsilent=true

# Additional databse settings
im.db.additional_settings:hsqldb.log_size=1;hsqldb.tx=mvcc;hsqldb.large_data=true;hsqldb.cache_file_scale=512

Note

To enable debug tracing, udpate file $LIKPI_HOME/conf/likpi-imdb_logback.xml configuration file

i.e: level=”WARN” to level=”TRACE”

MetricsManager

Using a text editor, edit the configuration file and customize it for MetricsManager service.

Path: $LIKPI_HOME/conf/likpi-metricsmanager.json

{
  "sql.client.type" :"POSTGRES_ASYNC", // Enum value for driver

  "host" : "<FQDN>",
  "port" : <port>, // default 5432
  "maxPoolSize" : 50,

  "username" : "<likpidba>",
  "password" : "<password>",
  "database" : "<likpidb>",
  "queryTimeout" : 30000,

  "nats.host":"<FQDN>", // host nats server
  "nats.port":4222, // port nats server
  "nats.subject": "METRIC", // NATs subject
  "threadPool":1, // pool thread size for scheduler

  "request.handler.url" : "tcp://<hostname>:<port>", // RequestHandler target url
  "request.handler.identity" : "<hostname#metrics>" // identity for request handler
}

Note

To enable debug tracing, udpate file $LIKPI_HOME/conf/likpi-metricsmanager.xml configuration file

i.e: level=”WARN” to level=”TRACE”

TrendAnalysis

Using a text editor, edit the configuration file and customize it for TrendsAnalysis service.

Path: $LIKPI_HOME/conf/likpi-trendsanalysis.properties

[postgresql]

# Database hostname i.e: localhost
host=<hostname>

# Database name
database=<database>

# port
port=<port>

# Database administrator user
user=<user>

# Database administrator user password
password=<password>

CoreManager

Using a text editor, edit the configuration file and customize it for TrendsAnalysis service.

Path: $LIKPI_HOME/conf/likpi-coremanager.json

{
  "prog.name" : "Likpi Bigdata & Analytics", // Name of the appliction
  "prog.version" : "v1.0", // Version
  "license.file"     :"/opt/likpi/security/licenseFor-free.license", // License file

  "sql.client.type" :"POSTGRES_ASYNC", // Client type

  "host" : "<FQDN>",
  "port" : <port>, // default 5432
  "maxPoolSize" : 50,
  "username" : "<likpidba>",
  "password" : "<password>",
  "database" : "<likpidb>",
  "queryTimeout" : 30000,

  "authenticate" : true, // Authenticate true|false

  "agent.subscription.refresh.delay": 30000, // Subscription refresh Delay

  "live.obsolete.min.duration" : 10,  // Live obsolete duration in min
  "live.obsolete.min.check" : 5,              // Live obsolete check in min
  "histo.obsolete.min.duration" : 10,         // Historic obsolete duration in min
  "histo.obsolete.min.check" : 5,             // Historic obsolete check in min
  "histo.batch.min" : 0,                              // Historic batch in min (Historic is done from NATs in real time if the value is 0)

  "private.key.file" :"/opt/likpi/security/rsa_2048_priv.pem", // Private key file
  "public.key.file"  :"/opt/likpi/security/rsa_2048_pub.pem",  // Public key file
  "session.timeout"  : 900,
  "jwt.algo"         : "RS256", // jwt algo type

  "api.metric.broker.secure" : false, // Metric broker secure false|true
  "api.metric.broker.address" :"0.0.0.0", // Metric broker ip|hostname
  "api.metric.broker.port": 4222, // Metric broker port ( NATs port)

  "api.http.secure.external" : false, // http secure external false|true
  "api.http.secure.internal" : false, // http secure internal false|true
  "api.http.secure.tls.cert" : "/opt/likpi/security/httpcertificate.pem", // Certificate file
  "api.http.secure.tls.key"  : "/opt/likpi/security/httpkey.pem",         // Self signed key file

  "nats.host" : "localhost", // FQDN hostname or localhost
  "nats.port" : 4222, // NATs port
  "nats.subject" : "METRIC", // NATs subject

  "api.auth.http.address": "0.0.0.0",
  "api.auth.http.port": 8001,

  "api.admin.http.address": "0.0.0.0",
  "api.admin.http.port": 8002,

  "api.connector.http.address": "0.0.0.0",
  "api.connector.http.port": 8003,

  "api.attribute.http.address": "0.0.0.0",
  "api.attribute.http.port": 8004,

  "api.metric.http.address": "0.0.0.0",
  "api.metric.http.port": 8005,

  "api.view.http.address": "0.0.0.0",
  "api.view.http.port": 8006,

  "api.queryBuilder.http.address": "0.0.0.0",
  "api.queryBuilder.http.port": 8007,

  "api.collector.subscriber.http.address": "0.0.0.0",
  "api.collector.subscriber.http.port": 8008,

  "api.sql.builder.http.address": "0.0.0.0",
  "api.sql.builder.http.port": 8009,

  "api.organization.http.address": "0.0.0.0",
  "api.organization.http.port": 8011,

  "api.event.http.address": "0.0.0.0",
  "api.event.http.port": 8012,

  "api.regex.http.address": "0.0.0.0",
  "api.regex.http.port": 8013,

  "api.automator.http.address": "0.0.0.0",
  "api.automator.http.port": 8014,

  "api.cefattribute.http.address": "0.0.0.0",
  "api.cefattribute.http.port": 8015,

  "api.scenario.http.address": "0.0.0.0",
  "api.scenario.http.port": 8016,

  "api.activity.http.address": "0.0.0.0",
  "api.activity.http.port": 8017,

  "api.automation.guide.http.address": "0.0.0.0",
  "api.automation.guide.http.port": 8018,

  "api.history.http.address": "0.0.0.0",
  "api.history.http.port": 8019,

  "api.sqlquerybuilder.http.address": "0.0.0.0",
  "api.sqlquerybuilder.http.port": 8020,

  "api.probe.http.address": "0.0.0.0",
  "api.probe.http.port": 8021,

  "api.gateway.http.address": "0.0.0.0",
  "api.gateway.http.port": 8087,

  "api.gateway.builder.get" : "/api/query-builder",
  "api.gateway.builder.post" : "/api/query-builder",

  "request.handler.url" : "tcp://<hostname>:<port>", // RequestHandler target url

  "request.handler.identity.sql.builder": "SqlBuilder",
  "request.handler.target.sql.builder" : "Scheduler",
  "request.handler.action.sql.builder" : "reload",

  "request.handler.identity.sqb" : "sqb-api",
  "request.handler.target.sqb" : "Scheduler",
  "request.handler.action.sqb" : "reload_scheduled_tasks",

  "request.handler.identity.regex" : "regex",
  "request.handler.target.regex" : "Collector",
  "request.handler.action.regex.add" : "reload_regex_configuration",
  "request.handler.action.regex.remove" : "remove_regex",

  "smtp.host" : "<server>", // SMTP server
  "smtp.port" : "<port>", // SMTP port
  "smtp.user" : "<user_mail>", // User mail
  "smtp.password" : "<mail_password>" // User mail password

}

Requesthandler

Using a text editor, edit the configuration file and customize it for RequestHandler service.

Path: $LIKPI_HOME/conf/likpi-requesthandler.properties

# Request Handler target url i.e: vps-rh-myserver:6666
RequestHandler.url=tcp://<hostname>:<port>

# RequestHandler identifier i.e: localhost
RequestHandler.id=<requesthandler_id>

# Central server database credentials (default port:5432)
main.dbdriver=org.postgresql.Driver
main.dburl=jdbc:postgresql://<vps-central-hostname>:<port>/<mydb>
main.dbuser=<postgresql-admin-user>
main.dbpwd=<password>

Note

To enable debug tracing, udpate file $LIKPI_HOME/conf/likpi-requesthandler_logback.xml configuration file

level=”WARN” to level=”TRACE”

NATs

Using a text editor, edit the server.conf configuration file and customize it for NATs service.

Path: $LIKPI_HOME/nats-server-{version}-{platform}/server.conf

websocket: {
  port: 8800, // Web socket port
  no_tls: true // TLS true/false
}

Note

Not needed on this release.

Automator

Using a text editor, edit the configuration file and customize it for RequestHandler service.

Path: $LIKPI_HOME/conf/likpi-requesthandler.properties

# Request Handler target url i.e: vps-rh-myserver:6666
RequestHandler.url=tcp://<hostname>:<port>

# RequestHandler identifier i.e: localhost
RequestHandler.id=<automator_id>

# Hostname of Automator i.e: vps-auto-server
Host.name = <hostname>

# Central server database credentials (default port:5432)
main.dbdriver=org.postgresql.Driver
main.dburl=jdbc:postgresql://<vps-central-hostname>:<port>/<mydb>
main.dbuser=<postgresql-admin-user>
main.dbpwd=<password>

Note

To enable debug tracing, udpate file $LIKPI_HOME/conf/likpi-automator_logback.xml configuration file

level=”WARN” to level=”TRACE”

TrueCorrelation

Using a text editor, edit the configuration file and customize it for TrueCorrelation service.

Path: $LIKPI_HOME/conf/likpi-truecorrelation.properties

# Request Handler target url i.e: vps-rh-myserver:6666
RequestHandler.url=tcp://<hostname>:<port>

# RequestHandler identifier i.e: localhost
RequestHandler.id=<request_id>

# Hostname of TrueCorrelation i.e: vps-tc-server
Host.name = <hostname>

# Central server database credentials (default port:5432)
main.dbdriver=org.postgresql.Driver
main.dburl=jdbc:postgresql://<vps-central-hostname>:<port>/<mydb>
main.dbuser=<postgresql-admin-user>
main.dbpwd=<password>

truecorrelation.scheduleractivities.id=<scheduler_id>

Note

To enable debug tracing, udpate file $LIKPI_HOME/conf/likpi-truecorrelation_logback.xml configuration file

level=”WARN” to level=”TRACE”

SchedulerActivities

Using a text editor, edit the configuration file and customize it for SchedulerActivities service.

Path: $LIKPI_HOME/conf/likpi-scheduleractivities.properties

# Request Handler target url i.e: vps-rh-myserver:6666
RequestHandler.url=tcp://<hostname>:<port>

# RequestHandler identifier i.e: localhost
RequestHandler.id=<request_id>

# Hostname of SchedulerActivities i.e: vps-sa-server
Host.name = <hostname>

# Central server database credentials (default port:5432)
main.dbdriver=org.postgresql.Driver
main.dburl=jdbc:postgresql://<vps-central-hostname>:<port>/<mydb>
main.dbuser=<postgresql-admin-user>
main.dbpwd=<password>

# Number od threads
scheduleractivities.thread.count=1

# Timeout for activity
scheduleractivities.timeout.action=60

Note

To enable debug tracing, udpate file $LIKPI_HOME/conf/likpi-scheduleractivities_logback.xml configuration file

level=”WARN” to level=”TRACE”

Web Portal

In $LIKPI_PATH/webroot/js/config, there are 2 javascript files and 2 json files:
  • app.config.js > initializes the paths for the APIs and html pages in the application
  • i18next.config.js > initializes translations
  • restAPI.config.json > structures paths, APIs and serves as a resource to app.config.js
  • server.config.json > Web Portal configuration
  • Plublic key file location $LIKPI_PATH/webroot/security

Using a text editor, edit the configuration file server.config.json and customize it for Web Portal.

{
    "prog" : {
        "name" : "Likpi",
        "version"    : "v0.1.6"
    },
    "id": {
        "company" : "L.I.K.P.I.",
        "length"    : 9
    },
    "http": {
        "address" : "<hostname>", // Hostname where Web Server is running
        "port"    : "<port>",     // default port 8087
        "secure"  : "",           // "s" for secure
        "prefix"  : ""            // Url prefix string
    },
    "ws": {
        "address" : "<hostname>", // Hostname where Gateway Web Socket is running
        "port"    : "<port>",     // default port 8900
        "secure"  : "",           // "s" for secure
        "prefix"  : "nats"        // Internal settings
    },
    "security": {
        "publicKey" : "security/rsa_2048_pub.pem"  // Plublic key file
    },
    "log": {
        "enabled" : false,    // Enable or Disable the logs
        "pattern" :"%d{yyyy-MM-dd HH:mm:ss,SSS} %-5p - %m%n"  // Timestamp format for the logs
    },
    "locale": {
        "lang" : "fr",
        "loadPath" :"locales/{{lng}}/{{ns}}.json",
        "dataTablesLoadPath" :"locales/{{lng}}/dataTables.json",
        "canvasJSLoadPath" :"locales/{{lng}}/canvasJS.json",
        "dateRangePickerLoadPath" : "locales/{{lng}}/dateRangePicker.json"
    },
    "dataFrameParam": {   // Below internal settings

        "noAggr": {
          "subscribeTo" : "",
          "xValueFmt" : "DD-MM-YY HH:mm:ss",
          "axisXDtFmt": "HH:mm",
          "axisXDtInterval": 0,
          "axisXDtIntervalType": "minute"
        },
        "aggrMinute": {
          "subscribeTo" : "MINUTE",
          "xValueFmt" : "DD-MM-YY HH:mm",
          "axisXDtFmt": "DD-MM-YY HH:mm",
          "axisXDtInterval": 0,
          "axisXDtIntervalType": "minute"
        },
        "aggrHour": {
          "subscribeTo" : "HOUR",
          "xValueFmt" : "DD-MM-YY HH:mm",
          "axisXDtFmt": "DD-MM-YY HH'h'",
          "axisXDtInterval": 0,
          "axisXDtIntervalType": "hour"
        },
        "aggrDay": {
          "subscribeTo" : "DAY",
          "xValueFmt" : "DD-MM-YY",
          "axisXDtFmt": "DD-MM-YY",
          "axisXDtInterval": 0,
          "axisXDtIntervalType": "day"

        },
        "aggrMonth": {
          "subscribeTo" : "MONTH",
          "xValueFmt" : "DD-MM-YY",
          "axisXDtFmt": "MMM YY",
          "axisXDtInterval": 1,
          "axisXDtIntervalType": "month"
        }
    },
    "dataValue": {
        "NumbertoFixed"     : 1
    }

}

Note

The file rest API.config.json is static and it reflects the services subjected by the core-manager service.

Web socket gateway with TLS

To enable TLS connection, please update the /opt/likpi/bin/likpi-wsgateway

From:

#!/bin/sh
appname="wsgateway"
IPADDR=`hostname -I | awk '{ print $1 }'`
pidfile=/opt/likpi/tmp/likpi-$appname.pid
nohup /opt/likpi/lib/ws-gateway-tcp -wsAddr=$IPADDR -noOriginCheck=true -trace=true >> /opt/likpi/log/likpi-$appname.out 2>&1 &
echo $! > $pidfile

To:

#!/bin/sh
appname="wsgateway"
IPADDR=`hostname -I | awk '{ print $1 }'`
pidfile=/opt/likpi/tmp/likpi-$appname.pid
nohup /opt/likpi/lib/ws-gateway-tcp -tls=true -tlsCert="/opt/likpi/security/httpcertificate.pem" -tlsKey="/opt/likpi/security/httpkey.pem" -tcpAddr=$IPADDR -noOriginCheck=true -trace=true >> /opt/likpi/log/likpi-$appname.out 2>&1 &
echo $! > $pidfile

Then restart likpi-wsgateway service.