forked from microsoft/AIOpsLab
-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathmitigation.py
More file actions
77 lines (55 loc) · 2.88 KB
/
mitigation.py
File metadata and controls
77 lines (55 loc) · 2.88 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
# Copyright (c) Microsoft Corporation.
# Licensed under the MIT License.
"""Define and query information about an AIOps Mitigation task."""
import textwrap
from typing import Any
from aiopslab.orchestrator.tasks.base import Task
from aiopslab.orchestrator.actions.mitigation import MitigationActions
from aiopslab.service.apps.base import Application
from aiopslab.session import SessionItem
from aiopslab.utils.actions import get_actions
from aiopslab.utils.status import InvalidActionError
class MitigationTask(Task):
"""An AIOps anomaly mitigation task."""
def __init__(self, app: Application):
super().__init__()
self.app = app
self.helm_configs = self.app.helm_configs
self.app_summary = self.app.get_app_summary()
self.actions = MitigationActions()
self.task_desc = """\
You are an expert DevOps engineer assigned to mitigate anomalies in a deployed service.
Service Details:
{app_summary}
You will begin by analyzing the service's state and telemetry, and then submit a solution that mitigates any detected anomalies.
Your mitigation can be performed using any of the available APIs.
"""
self.instructions = """\
You will respond with one of the above APIs as your next action.
Please respond in the following format in a markdown code block:
```\n<API_NAME>(<API_PARAM1>, <API_PARAM2> ...)\n```
For instance, if you want to list files in current directory, your response must be exactly:
```\nexec_shell("ls -l")\n```
Once your solution is complete and ready for evaluation, you must call:
```\nsubmit()\n```
Note:
- The submit() call for the mitigation task does not take any parameters.
- A submission via submit() is considered valid if it is made, though this does not necessarily indicate that your solution is correct.
Please respond with only a single API call (a.k.a., action) per turn without any additional words, labels, or prefixes.
"""
def get_task_description(self):
return textwrap.dedent(self.task_desc).format(app_summary=self.app_summary)
def get_instructions(self):
return textwrap.dedent(self.instructions)
def get_available_actions(self):
return get_actions(task="mitigation")
def perform_action(self, action_name, *args, **kwargs):
action_method = getattr(self.actions, action_name, None)
if action_method is not None and callable(action_method):
return action_method(*args, **kwargs)
else:
raise InvalidActionError(action_name)
def eval(self, soln: Any, trace: list[SessionItem], duration: float):
self.add_result("TTM", duration)
self.common_eval(trace)
return self.results