vinted-memcached 1.8.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (210) hide show
  1. checksums.yaml +7 -0
  2. data/BENCHMARKS +142 -0
  3. data/CHANGELOG +176 -0
  4. data/Gemfile +11 -0
  5. data/Gemfile.lock +45 -0
  6. data/LICENSE +184 -0
  7. data/Manifest +209 -0
  8. data/README.rdoc +124 -0
  9. data/Rakefile +134 -0
  10. data/TODO +1 -0
  11. data/ext/extconf-make.rb +25 -0
  12. data/ext/extconf.rb +78 -0
  13. data/ext/libmemcached-0.32/AUTHORS +7 -0
  14. data/ext/libmemcached-0.32/COPYING +32 -0
  15. data/ext/libmemcached-0.32/ChangeLog +303 -0
  16. data/ext/libmemcached-0.32/INSTALL +302 -0
  17. data/ext/libmemcached-0.32/Makefile.am +36 -0
  18. data/ext/libmemcached-0.32/Makefile.in +911 -0
  19. data/ext/libmemcached-0.32/NEWS +1 -0
  20. data/ext/libmemcached-0.32/README +33 -0
  21. data/ext/libmemcached-0.32/THANKS +14 -0
  22. data/ext/libmemcached-0.32/TODO +11 -0
  23. data/ext/libmemcached-0.32/aclocal.m4 +2108 -0
  24. data/ext/libmemcached-0.32/clients/Makefile.am +80 -0
  25. data/ext/libmemcached-0.32/clients/Makefile.in +773 -0
  26. data/ext/libmemcached-0.32/clients/client_options.h +32 -0
  27. data/ext/libmemcached-0.32/clients/execute.c +64 -0
  28. data/ext/libmemcached-0.32/clients/execute.h +5 -0
  29. data/ext/libmemcached-0.32/clients/generator.c +74 -0
  30. data/ext/libmemcached-0.32/clients/generator.h +20 -0
  31. data/ext/libmemcached-0.32/clients/memcat.c +178 -0
  32. data/ext/libmemcached-0.32/clients/memcp.c +251 -0
  33. data/ext/libmemcached-0.32/clients/memdump.c +170 -0
  34. data/ext/libmemcached-0.32/clients/memerror.c +80 -0
  35. data/ext/libmemcached-0.32/clients/memflush.c +143 -0
  36. data/ext/libmemcached-0.32/clients/memrm.c +160 -0
  37. data/ext/libmemcached-0.32/clients/memslap.c +441 -0
  38. data/ext/libmemcached-0.32/clients/memstat.c +326 -0
  39. data/ext/libmemcached-0.32/clients/utilities.c +207 -0
  40. data/ext/libmemcached-0.32/clients/utilities.h +41 -0
  41. data/ext/libmemcached-0.32/config/compile +143 -0
  42. data/ext/libmemcached-0.32/config/config.guess +1561 -0
  43. data/ext/libmemcached-0.32/config/config.rpath +666 -0
  44. data/ext/libmemcached-0.32/config/config.sub +1686 -0
  45. data/ext/libmemcached-0.32/config/depcomp +630 -0
  46. data/ext/libmemcached-0.32/config/install-sh +520 -0
  47. data/ext/libmemcached-0.32/config/ltmain.sh +9636 -0
  48. data/ext/libmemcached-0.32/config/missing +376 -0
  49. data/ext/libmemcached-0.32/config.h.in +254 -0
  50. data/ext/libmemcached-0.32/configure +23843 -0
  51. data/ext/libmemcached-0.32/configure.ac +120 -0
  52. data/ext/libmemcached-0.32/libmemcached/Makefile.am +111 -0
  53. data/ext/libmemcached-0.32/libmemcached/Makefile.in +1069 -0
  54. data/ext/libmemcached-0.32/libmemcached/byteorder.c +31 -0
  55. data/ext/libmemcached-0.32/libmemcached/common.h +189 -0
  56. data/ext/libmemcached-0.32/libmemcached/crc.c +86 -0
  57. data/ext/libmemcached-0.32/libmemcached/hsieh_hash.c +68 -0
  58. data/ext/libmemcached-0.32/libmemcached/jenkins_hash.c +213 -0
  59. data/ext/libmemcached-0.32/libmemcached/libmemcached.ver +1 -0
  60. data/ext/libmemcached-0.32/libmemcached/libmemcached_probes.d +30 -0
  61. data/ext/libmemcached-0.32/libmemcached/libmemcached_probes.h +82 -0
  62. data/ext/libmemcached-0.32/libmemcached/md5.c +354 -0
  63. data/ext/libmemcached-0.32/libmemcached/memcached/README.txt +7 -0
  64. data/ext/libmemcached-0.32/libmemcached/memcached/protocol_binary.h +385 -0
  65. data/ext/libmemcached-0.32/libmemcached/memcached.c +153 -0
  66. data/ext/libmemcached-0.32/libmemcached/memcached.h +305 -0
  67. data/ext/libmemcached-0.32/libmemcached/memcached.hpp +799 -0
  68. data/ext/libmemcached-0.32/libmemcached/memcached_allocators.c +72 -0
  69. data/ext/libmemcached-0.32/libmemcached/memcached_analyze.c +100 -0
  70. data/ext/libmemcached-0.32/libmemcached/memcached_auto.c +207 -0
  71. data/ext/libmemcached-0.32/libmemcached/memcached_behavior.c +290 -0
  72. data/ext/libmemcached-0.32/libmemcached/memcached_callback.c +175 -0
  73. data/ext/libmemcached-0.32/libmemcached/memcached_configure.h.in +23 -0
  74. data/ext/libmemcached-0.32/libmemcached/memcached_connect.c +371 -0
  75. data/ext/libmemcached-0.32/libmemcached/memcached_constants.h +146 -0
  76. data/ext/libmemcached-0.32/libmemcached/memcached_delete.c +0 -0
  77. data/ext/libmemcached-0.32/libmemcached/memcached_do.c +72 -0
  78. data/ext/libmemcached-0.32/libmemcached/memcached_dump.c +79 -0
  79. data/ext/libmemcached-0.32/libmemcached/memcached_exist.c +114 -0
  80. data/ext/libmemcached-0.32/libmemcached/memcached_exist.h +20 -0
  81. data/ext/libmemcached-0.32/libmemcached/memcached_fetch.c +102 -0
  82. data/ext/libmemcached-0.32/libmemcached/memcached_flush.c +89 -0
  83. data/ext/libmemcached-0.32/libmemcached/memcached_flush_buffers.c +23 -0
  84. data/ext/libmemcached-0.32/libmemcached/memcached_get.c +494 -0
  85. data/ext/libmemcached-0.32/libmemcached/memcached_get.h +87 -0
  86. data/ext/libmemcached-0.32/libmemcached/memcached_hash.c +252 -0
  87. data/ext/libmemcached-0.32/libmemcached/memcached_hosts.c +510 -0
  88. data/ext/libmemcached-0.32/libmemcached/memcached_internal.h +31 -0
  89. data/ext/libmemcached-0.32/libmemcached/memcached_io.c +594 -0
  90. data/ext/libmemcached-0.32/libmemcached/memcached_io.h +72 -0
  91. data/ext/libmemcached-0.32/libmemcached/memcached_key.c +28 -0
  92. data/ext/libmemcached-0.32/libmemcached/memcached_parse.c +74 -0
  93. data/ext/libmemcached-0.32/libmemcached/memcached_pool.h +38 -0
  94. data/ext/libmemcached-0.32/libmemcached/memcached_purge.c +76 -0
  95. data/ext/libmemcached-0.32/libmemcached/memcached_quit.c +75 -0
  96. data/ext/libmemcached-0.32/libmemcached/memcached_response.c +529 -0
  97. data/ext/libmemcached-0.32/libmemcached/memcached_result.c +57 -0
  98. data/ext/libmemcached-0.32/libmemcached/memcached_result.h +59 -0
  99. data/ext/libmemcached-0.32/libmemcached/memcached_sasl.c +225 -0
  100. data/ext/libmemcached-0.32/libmemcached/memcached_sasl.h +44 -0
  101. data/ext/libmemcached-0.32/libmemcached/memcached_server.c +159 -0
  102. data/ext/libmemcached-0.32/libmemcached/memcached_server.h +93 -0
  103. data/ext/libmemcached-0.32/libmemcached/memcached_stats.c +437 -0
  104. data/ext/libmemcached-0.32/libmemcached/memcached_storage.c +514 -0
  105. data/ext/libmemcached-0.32/libmemcached/memcached_storage.h +107 -0
  106. data/ext/libmemcached-0.32/libmemcached/memcached_strerror.c +92 -0
  107. data/ext/libmemcached-0.32/libmemcached/memcached_string.c +138 -0
  108. data/ext/libmemcached-0.32/libmemcached/memcached_string.h +53 -0
  109. data/ext/libmemcached-0.32/libmemcached/memcached_touch.c +60 -0
  110. data/ext/libmemcached-0.32/libmemcached/memcached_touch.h +31 -0
  111. data/ext/libmemcached-0.32/libmemcached/memcached_types.h +44 -0
  112. data/ext/libmemcached-0.32/libmemcached/memcached_util.h +15 -0
  113. data/ext/libmemcached-0.32/libmemcached/memcached_verbosity.c +36 -0
  114. data/ext/libmemcached-0.32/libmemcached/memcached_version.c +112 -0
  115. data/ext/libmemcached-0.32/libmemcached/memcached_watchpoint.h +38 -0
  116. data/ext/libmemcached-0.32/libmemcached/murmur_hash.c +76 -0
  117. data/ext/libmemcached-0.32/libmemcached/visibility.h +51 -0
  118. data/ext/libmemcached-0.32/libmemcachedutil/Makefile.am +11 -0
  119. data/ext/libmemcached-0.32/libmemcachedutil/Makefile.in +604 -0
  120. data/ext/libmemcached-0.32/libmemcachedutil/libmemcachedutil.ver +1 -0
  121. data/ext/libmemcached-0.32/libmemcachedutil/memcached_pool.c +170 -0
  122. data/ext/libmemcached-0.32/m4/ac_cxx_compile_stdcxx_0x.m4 +103 -0
  123. data/ext/libmemcached-0.32/m4/ac_cxx_header_stdcxx_98.m4 +67 -0
  124. data/ext/libmemcached-0.32/m4/acx_pthread.m4 +276 -0
  125. data/ext/libmemcached-0.32/m4/byteorder.m4 +40 -0
  126. data/ext/libmemcached-0.32/m4/deprecated.m4 +17 -0
  127. data/ext/libmemcached-0.32/m4/enable_utillib.m4 +16 -0
  128. data/ext/libmemcached-0.32/m4/extensions.m4 +94 -0
  129. data/ext/libmemcached-0.32/m4/hsieh.m4 +18 -0
  130. data/ext/libmemcached-0.32/m4/lib-prefix.m4 +221 -0
  131. data/ext/libmemcached-0.32/m4/libtool.m4 +7831 -0
  132. data/ext/libmemcached-0.32/m4/ltoptions.m4 +369 -0
  133. data/ext/libmemcached-0.32/m4/ltsugar.m4 +123 -0
  134. data/ext/libmemcached-0.32/m4/ltversion.m4 +23 -0
  135. data/ext/libmemcached-0.32/m4/lt~obsolete.m4 +98 -0
  136. data/ext/libmemcached-0.32/m4/memcached.m4 +30 -0
  137. data/ext/libmemcached-0.32/m4/pandora_64bit.m4 +55 -0
  138. data/ext/libmemcached-0.32/m4/pandora_canonical.m4 +151 -0
  139. data/ext/libmemcached-0.32/m4/pandora_check_compiler_version.m4 +37 -0
  140. data/ext/libmemcached-0.32/m4/pandora_check_cxx_standard.m4 +16 -0
  141. data/ext/libmemcached-0.32/m4/pandora_enable_dtrace.m4 +41 -0
  142. data/ext/libmemcached-0.32/m4/pandora_ensure_gcc_version.m4 +36 -0
  143. data/ext/libmemcached-0.32/m4/pandora_have_better_malloc.m4 +54 -0
  144. data/ext/libmemcached-0.32/m4/pandora_have_sasl.m4 +133 -0
  145. data/ext/libmemcached-0.32/m4/pandora_header_assert.m4 +23 -0
  146. data/ext/libmemcached-0.32/m4/pandora_libtool.m4 +15 -0
  147. data/ext/libmemcached-0.32/m4/pandora_optimize.m4 +79 -0
  148. data/ext/libmemcached-0.32/m4/pandora_shared_ptr.m4 +56 -0
  149. data/ext/libmemcached-0.32/m4/pandora_vc_build.m4 +32 -0
  150. data/ext/libmemcached-0.32/m4/pandora_warnings.m4 +262 -0
  151. data/ext/libmemcached-0.32/m4/pod2man.m4 +7 -0
  152. data/ext/libmemcached-0.32/m4/protocol_binary.m4 +23 -0
  153. data/ext/libmemcached-0.32/m4/setsockopt.m4 +57 -0
  154. data/ext/libmemcached-0.32/m4/visibility.m4 +52 -0
  155. data/ext/libmemcached-0.32/support/Makefile.am +4 -0
  156. data/ext/libmemcached-0.32/support/Makefile.in +487 -0
  157. data/ext/libmemcached-0.32/support/libmemcached-fc.spec.in +105 -0
  158. data/ext/libmemcached-0.32/support/libmemcached.pc.in +10 -0
  159. data/ext/libmemcached-0.32/support/libmemcached.spec +105 -0
  160. data/ext/libmemcached-0.32/support/libmemcached.spec.in +105 -0
  161. data/ext/libmemcached-0.32/support/set_benchmark.sh +5 -0
  162. data/ext/libmemcached-0.32/tests/Makefile.am +113 -0
  163. data/ext/libmemcached-0.32/tests/Makefile.in +762 -0
  164. data/ext/libmemcached-0.32/tests/atomsmasher.c +245 -0
  165. data/ext/libmemcached-0.32/tests/function.c +4904 -0
  166. data/ext/libmemcached-0.32/tests/ketama_test_cases.h +108 -0
  167. data/ext/libmemcached-0.32/tests/output.cmp +7 -0
  168. data/ext/libmemcached-0.32/tests/output.res +7 -0
  169. data/ext/libmemcached-0.32/tests/output2.res +46 -0
  170. data/ext/libmemcached-0.32/tests/plus.cpp +293 -0
  171. data/ext/libmemcached-0.32/tests/r/memcat.res +19 -0
  172. data/ext/libmemcached-0.32/tests/r/memcp.res +27 -0
  173. data/ext/libmemcached-0.32/tests/r/memrm.res +19 -0
  174. data/ext/libmemcached-0.32/tests/r/memslap.res +33 -0
  175. data/ext/libmemcached-0.32/tests/r/memstat.res +33 -0
  176. data/ext/libmemcached-0.32/tests/server.c +118 -0
  177. data/ext/libmemcached-0.32/tests/server.h +25 -0
  178. data/ext/libmemcached-0.32/tests/start.c +16 -0
  179. data/ext/libmemcached-0.32/tests/t/memcat.test +4 -0
  180. data/ext/libmemcached-0.32/tests/t/memcp.test +3 -0
  181. data/ext/libmemcached-0.32/tests/t/memrm.test +3 -0
  182. data/ext/libmemcached-0.32/tests/t/memslap.test +5 -0
  183. data/ext/libmemcached-0.32/tests/t/memstat.test +3 -0
  184. data/ext/libmemcached-0.32/tests/test.c +137 -0
  185. data/ext/libmemcached-0.32/tests/test.h +46 -0
  186. data/ext/libmemcached-0.32/tests/udp.c +76 -0
  187. data/ext/rlibmemcached.i +258 -0
  188. data/ext/rlibmemcached_wrap.c +13917 -0
  189. data/lib/memcached/auth.rb +16 -0
  190. data/lib/memcached/behaviors.rb +78 -0
  191. data/lib/memcached/exceptions.rb +84 -0
  192. data/lib/memcached/experimental.rb +48 -0
  193. data/lib/memcached/marshal_codec.rb +10 -0
  194. data/lib/memcached/memcached.rb +732 -0
  195. data/lib/memcached/rails.rb +250 -0
  196. data/lib/memcached.rb +33 -0
  197. data/memcached.gemspec +0 -0
  198. data/test/profile/benchmark.rb +280 -0
  199. data/test/profile/c_profiler.rb +14 -0
  200. data/test/profile/exercise.rb +185 -0
  201. data/test/profile/rb_profiler.rb +21 -0
  202. data/test/profile/valgrind.rb +10 -0
  203. data/test/setup.rb +30 -0
  204. data/test/teardown.rb +0 -0
  205. data/test/test_helper.rb +18 -0
  206. data/test/unit/binding_test.rb +8 -0
  207. data/test/unit/memcached_experimental_test.rb +272 -0
  208. data/test/unit/memcached_test.rb +1487 -0
  209. data/test/unit/rails_test.rb +330 -0
  210. metadata +336 -0
