a45616a1010109f2f814f8682381e0dba98514f0
[m6w6/libmemcached] / libmemcached / server.h
1 /* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
2 *
3 * Libmemcached library
4 *
5 * Copyright (C) 2011 Data Differential, http://datadifferential.com/
6 * Copyright (C) 2006-2009 Brian Aker All rights reserved.
7 *
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions are
10 * met:
11 *
12 * * Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 *
15 * * Redistributions in binary form must reproduce the above
16 * copyright notice, this list of conditions and the following disclaimer
17 * in the documentation and/or other materials provided with the
18 * distribution.
19 *
20 * * The names of its contributors may not be used to endorse or
21 * promote products derived from this software without specific prior
22 * written permission.
23 *
24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
25 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
26 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
27 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
28 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
29 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
30 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
31 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
32 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
33 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
34 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
35 *
36 */
37
38
39 #pragma once
40
41 enum memcached_server_state_t {
42 MEMCACHED_SERVER_STATE_NEW, // fd == -1, no address lookup has been done
43 MEMCACHED_SERVER_STATE_ADDRINFO, // ADDRRESS information has been gathered
44 MEMCACHED_SERVER_STATE_IN_PROGRESS,
45 MEMCACHED_SERVER_STATE_CONNECTED
46 };
47
48 struct memcached_server_st {
49 struct {
50 bool is_allocated:1;
51 bool is_initialized:1;
52 bool is_shutting_down:1;
53 bool is_dead:1;
54 } options;
55 uint32_t number_of_hosts;
56 uint32_t cursor_active;
57 in_port_t port;
58 memcached_socket_t fd;
59 uint32_t io_bytes_sent; /* # bytes sent since last read */
60 uint32_t server_failure_counter;
61 uint32_t weight;
62 enum memcached_server_state_t state;
63 struct {
64 uint32_t read;
65 uint32_t write;
66 } io_wait_count;
67 uint8_t major_version; // Default definition of UINT8_MAX means that it has not been set.
68 uint8_t micro_version; // ditto
69 uint8_t minor_version; // ditto
70 memcached_connection_t type;
71 char *read_ptr;
72 size_t read_buffer_length;
73 size_t read_data_length;
74 size_t write_buffer_offset;
75 struct addrinfo *address_info;
76 struct addrinfo *address_info_next;
77 time_t next_retry;
78 memcached_st *root;
79 uint64_t limit_maxbytes;
80 struct memcached_error_t *error_messages;
81 char read_buffer[MEMCACHED_MAX_BUFFER];
82 char write_buffer[MEMCACHED_MAX_BUFFER];
83 char hostname[NI_MAXHOST];
84 };
85
86
87 #ifdef __cplusplus
88 extern "C" {
89 #endif
90
91 LIBMEMCACHED_API
92 memcached_return_t memcached_server_cursor(const memcached_st *ptr,
93 const memcached_server_fn *callback,
94 void *context,
95 uint32_t number_of_callbacks);
96
97 LIBMEMCACHED_API
98 memcached_server_instance_st memcached_server_by_key(const memcached_st *ptr,
99 const char *key,
100 size_t key_length,
101 memcached_return_t *error);
102
103 LIBMEMCACHED_API
104 void memcached_server_error_reset(memcached_server_st *ptr);
105
106 LIBMEMCACHED_API
107 void memcached_server_free(memcached_server_st *ptr);
108
109 LIBMEMCACHED_LOCAL
110 memcached_server_st *memcached_server_clone(memcached_server_st *destination,
111 const memcached_server_st *source);
112
113 LIBMEMCACHED_API
114 memcached_server_instance_st memcached_server_get_last_disconnect(const memcached_st *ptr);
115
116
117 LIBMEMCACHED_API
118 memcached_return_t memcached_server_add_udp(memcached_st *ptr,
119 const char *hostname,
120 in_port_t port);
121 LIBMEMCACHED_API
122 memcached_return_t memcached_server_add_unix_socket(memcached_st *ptr,
123 const char *filename);
124 LIBMEMCACHED_API
125 memcached_return_t memcached_server_add(memcached_st *ptr,
126 const char *hostname, in_port_t port);
127
128 LIBMEMCACHED_LOCAL
129 memcached_return_t memcached_server_add_parsed(memcached_st *ptr,
130 const char *hostname,
131 size_t hostname_length,
132 in_port_t port,
133 uint32_t weight);
134
135 LIBMEMCACHED_API
136 memcached_return_t memcached_server_add_udp_with_weight(memcached_st *ptr,
137 const char *hostname,
138 in_port_t port,
139 uint32_t weight);
140 LIBMEMCACHED_API
141 memcached_return_t memcached_server_add_unix_socket_with_weight(memcached_st *ptr,
142 const char *filename,
143 uint32_t weight);
144 LIBMEMCACHED_API
145 memcached_return_t memcached_server_add_with_weight(memcached_st *ptr, const char *hostname,
146 in_port_t port,
147 uint32_t weight);
148
149 /**
150 Operations on Single Servers.
151 */
152 LIBMEMCACHED_API
153 uint32_t memcached_server_response_count(memcached_server_instance_st self);
154
155 LIBMEMCACHED_API
156 const char *memcached_server_name(memcached_server_instance_st self);
157
158 LIBMEMCACHED_API
159 in_port_t memcached_server_port(memcached_server_instance_st self);
160
161 LIBMEMCACHED_API
162 const char *memcached_server_type(memcached_server_instance_st ptr);
163
164
165 LIBMEMCACHED_LOCAL
166 void __server_free(memcached_server_st *);
167
168 #ifdef __cplusplus
169 } // extern "C"
170 #endif