1 /* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
5 * Copyright (C) 2011 Data Differential, http://datadifferential.com/
6 * Copyright (C) 2006-2009 Brian Aker All rights reserved.
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions are
12 * * Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
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
20 * * The names of its contributors may not be used to endorse or
21 * promote products derived from this software without specific prior
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.
46 #define MEMCACHED_NI_MAXHOST NI_MAXHOST
48 #define MEMCACHED_NI_MAXHOST 1025
51 enum memcached_server_state_t
{
52 MEMCACHED_SERVER_STATE_NEW
, // fd == -1, no address lookup has been done
53 MEMCACHED_SERVER_STATE_ADDRINFO
, // ADDRRESS information has been gathered
54 MEMCACHED_SERVER_STATE_IN_PROGRESS
,
55 MEMCACHED_SERVER_STATE_CONNECTED
,
56 MEMCACHED_SERVER_STATE_IN_TIMEOUT
59 struct memcached_server_st
{
62 bool is_initialized
:1;
63 bool is_shutting_down
:1;
66 uint32_t number_of_hosts
;
67 uint32_t cursor_active
;
69 memcached_socket_t fd
;
70 uint32_t io_bytes_sent
; /* # bytes sent since last read */
71 uint32_t server_failure_counter
;
72 uint64_t server_failure_counter_query_id
;
75 enum memcached_server_state_t state
;
80 uint8_t major_version
; // Default definition of UINT8_MAX means that it has not been set.
81 uint8_t micro_version
; // ditto
82 uint8_t minor_version
; // ditto
83 memcached_connection_t type
;
85 size_t read_buffer_length
;
86 size_t read_data_length
;
87 size_t write_buffer_offset
;
88 struct addrinfo
*address_info
;
89 struct addrinfo
*address_info_next
;
92 uint64_t limit_maxbytes
;
93 struct memcached_error_t
*error_messages
;
94 char read_buffer
[MEMCACHED_MAX_BUFFER
];
95 char write_buffer
[MEMCACHED_MAX_BUFFER
];
96 char hostname
[MEMCACHED_NI_MAXHOST
];
105 memcached_return_t
memcached_server_cursor(const memcached_st
*ptr
,
106 const memcached_server_fn
*callback
,
108 uint32_t number_of_callbacks
);
111 memcached_server_instance_st
memcached_server_by_key(memcached_st
*ptr
,
114 memcached_return_t
*error
);
117 void memcached_server_error_reset(memcached_server_st
*ptr
);
120 void memcached_server_free(memcached_server_st
*ptr
);
123 memcached_server_st
*memcached_server_clone(memcached_server_st
*destination
,
124 memcached_server_st
*source
);
127 memcached_server_instance_st
memcached_server_get_last_disconnect(const memcached_st
*ptr
);
131 memcached_return_t
memcached_server_add_udp(memcached_st
*ptr
,
132 const char *hostname
,
135 memcached_return_t
memcached_server_add_unix_socket(memcached_st
*ptr
,
136 const char *filename
);
138 memcached_return_t
memcached_server_add(memcached_st
*ptr
,
139 const char *hostname
, in_port_t port
);
142 memcached_return_t
memcached_server_add_parsed(memcached_st
*ptr
,
143 const char *hostname
,
144 size_t hostname_length
,
149 memcached_return_t
memcached_server_add_udp_with_weight(memcached_st
*ptr
,
150 const char *hostname
,
154 memcached_return_t
memcached_server_add_unix_socket_with_weight(memcached_st
*ptr
,
155 const char *filename
,
158 memcached_return_t
memcached_server_add_with_weight(memcached_st
*ptr
, const char *hostname
,
163 Operations on Single Servers.
166 uint32_t memcached_server_response_count(const memcached_server_instance_st self
);
169 const char *memcached_server_name(const memcached_server_instance_st self
);
172 in_port_t
memcached_server_port(const memcached_server_instance_st self
);
175 const char *memcached_server_type(const memcached_server_instance_st ptr
);
179 void __server_free(memcached_server_st
*);