Show More
@@ -13,6 +13,7 b' import traceback' | |||||
13 | import random |
|
13 | import random | |
14 | import socket |
|
14 | import socket | |
15 | import dataclasses |
|
15 | import dataclasses | |
|
16 | import json | |||
16 | from gunicorn.glogging import Logger |
|
17 | from gunicorn.glogging import Logger | |
17 |
|
18 | |||
18 |
|
19 | |||
@@ -37,17 +38,41 b" accesslog = '-'" | |||||
37 | worker_tmp_dir = None |
|
38 | worker_tmp_dir = None | |
38 | tmp_upload_dir = None |
|
39 | tmp_upload_dir = None | |
39 |
|
40 | |||
40 | # use re-use port logic |
|
41 | # use re-use port logic to let linux internals load-balance the requests better. | |
41 |
|
|
42 | reuse_port = True | |
42 |
|
43 | |||
43 | # Custom log format |
|
44 | # Custom log format | |
44 | #access_log_format = ( |
|
45 | #access_log_format = ( | |
45 | # '%(t)s %(p)s INFO [GNCRN] %(h)-15s rqt:%(L)s %(s)s %(b)-6s "%(m)s:%(U)s %(q)s" usr:%(u)s "%(f)s" "%(a)s"') |
|
46 | # '%(t)s %(p)s INFO [GNCRN] %(h)-15s rqt:%(L)s %(s)s %(b)-6s "%(m)s:%(U)s %(q)s" usr:%(u)s "%(f)s" "%(a)s"') | |
46 |
|
47 | |||
47 | # loki format for easier parsing in grafana |
|
48 | # loki format for easier parsing in grafana | |
48 | access_log_format = ( |
|
49 | loki_access_log_format = ( | |
49 | 'time="%(t)s" pid=%(p)s level="INFO" type="[GNCRN]" ip="%(h)-15s" rqt="%(L)s" response_code="%(s)s" response_bytes="%(b)-6s" uri="%(m)s:%(U)s %(q)s" user=":%(u)s" user_agent="%(a)s"') |
|
50 | 'time="%(t)s" pid=%(p)s level="INFO" type="[GNCRN]" ip="%(h)-15s" rqt="%(L)s" response_code="%(s)s" response_bytes="%(b)-6s" uri="%(m)s:%(U)s %(q)s" user=":%(u)s" user_agent="%(a)s"') | |
50 |
|
51 | |||
|
52 | # JSON format | |||
|
53 | json_access_log_format = json.dumps({ | |||
|
54 | 'time': r'%(t)s', | |||
|
55 | 'pid': r'%(p)s', | |||
|
56 | 'level': 'INFO', | |||
|
57 | 'ip': r'%(h)s', | |||
|
58 | 'request_time': r'%(L)s', | |||
|
59 | 'remote_address': r'%(h)s', | |||
|
60 | 'user_name': r'%(u)s', | |||
|
61 | 'status': r'%(s)s', | |||
|
62 | 'method': r'%(m)s', | |||
|
63 | 'url_path': r'%(U)s', | |||
|
64 | 'query_string': r'%(q)s', | |||
|
65 | 'protocol': r'%(H)s', | |||
|
66 | 'response_length': r'%(B)s', | |||
|
67 | 'referer': r'%(f)s', | |||
|
68 | 'user_agent': r'%(a)s', | |||
|
69 | ||||
|
70 | }) | |||
|
71 | ||||
|
72 | access_log_format = loki_access_log_format | |||
|
73 | if os.environ.get('RC_LOGGING_FORMATTER') == 'json': | |||
|
74 | access_log_format = json_access_log_format | |||
|
75 | ||||
51 | # self adjust workers based on CPU count, to use maximum of CPU and not overquota the resources |
|
76 | # self adjust workers based on CPU count, to use maximum of CPU and not overquota the resources | |
52 | # workers = get_workers() |
|
77 | # workers = get_workers() | |
53 |
|
78 |
General Comments 0
You need to be logged in to leave comments.
Login now