This repository has been archived by the owner on Aug 3, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 23
/
Copy pathmain.py
executable file
·109 lines (75 loc) · 2.83 KB
/
main.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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
#!/usr/bin/env python
import sys
import os
# Cattle imports should go after this.
if __name__ == '__main__':
dist = os.path.join(os.path.dirname(__file__), "dist")
if os.path.exists(dist):
sys.path.insert(0, dist)
from cattle import concurrency # NOQA
import logging
from logging.handlers import RotatingFileHandler
import argparse
_LOG_SIZE = 20971520
_LOG_COUNT = 2
from cattle import plugins, Config, process_manager
from cattle.agent.event import EventClient
from cattle.type_manager import types, get_type_list, LIFECYCLE
log = logging.getLogger("agent")
def _setup_logger():
format = '%(asctime)s %(levelname)s %(name)s [%(thread)s] ' \
'[%(filename)s:%(lineno)s] %(message)s '
level = logging.INFO
if Config.debug():
level = logging.DEBUG
logging.root.setLevel(level)
file_handler = RotatingFileHandler(Config.log(), maxBytes=_LOG_SIZE,
backupCount=_LOG_COUNT)
file_handler.setFormatter(logging.Formatter(format))
std_err_handler = logging.StreamHandler(sys.stderr)
std_err_handler.setFormatter(logging.Formatter(format))
std_err_handler.setLevel(logging.WARN)
logging.root.addHandler(file_handler)
logging.root.addHandler(std_err_handler)
def _gather_events():
events = []
for t in types():
if hasattr(t, "events"):
for e in t.events():
events.append(e)
return events
def _args():
parser = argparse.ArgumentParser(add_help=True)
parser.add_argument("--access-key", default=Config.access_key(),
help='Default value from CATTLE_ACCESS_KEY')
parser.add_argument("--secret-key", default=Config.secret_key(),
help='Default value from CATTLE_SECRET_KEY')
parser.add_argument("--url", default=Config.api_url(),
help='Default value from CATTLE_URL')
parser.add_argument("--workers", default=Config.workers(),
help='Default value from CATTLE_WORKERS')
parser.add_argument("--agent-id")
return parser.parse_args()
def main():
if Config.setup_logger():
_setup_logger()
else:
logging.basicConfig(level=logging.INFO)
args = _args()
Config.set_access_key(args.access_key)
Config.set_secret_key(args.secret_key)
Config.set_api_url(args.url)
Config.physical_host_uuid(force_write=True)
process_manager.init()
plugins.load()
log.info('API URL %s', Config.api_url())
client = EventClient(Config.api_url(), auth=Config.api_auth(),
workers=args.workers, agent_id=args.agent_id)
events = _gather_events()
log.info("Subscribing to %s", events)
for startup in get_type_list(LIFECYCLE):
startup.on_startup()
client.run(events)
sys.exit(0)
if __name__ == '__main__':
main()