-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathneon_maintenance.py
executable file
·80 lines (53 loc) · 2.76 KB
/
neon_maintenance.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
73
74
75
76
77
78
import argparse
import logging
from typing import List
from proxy.common_neon.maintenance_api import MaintenanceCommand, MaintenanceRequest, ReplicationRequest, Peer
from proxy.common_neon.utils.utils import gen_unique_id
from proxy.common_neon.pickable_data_server import AddrPickableDataClient
LOG = logging.getLogger(__name__)
class MaintenanceClient:
def __init__(self, address):
self.address = address
self._client = AddrPickableDataClient(address)
def suspend(self):
result = self._client.send_data(MaintenanceRequest(req_id=gen_unique_id(), command=MaintenanceCommand.SuspendMemPool))
LOG.info(f"The suspend command has been sent to the MemPool: {self.address}, result: {result}")
def resume(self):
result = self._client.send_data(MaintenanceRequest(req_id=gen_unique_id(), command=MaintenanceCommand.ResumeMemPool))
LOG.info(f"The resume command has been sent to the MemPool: {self.address}, result: {result}")
def replicate(self, peers: List[Peer]):
request = ReplicationRequest(peers=peers)
result = self._client.send_data(request)
LOG.info(f"The replicate command has been sent to the MemPool: {self.address}, result: {result}")
def main():
args = get_maintenance_args()
maintenance_client = MaintenanceClient((args.host, args.port))
if args.command == "suspend":
maintenance_client.suspend()
elif args.command == "resume":
maintenance_client.resume()
elif args.command == "replicate":
peers = [Peer(*(peer_info.split(":"))) for peer_info in args.peers]
maintenance_client.replicate(peers)
def get_maintenance_args():
examples = """
Examples:
suspend:
neon_maintenance.py --port 8092 suspend
resume:
neon_maintenance.py --host localhost --port 9092 resume
replicate:
python3 neon_maintenance.py replicate proxy-replica:9092
\x0D"""
parser = argparse.ArgumentParser(prog="neon_maintenance", formatter_class=argparse.RawDescriptionHelpFormatter, epilog=examples)
parser.add_argument("--host", type=str, required=False, default="127.0.0.1", help="Neon Proxy maintenance host to connect")
parser.add_argument("--port", type=int, required=False, default=9092, help="Neon Proxy maintenance port to connect")
subparsers = parser.add_subparsers(dest="command", help="subcommand help")
subparsers.add_parser("suspend", help="suspend Neon Proxy mempool")
subparsers.add_parser("resume", help="resume Neon Proxy mempool")
parser_replicate = subparsers.add_parser("replicate", help="replicate Neon Proxy mempool")
parser_replicate.add_argument("peers", nargs="+", help="other Neon Proxy peer address list to replicate to")
args = parser.parse_args()
return args
if __name__ == "__main__":
main()