-
Notifications
You must be signed in to change notification settings - Fork 46
/
Copy pathrct_log.h
174 lines (142 loc) · 7.02 KB
/
rct_log.h
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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
#ifndef _RCT_LOG_H_
#define _RCT_LOG_H_
#define LOG_ROTATE_DEFAULT 0
#define LOG_FILE_MAX_SIZE_DEFAULT 1073741824
#define LOG_FILE_MAX_SIZE_MIN 1000000
#define LOG_FILE_MAX_SIZE_MAX 1122601371959296
#define LOG_FILE_COUNT_DEFAULT 10
#define LOG_FILE_COUNT_MIN -1
#define LOG_FILE_COUNT_MAX LOG_FILES_CIRCULAR_MAX_LEN
/* LOG_RORATE
* 0 : twemproxy do not use log rotate functionality.
* 1 : twemproxy use log rotate functionality.
*/
extern int LOG_RORATE;
extern ssize_t LOG_FIEL_MAX_SIZE_FOR_ROTATING;
/* LOG_FILE_COUNT_TO_STAY
* -1 : do not use log_files_circular, the log bak files do not delete anymore.
* =0 : there is no log bak files, only current log file exist.
* >0 : use log_files_circular, and only stay newest N log bak files.
*/
extern int LOG_FILE_COUNT_TO_STAY;
#define LOG_FILES_CIRCULAR_MAX_LEN 200
struct logger {
char *name; /* log file name */
int level; /* log level */
int fd; /* log file descriptor */
int nerror; /* # log error */
ssize_t current_log_size; /* log current size */
char* log_files_circular[LOG_FILES_CIRCULAR_MAX_LEN]; /* we allow stay LOG_FILE_COUNT_TO_STAY log files */
int circular_cur_pos; /* the current position for the circular */
bool circular_full; /* the log_files_circular already had LOG_FILE_COUNT_TO_STAY elements*/
};
#define LOG_EMERG 0 /* system in unusable */
#define LOG_ALERT 1 /* action must be taken immediately */
#define LOG_CRIT 2 /* critical conditions */
#define LOG_ERR 3 /* error conditions */
#define LOG_WARN 4 /* warning conditions */
#define LOG_NOTICE 5 /* normal but significant condition (default) */
#define LOG_INFO 6 /* informational */
#define LOG_DEBUG 7 /* debug messages */
#define LOG_VERB 8 /* verbose messages */
#define LOG_VVERB 9 /* verbose messages on crack */
#define LOG_VVVERB 10 /* verbose messages on ganga */
#define LOG_PVERB 11 /* periodic verbose messages on crack */
#define RCT_LOG_DEFAULT LOG_NOTICE
#define RCT_LOG_MIN LOG_EMERG
#define RCT_LOG_MAX LOG_PVERB
#define LOG_MAX_LEN 256 /* max length of log message */
/*
* log_stderr - log to stderr
* loga - log always
* loga_hexdump - log hexdump always
* log_error - error log messages
* log_warn - warning log messages
* log_panic - log messages followed by a panic
* ...
* log_debug - debug log messages based on a log level
* log_hexdump - hexadump -C of a log buffer
*/
#ifdef RCT_DEBUG_LOG
#define log_debug(_level, ...) do { \
if (log_loggable(_level) != 0) { \
_log(__FILE__, __LINE__, 0, __VA_ARGS__); \
} \
} while (0)
#define log_hexdump(_level, _data, _datalen, ...) do { \
if (log_loggable(_level) != 0) { \
_log(__FILE__, __LINE__, 0, __VA_ARGS__); \
_log_hexdump(__FILE__, __LINE__, (char *)(_data), (int)(_datalen), \
__VA_ARGS__); \
} \
} while (0)
#else
#define log_debug(_level, ...)
#define log_hexdump(_level, _data, _datalen, ...)
#endif
#define log_stderr(...) do { \
_log_stderr(__VA_ARGS__); \
} while (0)
#define log_stdout(...) do { \
_log_stdout(__VA_ARGS__); \
} while (0)
#define log_stdout_without_newline(...) do { \
_log_stdout_without_newline(__VA_ARGS__); \
} while (0)
#define log_safe(...) do { \
_log_safe(__VA_ARGS__); \
} while (0)
#define log_stderr_safe(...) do { \
_log_stderr_safe(__VA_ARGS__); \
} while (0)
#define loga(...) do { \
_log(__FILE__, __LINE__, 0, __VA_ARGS__); \
} while (0)
#define loga_hexdump(_data, _datalen, ...) do { \
_log(__FILE__, __LINE__, 0, __VA_ARGS__); \
_log_hexdump(__FILE__, __LINE__, (char *)(_data), (int)(_datalen), \
__VA_ARGS__); \
} while (0) \
#define log_error(...) do { \
if (log_loggable(LOG_ALERT) != 0) { \
_log(__FILE__, __LINE__, 0, __VA_ARGS__); \
} \
} while (0)
#define log_warn(...) do { \
if (log_loggable(LOG_WARN) != 0) { \
_log(__FILE__, __LINE__, 0, __VA_ARGS__); \
} \
} while (0)
#define log_panic(...) do { \
if (log_loggable(LOG_EMERG) != 0) { \
_log(__FILE__, __LINE__, 1, __VA_ARGS__); \
} \
} while (0)
int log_init(int level, char *filename);
void log_deinit(void);
void log_level_up(void);
void log_level_down(void);
void log_level_set(int level);
void log_stacktrace(void);
void log_reopen(void);
int log_loggable(int level);
void _log(const char *file, int line, int panic, const char *fmt, ...);
void _log_stderr(const char *fmt, ...);
void _log_stdout(const char *fmt, ...);
void _log_stdout_without_newline(const char *fmt, ...);
void _log_safe(const char *fmt, ...);
void _log_stderr_safe(const char *fmt, ...);
void _log_hexdump(const char *file, int line, char *data, int datalen, const char *fmt, ...);
int log_rotate_init(struct logger *l);
int _log_rotate_deinit(struct logger *l);
int _log_rotating(ssize_t write_bytes, struct logger *l);
int _log_files_circular_maintain(const char * file, struct logger *l);
int _is_log_bak_file(const char * logname, const char * filename);
int _log_files_circular_insert(const char * filename, struct logger *l);
int log_files_circular_init(struct logger *l);
int _log_files_circular_deinit(struct logger *l);
void _log_files_circular_info(struct logger *l);
char * set_log_file_max_size(char *arg);
char * set_log_file_count(char *arg);
void log_all(const char *file, int line, size_t data_len, uint8_t *data, const char *fmt, ...);
#endif