Configuration¶
The service allowed two variants of configuration:
use the Configurator service
use the configuration file
The service reads settings from the configuration file by default.
You can specify the –luna-config option for pulling settings from the Configurator service, see configurator.
Auto reload configuration¶
The service supports an auto-reload of configurations. You can enable this feature by specifying a config-reload option in the command line. The service periodically checks new settings. If current settings and new pulled settings are the same the service will not perform any actions. You can specify the check period in the pulling-time command line argument (10 seconds by default).
If a configuration fetching has failed, the service will work without applying any changes to the existing configurations.
If check connections with the new configuration have failed, the service will retry pulling new configuration after pulling-time seconds. The service will shut down after 10 failed attempts.
Warning
Service can work incorrectly while the new settings are being applied. It is strongly recommended not to send requests to the service when you change important settings (database configuration, work plugins list, and others).
Configuration file for administrator¶
# LUNA Plugin Administrator configuration file
[LUNA_CONFIGURATOR]
#: [integer] load configs from LUNA Configurator
USE_CONFIGURATOR = 0
#: [string] LUNA Configurator protocol, IP address, and port
LUNA_CONFIGURATOR_ORIGIN = http://127.0.0.1:5070
#: [integer] API version of the LUNA Configurator
LUNA_CONFIGURATOR_API  = 1
[LUNA_VIDEO_AGENT_LOGGER]
#: [string] folder, where logs are saved (relative path begins in directory with application)
FOLDER_WITH_LOGS = ./
#: [string] level of debug print, by priority: "ERROR", "WARNING", "INFO", "DEBUG"
LOG_LEVEL = INFO
#: [string] time format used in log records: "LOCAL" or "UTC"
LOG_TIME = LOCAL
#: [integer] maximum log file size in megabytes before performing rotation (0 - without rotation)
MAX_LOG_FILE_SIZE = 1024
#: send log to stdout
LOG_TO_STDOUT = 1
#: send log to file
LOG_TO_FILE = 0
#: allow multiline stack trace in logs
MULTILINE_STACK_TRACE = 1
[LUNA_MONITORING]
#: [string] storage type
STORAGE_TYPE = influx
#: [integer] send data for monitoring to InfluxDB
SEND_DATA_FOR_MONITORING = 1
#: [string] InfluxDB 2.x workspace
ORGANIZATION = luna
#: [string] InfluxDB 2.x authentication token
TOKEN = kofqt4Pfqjn6o0RBtMDQqVoJLgHoxxDUmmhiAZ7JS6VmEnrqZXQhxDhad8AX9tmiJH6CjM7Y1U8p5eSEocGzIA==
#: [string] InfluxDB 2.x bucket name
BUCKET = luna_monitoring
#: [string] InfluxDB IP address
HOST = 127.0.0.1
#: [integer] InfluxDB port
PORT = 8086
#: [integer] use HTTPS to connect to InfluxDB
USE_SSL = 0
#: [integer] frequency of sending monitoring data to InfluxDB (in seconds)
FLUSHING_PERIOD = 1
[LUNA_LICENSES_ADDRESS]
#: LUNA Licenses protocol, IP address, and port
ORIGIN = http://127.0.0.1:5120
#: API version of the LUNA Licenses
API_VERSION = 1
[LUNA_SERVICE_METRICS]
#: [int] whether to enable /metrics path and statistics collection
ENABLED = 0
# [string] statistics data format (prometheus is the only option yet)
METRICS_FORMAT = prometheus
[LUNA_SERVICE_METRICS.EXTRA_LABELS]
[ADDITIONAL_SERVICES_USAGE]
#: [integer] send events to LUNA Events for storing
LUNA_EVENTS = 1
#: [integer] use LUNA Tasks
LUNA_TASKS = 1
#: [integer] support LUNA-python-matcher service
LUNA_PYTHON_MATCHER = 1
#: [integer] use LUNA Python Matcher Proxy instead of LUNA Python Matcher
LUNA_MATCHER_PROXY = 1
#: [integer] use LUNA Sender
LUNA_SENDER = 1
#: [integer] use LUNA Image Store
LUNA_IMAGE_STORE = 1
#: [integer] use LUNA Handlers
LUNA_HANDLERS = 1
#: [integer] use LUNA Video Manager
LUNA_VIDEO_MANAGER = 1
#: [integer] use LUNA Streams Retranslator
LUNA_STREAMS_RETRANSLATOR = 0
#: [integer] use Luna Remote SDK
LUNA_REMOTE_SDK = 1
#: [integer] use LUNA Lambda
LUNA_LAMBDA = 0
[LUNA_VIDEO_MANAGER_ADDRESS]
#: LUNA Video Manager protocol, IP address, and port
ORIGIN = http://127.0.0.1:5230
#: API version of the LUNA Video Manager
API_VERSION = 2
[LUNA_VIDEO_AGENT_HTTP_SETTINGS]
#: [integer] service request timeout (in seconds)
REQUEST_TIMEOUT = 60
#: [integer] service response timeout (in seconds)
RESPONSE_TIMEOUT = 600
#: [integer] max request size (in bytes), default 1gb
REQUEST_MAX_SIZE = 1073741824
#: [integer] service http keep-alive timeout (in seconds)
KEEP_ALIVE_TIMEOUT = 15
[LUNA_SENDER_ADDRESS]
#: luna-sender origin
ORIGIN = http://127.0.0.1:5080
#: luna-sender api version
API_VERSION = 2
[EXTERNAL_LUNA_API_ADDRESS]
#: external luna-api origin
ORIGIN = http://127.0.0.1:5000
#: external luna-api origin
API_VERSION = 6
[LUNA_API_ADDRESS]
#: LUNA API protocol, IP address, and port
ORIGIN = http://127.0.0.1:5000
#: API version of the LUNA API
API_VERSION = 6
[LUNA_API_TIMEOUTS]
#: CONNECT TIMEOUT
CONNECT = 30
#: REQUEST TIMEOUT (total)
REQUEST =  60
[LUNA_HANDLERS_ADDRESS]
#: [string] LUNA Handlers protocol, IP address, and port
ORIGIN = http://127.0.0.1:5090
#: [integer] API version of the LUNA Handlers
API_VERSION = 1
[LUNA_HANDLERS_TIMEOUTS]
#: [integer] HTTP connection timeout
CONNECT = 30
#: [integer] HTTP request timeout (total)
REQUEST = 60
[LUNA_IMAGE_STORE_IMAGES_ADDRESS]
#: LUNA Image Store protocol, IP address, and port (for samples)
ORIGIN = http://127.0.0.1:5020
#: API version of the LUNA Image Store (for samples)
API_VERSION = 1
#: *bucket* name, where samples will be stored
BUCKET = visionlabs-image-origin
[LUNA_IMAGE_STORE_IMAGES_TIMEOUTS]
#: CONNECT TIMEOUT
CONNECT = 30
#: REQUEST TIMEOUT (total)
REQUEST =  60
[LUNA_VIDEO_MANAGER_TIMEOUTS]
#: CONNECT TIMEOUT
CONNECT = 30
#: REQUEST TIMEOUT (total)
REQUEST =  60
[LUNA_SENDER_TIMEOUTS]
#: CONNECT TIMEOUT
CONNECT = 30
#: REQUEST TIMEOUT (total)
REQUEST =  60
[LUNA_VIDEO_AGENT_RUNTIME_SETTINGS]
#: device type on which estimations is performed - "cpu" or "gpu"
GLOBAL_DEVICE_CLASS = cpu
#: number of worker threads
NUM_THREADS = 4
#: number of streams; this parameter increases performance, but works only with new versions of NVIDIA drivers
NUM_COMPUTE_STREAMS = 6
[LUNA_VIDEO_AGENT_PEOPLE_COUNT_ESTIMATOR_SETTINGS.runtime_settings]
#: device type on which the face detection is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_VIDEO_SETTINGS]
#: video decoder device type - "cpu", "gpu", or "auto"
DECODER_DEVICE_CLASS = auto
#: [int] number of video decoder workers
DECODER_WORKER_COUNT = 10
#: [int] number of pre-allocated frames for video stream
FRAME_POOL_SIZE = 10
#: [int] number of threads ffmpeg uses when decoding
FFMPEG_THREAD_COUNT = 0
[LUNA_VIDEO_AGENT_VIDEO_SETTINGS.timeouts]
#: [float] CONNECT TIMEOUT
CONNECT = 10.0
#: [float] REQUEST TIMEOUT (total)
REQUEST =  60.0
# [float] SOCK_CONNECT TIMEOUT
SOCK_CONNECT = 10.0
# [float] SOCKET_READ TIMEOUT
SOCK_READ = 60.0
[LUNA_VIDEO_AGENT_REDIS_DB_ADDRESS]
#: [string] Redis database username
USER =
#: [string] Redis database password
PASSWORD =
#: [string] Redis database IP address
HOST = 127.0.0.1
#: [integer] Redis database listener port
PORT = 6379
#: [integer] Redis database number (0-15)
NUMBER = 0
[LUNA_VIDEO_AGENT_REDIS_DB_ADDRESS.SENTINEL]
#: [string] sentinel master name
MASTER_NAME = luna_attributes
#: [list(string)] list of Redis Sentinel listeners (example [127.0.0.1:26379, 10.0.4.1:26379])
SENTINELS = []
#: [string] sentinel username
USER =
#: [string] sentinel password
PASSWORD =
[LUNA_IMAGE_STORE_OBJECTS_TIMEOUTS]
#: [integer] HTTP connection timeout
CONNECT = 30
#: [integer] HTTP request timeout (total)
REQUEST = 60
[LUNA_EVENTS_ADDRESS]
#: [string] LUNA Events protocol, IP address, and port
ORIGIN = http://127.0.0.1:5040
#: [integer] API version of the LUNA Events
API_VERSION = 2
[LUNA_EVENTS_TIMEOUTS]
#: [integer] HTTP connection timeout
CONNECT = 30
#: [integer] HTTP request timeout (total)
REQUEST = 60
[LUNA_VIDEO_AGENT_SETTINGS]
#: [int] number of max active streams
MAX_ACTIVE_STREAMS = 2
[LUNA_IMAGE_STORE_OBJECTS_ADDRESS]
#: LUNA Image Store protocol, IP address, and port (for objects)
ORIGIN = http://127.0.0.1:5020
#: API version of the LUNA Image Store (for objects)
API_VERSION = 1
#: *bucket* name, where objects will be stored
BUCKET = visionlabs-objects
[LUNA_VIDEO_AGENT_DEEPFAKE_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_LIVENESS_ESTIMATOR_SETTINGS.runtime_settings]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_LIVENESS_ESTIMATOR_SETTINGS.estimator_settings]
#: [float] liveness score threshold
REAL_THRESHOLD = 0.5
[LUNA_VIDEO_AGENT_PEOPLE_COUNT_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_HUMAN_DETECTOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_HEAD_POSE_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_FACE_LANDMARKS5_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_BODY_WARP_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_FACE_WARP_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_FACE_WARP_QUALITY_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_FACE_DESCRIPTOR_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_BASIC_ATTRIBUTES_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_BODY_DESCRIPTOR_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_BODY_ATTRIBUTES_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_EMOTIONS_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_GAZE_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_EYES_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_MASK_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_GLASSES_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_MOUTH_ATTRIBUTES_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_AGS_ESTIMATOR_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 10
#: worker count for estimation
WORKER_COUNT = 1
[LUNA_VIDEO_AGENT_HUMAN_TRACKER_SETTINGS.RUNTIME_SETTINGS]
#: device type on which estimation is performed - "cpu", "gpu" or "global"
DEVICE_CLASS = global
#: optimal batch size for stage
OPTIMAL_BATCH_SIZE = 100
[LUNA_VIDEO_AGENT_HUMAN_TRACKER_SETTINGS.ESTIMATOR_SETTINGS]
#: The count of frames between frames with full detection.
DETECTOR_STEP = 7
#: Frame will be scaled to this size in pixels for detection step (by the max dimension of width/height).
SCALE_RESULT_SIZE = 640
#: If track wasn't updated by detect/redetect for this number of frames, then track is finished
SKIP_FRAMES = 18
[OTHER]
#: default face descriptor version
DEFAULT_FACE_DESCRIPTOR_VERSION = 65
#: default human body descriptor version
DEFAULT_HUMAN_DESCRIPTOR_VERSION = 116
#: list of active plugins
LUNA_VIDEO_AGENT_ACTIVE_PLUGINS = []
Extended administrator configuration¶
Extended configuration.
- configs.config.ESTIMATORS_TARGETS = [LoopEstimations.peopleCount, LoopEstimations.humanTracker]¶
- list of estimators targets for initialization 
- configs.config.WSCODE_GOING_AWAY = 1001¶
- WebSocket close code for going away