-
Notifications
You must be signed in to change notification settings - Fork 36
/
Copy pathmitigation.py
72 lines (54 loc) · 2.49 KB
/
mitigation.py
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
# 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 who has been tasked with mitigating anomalies in a deployed service.
The service you are working with today is described below:
{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:
```
<API_NAME>(<API_PARAM1>, <API_PARAM2> ...)
```
For example:
```
exec_shell("ls -l") # will list files in current directory
```
Please respond with only a single action per turn.
"""
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