jumpserver/utils/generate_fake_data/resources/system.py

70 lines
2.1 KiB
Python

import random
from .base import FakeDataGenerator
from terminal.models import *
class StatGenerator(FakeDataGenerator):
resource = 'stat'
nodes = [
{
'node': 'guacamole-01',
'ip': '192.168.1.1',
'component': 'guacamole'
},
{
'node': 'koko-01',
'ip': '192.168.1.2',
'component': 'koko'
},
{
'node': 'omnidb-01',
'ip': '192.168.1.3',
'component': 'omnidb'
},
{
'node': 'core-01',
'ip': '192.168.1.4',
'component': 'core'
}
]
items_value_range = {
'cpu_load': (0, 3.0),
'memory_used_percent': (20, 10.0),
'disk_used_percent': (30, 80.0),
'thread': (100, 100),
'goroutine': (200, 500),
'replay_upload_health': (0, [0, 1]),
'command_upload_health': (0, [0, 1]),
'session_active': (100, 50),
'session_processed': (400, 400),
'session_failed': (50, 100),
'session_succeeded': (500, 300)
}
def do_generate(self, batch, batch_size):
datetime = timezone.now()
for i in batch:
datetime = datetime - timezone.timedelta(minutes=1)
items = []
for node in self.nodes:
for key, values in self.items_value_range.items():
base, r = values
if isinstance(r, int):
value = int(random.random() * r)
elif isinstance(r, float):
value = round(random.random() * r, 2)
elif isinstance(r, list):
value = random.choice(r)
else:
continue
value += base
node.update({
'key': key,
'value': value,
'datetime': datetime
})
items.append(Stat(**node))
Stat.objects.bulk_create(items, ignore_conflicts=True)