mirror of
https://github.com/Pardus-LiderAhenk/ahenk
synced 2025-01-10 16:22:16 +03:00
79 lines
3.5 KiB
Python
79 lines
3.5 KiB
Python
#!/usr/bin/python
|
||
# -*- coding: utf-8 -*-
|
||
# Author: Cemre ALPSOY <cemre.alpsoy@agem.com.tr>
|
||
# Author: Emre Akkaya <emre.akkaya@agem.com.tr>
|
||
|
||
from base.plugin.abstract_plugin import AbstractPlugin
|
||
from threading import Thread
|
||
import time
|
||
import psutil
|
||
import json
|
||
|
||
|
||
class ResourceUsage(AbstractPlugin):
|
||
def __init__(self, data, context):
|
||
super(AbstractPlugin, self).__init__()
|
||
self.data = data
|
||
self.context = context
|
||
self.logger = self.get_logger()
|
||
self.message_code = self.get_message_code()
|
||
self.is_running = False
|
||
self._threadCep = None
|
||
|
||
def handle_task(self):
|
||
try:
|
||
action = self.data['action']
|
||
self.logger.debug("Action: {0}".format(action))
|
||
|
||
if action == "start_timer":
|
||
self.is_running = True
|
||
with open('is_running.txt', 'w') as f:
|
||
f.write("%s" % str('true'))
|
||
self._threadCep = Thread(target=self.run_timer,
|
||
args=(int(self.data['interval']), self.context.get('task_id')))
|
||
self._threadCep.start()
|
||
data = {"status": "started"}
|
||
self.context.create_response(code=self.message_code.TASK_PROCESSED.value,
|
||
message='Kaynak kullanım bilgileri toplanmaya başlandı.', data=json.dumps(data), content_type=self.get_content_type().APPLICATION_JSON.value)
|
||
elif action == "stop_timer":
|
||
self.is_running = False
|
||
with open('is_running.txt', 'w') as f:
|
||
f.write("%s" % str('false'))
|
||
data = {"action": "stop"}
|
||
self.context.create_response(code=self.message_code.TASK_PROCESSED.value,
|
||
message='Kaynak kullanım bilgilerinin toplanması durduruldu.',
|
||
data=json.dumps(data), content_type=self.get_content_type().APPLICATION_JSON.value)
|
||
except Exception as e:
|
||
self.logger.error(str(e))
|
||
self.context.create_response(code=self.message_code.TASK_ERROR.value,
|
||
message='Kaynak kullanım bilgileri işlenirken hata oluştu: ' + str(e))
|
||
|
||
def run_timer(self, interval, task_id):
|
||
while self.is_running:
|
||
self.gather_resource_usage(task_id)
|
||
time.sleep(interval)
|
||
with open('is_running.txt', 'r') as f:
|
||
if f.read() == 'false':
|
||
self.is_running = False
|
||
|
||
def gather_resource_usage(self, task_id):
|
||
# Memory usage
|
||
memory_usage = psutil.virtual_memory()
|
||
self.logger.debug("Memory usage: {0}".format(memory_usage))
|
||
# Disk usage
|
||
disk_usage = psutil.disk_usage('/')
|
||
self.logger.debug("Disk usage: {0}".format(disk_usage))
|
||
# CPU usage
|
||
cpu_percentage = psutil.cpu_percent(interval=1)
|
||
self.logger.debug("CPU percentage: {0}".format(cpu_percentage))
|
||
|
||
data = {'memoryUsage': str(memory_usage), 'diskUsage': str(disk_usage), 'cpuPercentage': str(cpu_percentage)}
|
||
command = 'python3 /opt/ahenk/ahenkd.py send -t {0} -m {1} -s'.format(task_id, json.dumps(str(data)))
|
||
result_code, p_out, p_err = self.execute(command)
|
||
if result_code != 0:
|
||
self.logger.error("Error occurred while sending message: " + str(p_err))
|
||
|
||
|
||
def handle_task(task, context):
|
||
plugin = ResourceUsage(task, context)
|
||
plugin.handle_task()
|