forked from twitter/twemproxy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
nc_core.h
140 lines (118 loc) · 3.45 KB
/
nc_core.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
/*
* twemproxy - A fast and lightweight proxy for memcached protocol.
* Copyright (C) 2011 Twitter, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef _NC_CORE_H_
#define _NC_CORE_H_
#ifdef HAVE_CONFIG_H
# include <config.h>
#endif
#ifdef HAVE_DEBUG_LOG
# define NC_DEBUG_LOG 1
#endif
#ifdef HAVE_ASSERT_PANIC
# define NC_ASSERT_PANIC 1
#endif
#ifdef HAVE_ASSERT_LOG
# define NC_ASSERT_LOG 1
#endif
#ifdef HAVE_STATS
# define NC_STATS 1
#else
# define NC_STATS 0
#endif
#ifdef HAVE_EPOLL
#define NC_HAVE_EPOLL 1
#elif HAVE_KQUEUE
#define NC_HAVE_KQUEUE 1
#endif
#ifdef HAVE_LITTLE_ENDIAN
# define NC_LITTLE_ENDIAN 1
#endif
#ifdef HAVE_BACKTRACE
#define NC_HAVE BACKTRACE 1
#endif
#define NC_OK 0
#define NC_ERROR -1
#define NC_EAGAIN -2
#define NC_ENOMEM -3
typedef int rstatus_t; /* return type */
typedef int err_t; /* error type */
struct array;
struct string;
struct context;
struct conn;
struct conn_tqh;
struct msg;
struct msg_tqh;
struct server;
struct server_pool;
struct mbuf;
struct mhdr;
struct conf;
struct stats;
struct epoll_event;
struct instance;
#include <stddef.h>
#include <stdint.h>
#include <stdbool.h>
#include <inttypes.h>
#include <string.h>
#include <errno.h>
#include <limits.h>
#include <time.h>
#include <unistd.h>
#include <pthread.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/un.h>
#include <netinet/in.h>
#include <nc_array.h>
#include <nc_string.h>
#include <nc_queue.h>
#include <nc_rbtree.h>
#include <nc_log.h>
#include <nc_util.h>
#include <nc_stats.h>
#include <nc_mbuf.h>
#include <nc_message.h>
#include <nc_connection.h>
struct context {
uint32_t id; /* unique context id */
struct conf *cf; /* configuration */
struct stats *stats; /* stats */
struct array pool; /* server_pool[] */
struct evbase *evb;
int max_timeout; /* epoll wait max timeout in msec */
int timeout;
};
struct instance {
struct context *ctx; /* active context */
int log_level; /* log level */
char *log_filename; /* log filename */
char *conf_filename; /* configuration filename */
uint16_t stats_port; /* stats monitoring port */
int stats_interval; /* stats aggregation interval */
char *stats_addr; /* stats monitoring addr */
char hostname[NC_MAXHOSTNAMELEN]; /* hostname */
size_t mbuf_chunk_size; /* mbuf chunk size */
pid_t pid; /* process id */
char *pid_filename; /* pid filename */
unsigned pidfile:1; /* pid file created? */
};
struct context *core_start(struct instance *nci);
void core_stop(struct context *ctx);
rstatus_t core_loop(struct context *ctx);
#endif