new: Display lacus monitoring

pull/865/head
Raphaël Vinot 2024-01-23 17:27:33 +01:00
parent 3443d5068b
commit 7e188b86c7
1 changed files with 33 additions and 2 deletions

View File

@ -5,14 +5,16 @@ from __future__ import annotations
import os import os
import sys import sys
from typing import List, Tuple, Any from typing import Any
from redis import Redis from redis import Redis
from redis.exceptions import ConnectionError from redis.exceptions import ConnectionError
from rich.console import Console from rich.console import Console
from rich.padding import Padding from rich.padding import Padding
from lookyloo.default import get_socket_path, AbstractManager from pylacus import PyLacus
from lookyloo.default import get_socket_path, AbstractManager, get_config
# NOTE: run with watch: # NOTE: run with watch:
# watch --color tools/monitoring.py # watch --color tools/monitoring.py
@ -22,9 +24,19 @@ console = Console(color_system="256")
class Monitoring(): class Monitoring():
lacus: PyLacus | None = None
def __init__(self) -> None: def __init__(self) -> None:
self.redis_cache: Redis = Redis(unix_socket_path=get_socket_path('cache'), decode_responses=True) # type: ignore[type-arg] self.redis_cache: Redis = Redis(unix_socket_path=get_socket_path('cache'), decode_responses=True) # type: ignore[type-arg]
self.redis_indexing: Redis = Redis(unix_socket_path=get_socket_path('indexing'), decode_responses=True) # type: ignore[type-arg] self.redis_indexing: Redis = Redis(unix_socket_path=get_socket_path('indexing'), decode_responses=True) # type: ignore[type-arg]
# try to connect to a remote lacus if lookyloo is configured this way
if remote_lacus_config := get_config('generic', 'remote_lacus'):
if remote_lacus_config.get('enable'):
remote_lacus_url = remote_lacus_config.get('url')
self.lacus = PyLacus(remote_lacus_url)
if not self.lacus.is_up:
self.lacus = None
console.print(f'[red]WARNING[/red]: Remote lacus is configured but not reachable: {remote_lacus_url}.')
@property @property
def backend_status(self) -> bool: def backend_status(self) -> bool:
@ -89,6 +101,17 @@ class Monitoring():
to_return[pid_name] = value to_return[pid_name] = value
return to_return return to_return
def lacus_status(self) -> dict[str, Any]:
if not self.lacus:
return {}
to_return = {}
to_return['is_busy'] = self.lacus.is_busy()
status = self.lacus.status()
to_return['max_concurrent_captures'] = status['max_concurrent_captures']
to_return['ongoing_captures'] = status['ongoing_captures']
to_return['enqueued_captures'] = status['enqueued_captures']
return to_return
if __name__ == '__main__': if __name__ == '__main__':
@ -109,6 +132,14 @@ if __name__ == '__main__':
s = Padding(f'{name}: {status}', (0, 2)) s = Padding(f'{name}: {status}', (0, 2))
console.print(s) console.print(s)
if m.lacus is not None:
status = m.lacus_status()
console.print('Lacus status:')
if status['is_busy']:
console.print(Padding('[red]WARNING[/red]: Lacus is busy.', (0, 2)))
console.print(Padding(f'Ongoing captures: {status["ongoing_captures"]}', (0, 2)))
console.print(Padding(f'Enqueued captures: {status["enqueued_captures"]}', (0, 2)))
console.print('Current queues:') console.print('Current queues:')
for q, priority in m.queues: for q, priority in m.queues:
s = Padding(f'{q} Recently enqueued captures: {int(priority)}', (0, 2)) s = Padding(f'{q} Recently enqueued captures: {int(priority)}', (0, 2))