@@ -0,0 +1,175 @@
1
+ #include "common.h"
2
+ #include <sys/types.h>
3
+ #include <sys/socket.h>
4
+ #include <netinet/tcp.h>
5
+
6
+ /*
7
+ These functions provide data and function callback support
8
+ */
9
+
10
+ memcached_return memcached_callback_set(memcached_st *ptr,
11
+ memcached_callback flag,
12
+ void *data)
13
+ {
14
+ switch (flag)
15
+ {
16
+ case MEMCACHED_CALLBACK_PREFIX_KEY:
17
+ {
18
+ char *key= (char *)data;
19
+
20
+ if (key)
21
+ {
22
+ size_t key_length= strlen(key);
23
+
24
+ if (memcached_key_test((const char **)&key, &key_length, 1) == MEMCACHED_BAD_KEY_PROVIDED)
25
+ {
26
+ return MEMCACHED_BAD_KEY_PROVIDED;
27
+ }
28
+
29
+ if ((key_length > MEMCACHED_PREFIX_KEY_MAX_SIZE -1)
30
+ || (strcpy(ptr->prefix_key, key) == NULL))
31
+ {
32
+ ptr->prefix_key_length= 0;
33
+ return MEMCACHED_BAD_KEY_PROVIDED;
34
+ }
35
+ else
36
+ {
37
+ ptr->prefix_key_length= key_length;
38
+ }
39
+ }
40
+ else
41
+ {
42
+ memset(ptr->prefix_key, 0, MEMCACHED_PREFIX_KEY_MAX_SIZE);
43
+ ptr->prefix_key_length= 0;
44
+ }
45
+
46
+ break;
47
+ }
48
+ case MEMCACHED_CALLBACK_USER_DATA:
49
+ {
50
+ ptr->user_data= data;
51
+ break;
52
+ }
53
+ case MEMCACHED_CALLBACK_CLEANUP_FUNCTION:
54
+ {
55
+ memcached_cleanup_func func= *(memcached_cleanup_func *)&data;
56
+ ptr->on_cleanup= func;
57
+ break;
58
+ }
59
+ case MEMCACHED_CALLBACK_CLONE_FUNCTION:
60
+ {
61
+ memcached_clone_func func= *(memcached_clone_func *)&data;
62
+ ptr->on_clone= func;
63
+ break;
64
+ }
65
+ #ifdef MEMCACHED_ENABLE_DEPRECATED
66
+ case MEMCACHED_CALLBACK_MALLOC_FUNCTION:
67
+ {
68
+ memcached_malloc_function func= *(memcached_malloc_function *)&data;
69
+ ptr->call_malloc= func;
70
+ break;
71
+ }
72
+ case MEMCACHED_CALLBACK_REALLOC_FUNCTION:
73
+ {
74
+ memcached_realloc_function func= *(memcached_realloc_function *)&data;
75
+ ptr->call_realloc= func;
76
+ break;
77
+ }
78
+ case MEMCACHED_CALLBACK_FREE_FUNCTION:
79
+ {
80
+ memcached_free_function func= *(memcached_free_function *)&data;
81
+ ptr->call_free= func;
82
+ break;
83
+ }
84
+ #endif
85
+ case MEMCACHED_CALLBACK_GET_FAILURE:
86
+ {
87
+ memcached_trigger_key func= *(memcached_trigger_key *)&data;
88
+ ptr->get_key_failure= func;
89
+ break;
90
+ }
91
+ case MEMCACHED_CALLBACK_DELETE_TRIGGER:
92
+ {
93
+ memcached_trigger_delete_key func= *(memcached_trigger_delete_key *)&data;
94
+ ptr->delete_trigger= func;
95
+ break;
96
+ }
97
+ default:
98
+ return MEMCACHED_FAILURE;
99
+ }
100
+
101
+ return MEMCACHED_SUCCESS;
102
+ }
103
+
104
+ void *memcached_callback_get(memcached_st *ptr,
105
+ memcached_callback flag,
106
+ memcached_return *error)
107
+ {
108
+ memcached_return local_error;
109
+
110
+ if (!error)
111
+ error = &local_error;
112
+
113
+ switch (flag)
114
+ {
115
+ case MEMCACHED_CALLBACK_PREFIX_KEY:
116
+ {
117
+ if (ptr->prefix_key[0] == 0)
118
+ {
119
+ *error= MEMCACHED_FAILURE;
120
+ return NULL;
121
+ }
122
+ else
123
+ {
124
+ *error= MEMCACHED_SUCCESS;
125
+ return (void *)ptr->prefix_key;
126
+ }
127
+ }
128
+ case MEMCACHED_CALLBACK_USER_DATA:
129
+ {
130
+ *error= ptr->user_data ? MEMCACHED_SUCCESS : MEMCACHED_FAILURE;
131
+ return (void *)ptr->user_data;
132
+ }
133
+ case MEMCACHED_CALLBACK_CLEANUP_FUNCTION:
134
+ {
135
+ *error= ptr->on_cleanup ? MEMCACHED_SUCCESS : MEMCACHED_FAILURE;
136
+ return *(void **)&ptr->on_cleanup;
137
+ }
138
+ case MEMCACHED_CALLBACK_CLONE_FUNCTION:
139
+ {
140
+ *error= ptr->on_clone ? MEMCACHED_SUCCESS : MEMCACHED_FAILURE;
141
+ return *(void **)&ptr->on_clone;
142
+ }
143
+ #ifdef MEMCACHED_ENABLE_DEPRECATED
144
+ case MEMCACHED_CALLBACK_MALLOC_FUNCTION:
145
+ {
146
+ *error= ptr->call_malloc ? MEMCACHED_SUCCESS : MEMCACHED_FAILURE;
147
+ return *(void **)&ptr->call_malloc;
148
+ }
149
+ case MEMCACHED_CALLBACK_REALLOC_FUNCTION:
150
+ {
151
+ *error= ptr->call_realloc ? MEMCACHED_SUCCESS : MEMCACHED_FAILURE;
152
+ return *(void **)&ptr->call_realloc;
153
+ }
154
+ case MEMCACHED_CALLBACK_FREE_FUNCTION:
155
+ {
156
+ *error= ptr->call_free ? MEMCACHED_SUCCESS : MEMCACHED_FAILURE;
157
+ return *(void **)&ptr->call_free;
158
+ }
159
+ #endif
160
+ case MEMCACHED_CALLBACK_GET_FAILURE:
161
+ {
162
+ *error= ptr->get_key_failure ? MEMCACHED_SUCCESS : MEMCACHED_FAILURE;
163
+ return *(void **)&ptr->get_key_failure;
164
+ }
165
+ case MEMCACHED_CALLBACK_DELETE_TRIGGER:
166
+ {
167
+ *error= ptr->delete_trigger ? MEMCACHED_SUCCESS : MEMCACHED_FAILURE;
168
+ return *(void **)&ptr->delete_trigger;
169
+ }
170
+ default:
171
+ WATCHPOINT_ASSERT(0);
172
+ *error= MEMCACHED_FAILURE;
173
+ return NULL;
174
+ }
175
+ }
@@ -0,0 +1,23 @@
1
+ /*
2
+ * Summary: Preprocessor symbols set from configure we need install-time
3
+ *
4
+ * Copy: See Copyright for the status of this software.
5
+ *
6
+ * Author: Trond Norbye
7
+ */
8
+
9
+ #ifndef MEMCACHED_CONFIGURE_H
10
+ #define MEMCACHED_CONFIGURE_H
11
+
12
+ #ifdef __cplusplus
13
+ extern "C" {
14
+ #endif
15
+
16
+ @DEPRECATED@
17
+ @LIBMEMCACHED_WITH_SASL_SUPPORT@
18
+
19
+ #ifdef __cplusplus
20
+ }
21
+ #endif
22
+
23
+ #endif /* MEMCACHED_CONFIGURE_H */
@@ -0,0 +1,371 @@
1
+ #include "common.h"
2
+ #include <netdb.h>
3
+ #include <poll.h>
4
+ #include <sys/time.h>
5
+
6
+ static memcached_return set_hostinfo(memcached_server_st *server)
7
+ {
8
+ struct addrinfo *ai;
9
+ struct addrinfo hints;
10
+ int e;
11
+ char str_port[NI_MAXSERV];
12
+
13
+ sprintf(str_port, "%u", server->port);
14
+
15
+ memset(&hints, 0, sizeof(hints));
16
+
17
+ // hints.ai_family= AF_INET;
18
+ if (server->type == MEMCACHED_CONNECTION_UDP)
19
+ {
20
+ hints.ai_protocol= IPPROTO_UDP;
21
+ hints.ai_socktype= SOCK_DGRAM;
22
+ }
23
+ else
24
+ {
25
+ hints.ai_socktype= SOCK_STREAM;
26
+ hints.ai_protocol= IPPROTO_TCP;
27
+ }
28
+
29
+ e= getaddrinfo(server->hostname, str_port, &hints, &ai);
30
+ if (e != 0)
31
+ {
32
+ WATCHPOINT_STRING(server->hostname);
33
+ WATCHPOINT_STRING(gai_strerror(e));
34
+ return MEMCACHED_HOST_LOOKUP_FAILURE;
35
+ }
36
+
37
+ if (server->address_info)
38
+ {
39
+ freeaddrinfo(server->address_info);
40
+ server->address_info= NULL;
41
+ }
42
+ server->address_info= ai;
43
+
44
+ return MEMCACHED_SUCCESS;
45
+ }
46
+
47
+ static memcached_return set_socket_options(memcached_server_st *ptr)
48
+ {
49
+ WATCHPOINT_ASSERT(ptr->fd != -1);
50
+
51
+ if (ptr->type == MEMCACHED_CONNECTION_UDP)
52
+ return MEMCACHED_SUCCESS;
53
+
54
+ #ifdef HAVE_SNDTIMEO
55
+ if (ptr->root->snd_timeout)
56
+ {
57
+ int error;
58
+ struct timeval waittime;
59
+
60
+ if (ptr->root->snd_timeout >= (1000 * 1000)) {
61
+ waittime.tv_sec= ptr->root->snd_timeout / (1000 * 1000);
62
+ waittime.tv_usec= ptr->root->snd_timeout % (1000 * 1000);
63
+ } else {
64
+ waittime.tv_sec= 0;
65
+ waittime.tv_usec= ptr->root->snd_timeout;
66
+ }
67
+
68
+ error= setsockopt(ptr->fd, SOL_SOCKET, SO_SNDTIMEO,
69
+ &waittime, (socklen_t)sizeof(struct timeval));
70
+ WATCHPOINT_ASSERT(error == 0);
71
+ }
72
+ #endif
73
+
74
+ #ifdef HAVE_RCVTIMEO
75
+ if (ptr->root->rcv_timeout)
76
+ {
77
+ int error;
78
+ struct timeval waittime;
79
+
80
+ if (ptr->root->rcv_timeout >= (1000 * 1000)) {
81
+ waittime.tv_sec= ptr->root->rcv_timeout / (1000 * 1000);
82
+ waittime.tv_usec= ptr->root->rcv_timeout % (1000 * 1000);
83
+ } else {
84
+ waittime.tv_sec= 0;
85
+ waittime.tv_usec= ptr->root->rcv_timeout;
86
+ }
87
+
88
+ error= setsockopt(ptr->fd, SOL_SOCKET, SO_RCVTIMEO,
89
+ &waittime, (socklen_t)sizeof(struct timeval));
90
+ WATCHPOINT_ASSERT(error == 0);
91
+ }
92
+ #endif
93
+
94
+ if (ptr->root->flags & MEM_NO_BLOCK)
95
+ {
96
+ int error;
97
+ struct linger linger;
98
+
99
+ linger.l_onoff= 1;
100
+ linger.l_linger= 0; /* By default on close() just drop the socket */
101
+ error= setsockopt(ptr->fd, SOL_SOCKET, SO_LINGER,
102
+ &linger, (socklen_t)sizeof(struct linger));
103
+ WATCHPOINT_ASSERT(error == 0);
104
+ }
105
+
106
+ if (ptr->root->flags & MEM_TCP_NODELAY)
107
+ {
108
+ int flag= 1;
109
+ int error;
110
+
111
+ error= setsockopt(ptr->fd, IPPROTO_TCP, TCP_NODELAY,
112
+ &flag, (socklen_t)sizeof(int));
113
+ WATCHPOINT_ASSERT(error == 0);
114
+ }
115
+
116
+ if (ptr->root->send_size)
117
+ {
118
+ int error;
119
+
120
+ error= setsockopt(ptr->fd, SOL_SOCKET, SO_SNDBUF,
121
+ &ptr->root->send_size, (socklen_t)sizeof(int));
122
+ WATCHPOINT_ASSERT(error == 0);
123
+ }
124
+
125
+ if (ptr->root->recv_size)
126
+ {
127
+ int error;
128
+
129
+ error= setsockopt(ptr->fd, SOL_SOCKET, SO_RCVBUF,
130
+ &ptr->root->recv_size, (socklen_t)sizeof(int));
131
+ WATCHPOINT_ASSERT(error == 0);
132
+ }
133
+
134
+ /* For the moment, not getting a nonblocking mode will not be fatal */
135
+ if ((ptr->root->flags & MEM_NO_BLOCK) || ptr->root->connect_timeout)
136
+ {
137
+ int flags;
138
+
139
+ flags= fcntl(ptr->fd, F_GETFL, 0);
140
+ unlikely (flags != -1)
141
+ {
142
+ (void)fcntl(ptr->fd, F_SETFL, flags | O_NONBLOCK);
143
+ }
144
+ }
145
+
146
+ return MEMCACHED_SUCCESS;
147
+ }
148
+
149
+ static memcached_return unix_socket_connect(memcached_server_st *ptr)
150
+ {
151
+ struct sockaddr_un servAddr;
152
+ socklen_t addrlen;
153
+
154
+ if (ptr->fd == -1)
155
+ {
156
+ if ((ptr->fd= socket(AF_UNIX, SOCK_STREAM, 0)) < 0)
157
+ {
158
+ ptr->cached_errno= errno;
159
+ return MEMCACHED_CONNECTION_SOCKET_CREATE_FAILURE;
160
+ }
161
+
162
+ memset(&servAddr, 0, sizeof (struct sockaddr_un));
163
+ servAddr.sun_family= AF_UNIX;
164
+ strcpy(servAddr.sun_path, ptr->hostname); /* Copy filename */
165
+
166
+ addrlen= (socklen_t) (strlen(servAddr.sun_path) + sizeof(servAddr.sun_family));
167
+
168
+ test_connect:
169
+ if (connect(ptr->fd,
170
+ (struct sockaddr *)&servAddr,
171
+ sizeof(servAddr)) < 0)
172
+ {
173
+ switch (errno)
174
+ {
175
+ case EINPROGRESS:
176
+ case EALREADY:
177
+ case EINTR:
178
+ goto test_connect;
179
+ case EISCONN: /* We were spinning waiting on connect */
180
+ break;
181
+ default:
182
+ WATCHPOINT_ERRNO(errno);
183
+ ptr->cached_errno= errno;
184
+ return MEMCACHED_ERRNO;
185
+ }
186
+ }
187
+ }
188
+
189
+ WATCHPOINT_ASSERT(ptr->fd != -1);
190
+ return MEMCACHED_SUCCESS;
191
+ }
192
+
193
+ static memcached_return network_connect(memcached_server_st *ptr)
194
+ {
195
+ if (ptr->fd == -1)
196
+ {
197
+ struct addrinfo *use;
198
+
199
+ if (!ptr->sockaddr_inited ||
200
+ (!(ptr->root->flags & MEM_USE_CACHE_LOOKUPS)))
201
+ {
202
+ memcached_return rc;
203
+
204
+ rc= set_hostinfo(ptr);
205
+ if (rc != MEMCACHED_SUCCESS)
206
+ return rc;
207
+ ptr->sockaddr_inited= true;
208
+ }
209
+
210
+ use= ptr->address_info;
211
+ /* Create the socket */
212
+ while (use != NULL)
213
+ {
214
+ /* Memcache server does not support IPV6 in udp mode, so skip if not ipv4 */
215
+ if (ptr->type == MEMCACHED_CONNECTION_UDP && use->ai_family != AF_INET)
216
+ {
217
+ use= use->ai_next;
218
+ continue;
219
+ }
220
+
221
+ if ((ptr->fd= socket(use->ai_family,
222
+ use->ai_socktype,
223
+ use->ai_protocol)) < 0)
224
+ {
225
+ ptr->cached_errno= errno;
226
+ WATCHPOINT_ERRNO(errno);
227
+ return MEMCACHED_CONNECTION_SOCKET_CREATE_FAILURE;
228
+ }
229
+
230
+ (void)set_socket_options(ptr);
231
+
232
+ int flags= 0;
233
+ if (ptr->root->connect_timeout)
234
+ {
235
+ flags= fcntl(ptr->fd, F_GETFL, 0);
236
+ if (flags != -1 && !(flags & O_NONBLOCK))
237
+ (void)fcntl(ptr->fd, F_SETFL, flags | O_NONBLOCK);
238
+ }
239
+
240
+ /* connect to server */
241
+ while (ptr->fd != -1 &&
242
+ connect(ptr->fd, use->ai_addr, use->ai_addrlen) < 0)
243
+ {
244
+ ptr->cached_errno= errno;
245
+ if (errno == EINPROGRESS || /* nonblocking mode - first return, */
246
+ errno == EALREADY) /* nonblocking mode - subsequent returns */
247
+ {
248
+ struct pollfd fds[1];
249
+ fds[0].fd = ptr->fd;
250
+ fds[0].events = POLLOUT;
251
+ int error= poll(fds, 1, ptr->root->connect_timeout);
252
+
253
+ if (error != 1 || fds[0].revents & POLLERR)
254
+ {
255
+ ptr->cached_errno = 0;
256
+
257
+ if (fds[0].revents & POLLERR)
258
+ {
259
+ int err;
260
+ socklen_t len = sizeof (err);
261
+ (void)getsockopt(ptr->fd, SOL_SOCKET, SO_ERROR, &err, &len);
262
+ ptr->cached_errno= (err == 0) ? errno : err;
263
+ }
264
+
265
+ (void)close(ptr->fd);
266
+ ptr->fd= -1;
267
+ }
268
+ }
269
+ else if (errno == EISCONN) /* we are connected :-) */
270
+ {
271
+ break;
272
+ }
273
+ else if (errno != EINTR)
274
+ {
275
+ (void)close(ptr->fd);
276
+ ptr->fd= -1;
277
+ break;
278
+ }
279
+ }
280
+
281
+ #ifdef LIBMEMCACHED_WITH_SASL_SUPPORT
282
+ if (ptr->fd != -1 && ptr->root->sasl_callbacks != NULL)
283
+ {
284
+ memcached_return rc= memcached_sasl_authenticate_connection(ptr);
285
+ if (rc != MEMCACHED_SUCCESS)
286
+ {
287
+ (void)close(ptr->fd);
288
+ ptr->fd= -1;
289
+ return rc;
290
+ }
291
+ }
292
+ #endif
293
+
294
+
295
+ if (ptr->fd != -1)
296
+ {
297
+ /* restore flags */
298
+ if (ptr->root->connect_timeout && (ptr->root->flags & MEM_NO_BLOCK) == 0)
299
+ (void)fcntl(ptr->fd, F_SETFL, flags & ~O_NONBLOCK);
300
+
301
+ WATCHPOINT_ASSERT(ptr->cursor_active == 0);
302
+ return MEMCACHED_SUCCESS;
303
+ }
304
+ use = use->ai_next;
305
+ }
306
+ }
307
+
308
+ if (ptr->fd == -1)
309
+ {
310
+ ptr->server_failure_counter ++;
311
+ if (ptr->cached_errno == 0)
312
+ return MEMCACHED_TIMEOUT;
313
+
314
+ return MEMCACHED_ERRNO; /* The last error should be from connect() */
315
+ }
316
+
317
+ return MEMCACHED_SUCCESS; /* The last error should be from connect() */
318
+ }
319
+
320
+
321
+ memcached_return memcached_connect(memcached_server_st *ptr)
322
+ {
323
+ memcached_return rc= MEMCACHED_NO_SERVERS;
324
+ LIBMEMCACHED_MEMCACHED_CONNECT_START();
325
+
326
+ /* both retry_timeout and server_failure_limit must be set in order to delay retrying a server on error. */
327
+ WATCHPOINT_ASSERT(ptr->root);
328
+ if (ptr->root->retry_timeout && ptr->root->server_failure_limit)
329
+ {
330
+ struct timeval next_time;
331
+
332
+ gettimeofday(&next_time, NULL);
333
+
334
+ /* if we've had too many consecutive errors on this server, mark it dead. */
335
+ if (ptr->server_failure_counter >= ptr->root->server_failure_limit)
336
+ {
337
+ ptr->next_retry= next_time.tv_sec + ptr->root->retry_timeout;
338
+ ptr->server_failure_counter= 0;
339
+ }
340
+
341
+ if (next_time.tv_sec < ptr->next_retry)
342
+ {
343
+ if (memcached_behavior_get(ptr->root, MEMCACHED_BEHAVIOR_AUTO_EJECT_HOSTS))
344
+ run_distribution(ptr->root);
345
+
346
+ return MEMCACHED_SERVER_MARKED_DEAD;
347
+ }
348
+ }
349
+
350
+ /* We need to clean up the multi startup piece */
351
+ switch (ptr->type)
352
+ {
353
+ case MEMCACHED_CONNECTION_UNKNOWN:
354
+ WATCHPOINT_ASSERT(0);
355
+ rc= MEMCACHED_NOT_SUPPORTED;
356
+ break;
357
+ case MEMCACHED_CONNECTION_UDP:
358
+ case MEMCACHED_CONNECTION_TCP:
359
+ rc= network_connect(ptr);
360
+ break;
361
+ case MEMCACHED_CONNECTION_UNIX_SOCKET:
362
+ rc= unix_socket_connect(ptr);
363
+ break;
364
+ default:
365
+ WATCHPOINT_ASSERT(0);
366
+ }
367
+
368
+ LIBMEMCACHED_MEMCACHED_CONNECT_END();
369
+
370
+ return rc;
371
+ }
@@ -0,0 +1,146 @@
1
+ /*
2
+ * Summary: Constants for libmemcached
3
+ *
4
+ * Copy: See Copyright for the status of this software.
5
+ *
6
+ * Author: Brian Aker
7
+ */
8
+
9
+ #ifndef __MEMCACHED_CONSTANTS_H__
10
+ #define __MEMCACHED_CONSTANTS_H__
11
+
12
+ /* Public defines */
13
+ #define MEMCACHED_DEFAULT_PORT 11211
14
+ #define MEMCACHED_MAX_KEY 251 /* We add one to have it null terminated */
15
+ #define MEMCACHED_MAX_BUFFER 8196
16
+ #define MEMCACHED_MAX_HOST_LENGTH 64
17
+ #define MEMCACHED_MAX_HOST_SORT_LENGTH 86 /* Used for Ketama */
18
+ #define MEMCACHED_POINTS_PER_SERVER 100
19
+ #define MEMCACHED_POINTS_PER_SERVER_KETAMA 160
20
+ #define MEMCACHED_CONTINUUM_SIZE MEMCACHED_POINTS_PER_SERVER*100 /* This would then set max hosts to 100 */
21
+ #define MEMCACHED_STRIDE 4
22
+ #define MEMCACHED_DEFAULT_TIMEOUT 1000
23
+ #define MEMCACHED_CONTINUUM_ADDITION 10 /* How many extra slots we should build for in the continuum */
24
+ #define MEMCACHED_PREFIX_KEY_MAX_SIZE 128
25
+ #define MEMCACHED_EXPIRATION_NOT_ADD 0xffffffffU
26
+
27
+ typedef enum {
28
+ MEMCACHED_SUCCESS,
29
+ MEMCACHED_FAILURE,
30
+ MEMCACHED_HOST_LOOKUP_FAILURE,
31
+ MEMCACHED_CONNECTION_FAILURE,
32
+ MEMCACHED_CONNECTION_BIND_FAILURE,
33
+ MEMCACHED_WRITE_FAILURE,
34
+ MEMCACHED_READ_FAILURE,
35
+ MEMCACHED_UNKNOWN_READ_FAILURE,
36
+ MEMCACHED_PROTOCOL_ERROR,
37
+ MEMCACHED_CLIENT_ERROR,
38
+ MEMCACHED_SERVER_ERROR,
39
+ MEMCACHED_CONNECTION_SOCKET_CREATE_FAILURE,
40
+ MEMCACHED_DATA_EXISTS,
41
+ MEMCACHED_DATA_DOES_NOT_EXIST,
42
+ MEMCACHED_NOTSTORED,
43
+ MEMCACHED_STORED,
44
+ MEMCACHED_NOTFOUND,
45
+ MEMCACHED_MEMORY_ALLOCATION_FAILURE,
46
+ MEMCACHED_PARTIAL_READ,
47
+ MEMCACHED_SOME_ERRORS,
48
+ MEMCACHED_NO_SERVERS,
49
+ MEMCACHED_END,
50
+ MEMCACHED_DELETED,
51
+ MEMCACHED_VALUE,
52
+ MEMCACHED_STAT,
53
+ MEMCACHED_ITEM,
54
+ MEMCACHED_ERRNO,
55
+ MEMCACHED_FAIL_UNIX_SOCKET,
56
+ MEMCACHED_NOT_SUPPORTED,
57
+ MEMCACHED_NO_KEY_PROVIDED, /* Deprecated. Use MEMCACHED_BAD_KEY_PROVIDED! */
58
+ MEMCACHED_FETCH_NOTFINISHED,
59
+ MEMCACHED_TIMEOUT,
60
+ MEMCACHED_BUFFERED,
61
+ MEMCACHED_BAD_KEY_PROVIDED,
62
+ MEMCACHED_INVALID_HOST_PROTOCOL,
63
+ MEMCACHED_SERVER_MARKED_DEAD,
64
+ MEMCACHED_UNKNOWN_STAT_KEY,
65
+ MEMCACHED_AUTH_PROBLEM,
66
+ MEMCACHED_AUTH_FAILURE,
67
+ MEMCACHED_AUTH_CONTINUE,
68
+ MEMCACHED_MAXIMUM_RETURN /* Always add new error code before */
69
+ } memcached_return;
70
+
71
+ typedef enum {
72
+ MEMCACHED_DISTRIBUTION_MODULA,
73
+ MEMCACHED_DISTRIBUTION_CONSISTENT,
74
+ MEMCACHED_DISTRIBUTION_CONSISTENT_KETAMA,
75
+ MEMCACHED_DISTRIBUTION_RANDOM
76
+ } memcached_server_distribution;
77
+
78
+ typedef enum {
79
+ MEMCACHED_BEHAVIOR_NO_BLOCK,
80
+ MEMCACHED_BEHAVIOR_TCP_NODELAY,
81
+ MEMCACHED_BEHAVIOR_HASH,
82
+ MEMCACHED_BEHAVIOR_KETAMA,
83
+ MEMCACHED_BEHAVIOR_SOCKET_SEND_SIZE,
84
+ MEMCACHED_BEHAVIOR_SOCKET_RECV_SIZE,
85
+ MEMCACHED_BEHAVIOR_CACHE_LOOKUPS,
86
+ MEMCACHED_BEHAVIOR_SUPPORT_CAS,
87
+ MEMCACHED_BEHAVIOR_POLL_TIMEOUT,
88
+ MEMCACHED_BEHAVIOR_POLL_MAX_RETRIES,
89
+ MEMCACHED_BEHAVIOR_DISTRIBUTION,
90
+ MEMCACHED_BEHAVIOR_BUFFER_REQUESTS,
91
+ MEMCACHED_BEHAVIOR_USER_DATA,
92
+ MEMCACHED_BEHAVIOR_SORT_HOSTS,
93
+ MEMCACHED_BEHAVIOR_VERIFY_KEY,
94
+ MEMCACHED_BEHAVIOR_CONNECT_TIMEOUT,
95
+ MEMCACHED_BEHAVIOR_RETRY_TIMEOUT,
96
+ MEMCACHED_BEHAVIOR_KETAMA_WEIGHTED,
97
+ MEMCACHED_BEHAVIOR_KETAMA_HASH,
98
+ MEMCACHED_BEHAVIOR_BINARY_PROTOCOL,
99
+ MEMCACHED_BEHAVIOR_SND_TIMEOUT,
100
+ MEMCACHED_BEHAVIOR_RCV_TIMEOUT,
101
+ MEMCACHED_BEHAVIOR_SERVER_FAILURE_LIMIT,
102
+ MEMCACHED_BEHAVIOR_IO_MSG_WATERMARK,
103
+ MEMCACHED_BEHAVIOR_IO_BYTES_WATERMARK,
104
+ MEMCACHED_BEHAVIOR_IO_KEY_PREFETCH,
105
+ MEMCACHED_BEHAVIOR_HASH_WITH_PREFIX_KEY,
106
+ MEMCACHED_BEHAVIOR_NOREPLY,
107
+ MEMCACHED_BEHAVIOR_USE_UDP,
108
+ MEMCACHED_BEHAVIOR_AUTO_EJECT_HOSTS
109
+ } memcached_behavior;
110
+
111
+ typedef enum {
112
+ MEMCACHED_CALLBACK_PREFIX_KEY = 0,
113
+ MEMCACHED_CALLBACK_USER_DATA = 1,
114
+ MEMCACHED_CALLBACK_CLEANUP_FUNCTION = 2,
115
+ MEMCACHED_CALLBACK_CLONE_FUNCTION = 3,
116
+ #ifdef MEMCACHED_ENABLE_DEPRECATED
117
+ MEMCACHED_CALLBACK_MALLOC_FUNCTION = 4,
118
+ MEMCACHED_CALLBACK_REALLOC_FUNCTION = 5,
119
+ MEMCACHED_CALLBACK_FREE_FUNCTION = 6,
120
+ #endif
121
+ MEMCACHED_CALLBACK_GET_FAILURE = 7,
122
+ MEMCACHED_CALLBACK_DELETE_TRIGGER = 8
123
+ } memcached_callback;
124
+
125
+ typedef enum {
126
+ MEMCACHED_HASH_DEFAULT= 0,
127
+ MEMCACHED_HASH_MD5,
128
+ MEMCACHED_HASH_CRC,
129
+ MEMCACHED_HASH_FNV1_64,
130
+ MEMCACHED_HASH_FNV1A_64,
131
+ MEMCACHED_HASH_FNV1_32,
132
+ MEMCACHED_HASH_FNV1A_32,
133
+ MEMCACHED_HASH_HSIEH,
134
+ MEMCACHED_HASH_MURMUR,
135
+ MEMCACHED_HASH_JENKINS,
136
+ MEMCACHED_HASH_NONE
137
+ } memcached_hash;
138
+
139
+ typedef enum {
140
+ MEMCACHED_CONNECTION_UNKNOWN,
141
+ MEMCACHED_CONNECTION_TCP,
142
+ MEMCACHED_CONNECTION_UDP,
143
+ MEMCACHED_CONNECTION_UNIX_SOCKET
144
+ } memcached_connection;
145
+
146
+ #endif /* __MEMCACHED_CONSTANTS_H__ */