roma-client 0.4.3 → 0.4.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (85) hide show
  1. checksums.yaml +4 -4
  2. data/{CHANGELOG → CHANGELOG.md} +8 -5
  3. data/Gemfile.lock +23 -15
  4. data/README.md +62 -0
  5. data/Rakefile +3 -3
  6. data/doc/CHANGELOG_md.html +119 -0
  7. data/doc/README_md.html +161 -0
  8. data/doc/Roma/Client/ClientPool.html +716 -0
  9. data/doc/Roma/Client/ClientRoutingTable.html +495 -0
  10. data/doc/Roma/Client/ConPool.html +484 -0
  11. data/doc/Roma/Client/Plugin/Alist.html +1276 -0
  12. data/doc/Roma/Client/Plugin/Map.html +531 -0
  13. data/doc/Roma/Client/Plugin/MapCount.html +401 -0
  14. data/doc/Roma/Client/Plugin.html +95 -0
  15. data/doc/Roma/Client/Proxy/ClientHandler.html +273 -0
  16. data/doc/Roma/Client/Proxy/Conpool.html +394 -0
  17. data/doc/Roma/Client/Proxy/Daemon.html +305 -0
  18. data/doc/Roma/Client/Proxy/RomaHandler.html +217 -0
  19. data/doc/Roma/Client/Proxy.html +95 -0
  20. data/doc/Roma/Client/RomaClient.html +1339 -0
  21. data/doc/Roma/Client/Sender.html +482 -0
  22. data/doc/Roma/Client/Stats.html +162 -0
  23. data/doc/Roma/Client/VERSION.html +141 -0
  24. data/doc/Roma/Client.html +95 -0
  25. data/doc/Roma/Logging/RLogger/ExtLogDev.html +159 -0
  26. data/doc/Roma/Logging/RLogger/ExtShiftAge.html +95 -0
  27. data/doc/Roma/Logging/RLogger/ExtTrace.html +109 -0
  28. data/doc/Roma/Logging/RLogger/Severity.html +139 -0
  29. data/doc/Roma/Logging/RLogger.html +786 -0
  30. data/doc/Roma/Logging.html +95 -0
  31. data/doc/Roma/Routing/RoutingData/RandomNodeListMaker.html +311 -0
  32. data/doc/Roma/Routing/RoutingData.html +912 -0
  33. data/doc/Roma/Routing.html +95 -0
  34. data/doc/Roma.html +95 -0
  35. data/doc/created.rid +20 -0
  36. data/doc/css/fonts.css +167 -0
  37. data/doc/css/rdoc.css +590 -0
  38. data/doc/fonts/Lato-Light.ttf +0 -0
  39. data/doc/fonts/Lato-LightItalic.ttf +0 -0
  40. data/doc/fonts/Lato-Regular.ttf +0 -0
  41. data/doc/fonts/Lato-RegularItalic.ttf +0 -0
  42. data/doc/fonts/SourceCodePro-Bold.ttf +0 -0
  43. data/doc/fonts/SourceCodePro-Regular.ttf +0 -0
  44. data/doc/images/add.png +0 -0
  45. data/doc/images/arrow_up.png +0 -0
  46. data/doc/images/brick.png +0 -0
  47. data/doc/images/brick_link.png +0 -0
  48. data/doc/images/bug.png +0 -0
  49. data/doc/images/bullet_black.png +0 -0
  50. data/doc/images/bullet_toggle_minus.png +0 -0
  51. data/doc/images/bullet_toggle_plus.png +0 -0
  52. data/doc/images/date.png +0 -0
  53. data/doc/images/delete.png +0 -0
  54. data/doc/images/find.png +0 -0
  55. data/doc/images/loadingAnimation.gif +0 -0
  56. data/doc/images/macFFBgHack.png +0 -0
  57. data/doc/images/package.png +0 -0
  58. data/doc/images/page_green.png +0 -0
  59. data/doc/images/page_white_text.png +0 -0
  60. data/doc/images/page_white_width.png +0 -0
  61. data/doc/images/plugin.png +0 -0
  62. data/doc/images/ruby.png +0 -0
  63. data/doc/images/tag_blue.png +0 -0
  64. data/doc/images/tag_green.png +0 -0
  65. data/doc/images/transparent.png +0 -0
  66. data/doc/images/wrench.png +0 -0
  67. data/doc/images/wrench_orange.png +0 -0
  68. data/doc/images/zoom.png +0 -0
  69. data/doc/index.html +210 -0
  70. data/doc/js/darkfish.js +161 -0
  71. data/doc/js/jquery.js +4 -0
  72. data/doc/js/navigation.js +142 -0
  73. data/doc/js/navigation.js.gz +0 -0
  74. data/doc/js/search.js +109 -0
  75. data/doc/js/search_index.js +1 -0
  76. data/doc/js/search_index.js.gz +0 -0
  77. data/doc/js/searcher.js +228 -0
  78. data/doc/js/searcher.js.gz +0 -0
  79. data/doc/table_of_contents.html +972 -0
  80. data/lib/roma/client/rclient.rb +2 -1
  81. data/lib/roma/client/sender.rb +2 -2
  82. data/lib/roma/client/version.rb +1 -1
  83. data/lib/roma/client.rb +0 -21
  84. metadata +84 -10
  85. data/README +0 -17
@@ -0,0 +1,495 @@
1
+ <!DOCTYPE html>
2
+
3
+ <html>
4
+ <head>
5
+ <meta charset=" UTF-8">
6
+
7
+ <title>class Roma::Client::ClientRoutingTable - ROMA documents</title>
8
+
9
+ <script type="text/javascript">
10
+ var rdoc_rel_prefix = "../../";
11
+ </script>
12
+
13
+ <script src="../../js/jquery.js"></script>
14
+ <script src="../../js/darkfish.js"></script>
15
+
16
+ <link href="../../css/fonts.css" rel="stylesheet">
17
+ <link href="../../css/rdoc.css" rel="stylesheet">
18
+
19
+
20
+
21
+ <body id="top" role="document" class="class">
22
+ <nav role="navigation">
23
+ <div id="project-navigation">
24
+ <div id="home-section" role="region" title="Quick navigation" class="nav-section">
25
+ <h2>
26
+ <a href="../../index.html" rel="home">Home</a>
27
+ </h2>
28
+
29
+ <div id="table-of-contents-navigation">
30
+ <a href="../../table_of_contents.html#pages">Pages</a>
31
+ <a href="../../table_of_contents.html#classes">Classes</a>
32
+ <a href="../../table_of_contents.html#methods">Methods</a>
33
+ </div>
34
+ </div>
35
+
36
+ <div id="search-section" role="search" class="project-section initially-hidden">
37
+ <form action="#" method="get" accept-charset="utf-8">
38
+ <div id="search-field-wrapper">
39
+ <input id="search-field" role="combobox" aria-label="Search"
40
+ aria-autocomplete="list" aria-controls="search-results"
41
+ type="text" name="search" placeholder="Search" spellcheck="false"
42
+ title="Type to search, Up and Down to navigate, Enter to load">
43
+ </div>
44
+
45
+ <ul id="search-results" aria-label="Search Results"
46
+ aria-busy="false" aria-expanded="false"
47
+ aria-atomic="false" class="initially-hidden"></ul>
48
+ </form>
49
+ </div>
50
+
51
+ </div>
52
+
53
+
54
+
55
+ <div id="class-metadata">
56
+
57
+ <div id="parent-class-section" class="nav-section">
58
+ <h3>Parent</h3>
59
+
60
+
61
+ <p class="link">Object
62
+
63
+ </div>
64
+
65
+
66
+
67
+ <!-- Method Quickref -->
68
+ <div id="method-list-section" class="nav-section">
69
+ <h3>Methods</h3>
70
+
71
+ <ul class="link-list" role="directory">
72
+
73
+ <li ><a href="#method-c-new">::new</a>
74
+
75
+ <li ><a href="#method-i-get_vnode_id">#get_vnode_id</a>
76
+
77
+ <li ><a href="#method-i-nodes">#nodes</a>
78
+
79
+ <li ><a href="#method-i-proc_failed">#proc_failed</a>
80
+
81
+ <li ><a href="#method-i-search_node">#search_node</a>
82
+
83
+ <li ><a href="#method-i-search_nodes">#search_nodes</a>
84
+
85
+ <li ><a href="#method-i-vnodes">#vnodes</a>
86
+
87
+ </ul>
88
+ </div>
89
+
90
+ </div>
91
+ </nav>
92
+
93
+ <main role="main" aria-labelledby="class-Roma::Client::ClientRoutingTable">
94
+ <h1 id="class-Roma::Client::ClientRoutingTable" class="class">
95
+ class Roma::Client::ClientRoutingTable
96
+ </h1>
97
+
98
+ <section class="description">
99
+
100
+ </section>
101
+
102
+
103
+
104
+
105
+ <section id="5Buntitled-5D" class="documentation-section">
106
+
107
+
108
+
109
+
110
+
111
+
112
+
113
+ <section class="attribute-method-details" class="method-section">
114
+ <header>
115
+ <h3>Attributes</h3>
116
+ </header>
117
+
118
+
119
+ <div id="attribute-i-div_bits" class="method-detail">
120
+ <div class="method-heading attribute-method-heading">
121
+ <span class="method-name">div_bits</span><span
122
+ class="attribute-access-type">[R]</span>
123
+ </div>
124
+
125
+ <div class="method-description">
126
+
127
+
128
+
129
+ </div>
130
+ </div>
131
+
132
+ <div id="attribute-i-fail_cnt" class="method-detail">
133
+ <div class="method-heading attribute-method-heading">
134
+ <span class="method-name">fail_cnt</span><span
135
+ class="attribute-access-type">[R]</span>
136
+ </div>
137
+
138
+ <div class="method-description">
139
+
140
+
141
+
142
+ </div>
143
+ </div>
144
+
145
+ <div id="attribute-i-hbits" class="method-detail">
146
+ <div class="method-heading attribute-method-heading">
147
+ <span class="method-name">hbits</span><span
148
+ class="attribute-access-type">[R]</span>
149
+ </div>
150
+
151
+ <div class="method-description">
152
+
153
+
154
+
155
+ </div>
156
+ </div>
157
+
158
+ <div id="attribute-i-mklhash" class="method-detail">
159
+ <div class="method-heading attribute-method-heading">
160
+ <span class="method-name">mklhash</span><span
161
+ class="attribute-access-type">[RW]</span>
162
+ </div>
163
+
164
+ <div class="method-description">
165
+
166
+
167
+
168
+ </div>
169
+ </div>
170
+
171
+ <div id="attribute-i-rd" class="method-detail">
172
+ <div class="method-heading attribute-method-heading">
173
+ <span class="method-name">rd</span><span
174
+ class="attribute-access-type">[R]</span>
175
+ </div>
176
+
177
+ <div class="method-description">
178
+
179
+
180
+
181
+ </div>
182
+ </div>
183
+
184
+ <div id="attribute-i-rn" class="method-detail">
185
+ <div class="method-heading attribute-method-heading">
186
+ <span class="method-name">rn</span><span
187
+ class="attribute-access-type">[R]</span>
188
+ </div>
189
+
190
+ <div class="method-description">
191
+
192
+
193
+
194
+ </div>
195
+ </div>
196
+
197
+ <div id="attribute-i-search_mask" class="method-detail">
198
+ <div class="method-heading attribute-method-heading">
199
+ <span class="method-name">search_mask</span><span
200
+ class="attribute-access-type">[R]</span>
201
+ </div>
202
+
203
+ <div class="method-description">
204
+
205
+
206
+
207
+ </div>
208
+ </div>
209
+
210
+ </section>
211
+
212
+
213
+
214
+ <section id="public-class-5Buntitled-5D-method-details" class="method-section">
215
+ <header>
216
+ <h3>Public Class Methods</h3>
217
+ </header>
218
+
219
+
220
+ <div id="method-c-new" class="method-detail ">
221
+
222
+ <div class="method-heading">
223
+ <span class="method-name">new</span><span
224
+ class="method-args">(rd)</span>
225
+
226
+ <span class="method-click-advice">click to toggle source</span>
227
+
228
+ </div>
229
+
230
+
231
+ <div class="method-description">
232
+
233
+
234
+
235
+
236
+
237
+
238
+ <div class="method-source-code" id="new-source">
239
+ <pre><span class="ruby-comment"># File lib/roma/client/client_rttable.rb, line 18</span>
240
+ <span class="ruby-keyword">def</span> <span class="ruby-identifier">initialize</span>(<span class="ruby-identifier">rd</span>)
241
+ <span class="ruby-ivar">@rd</span> = <span class="ruby-identifier">rd</span>
242
+ <span class="ruby-ivar">@rn</span> = <span class="ruby-ivar">@rd</span>.<span class="ruby-identifier">rn</span>
243
+ <span class="ruby-ivar">@div_bits</span>=<span class="ruby-ivar">@rd</span>.<span class="ruby-identifier">div_bits</span>
244
+ <span class="ruby-ivar">@hbits</span> = <span class="ruby-value">2</span><span class="ruby-operator">**</span><span class="ruby-ivar">@rd</span>.<span class="ruby-identifier">dgst_bits</span>
245
+ <span class="ruby-ivar">@search_mask</span> = <span class="ruby-ivar">@rd</span>.<span class="ruby-identifier">search_mask</span>
246
+ <span class="ruby-ivar">@fail_cnt</span> = <span class="ruby-constant">Hash</span>.<span class="ruby-identifier">new</span>(<span class="ruby-value">0</span>)
247
+ <span class="ruby-ivar">@mklhash</span> = <span class="ruby-keyword">nil</span>
248
+ <span class="ruby-keyword">end</span></pre>
249
+ </div>
250
+
251
+ </div>
252
+
253
+
254
+
255
+
256
+ </div>
257
+
258
+
259
+ </section>
260
+
261
+ <section id="public-instance-5Buntitled-5D-method-details" class="method-section">
262
+ <header>
263
+ <h3>Public Instance Methods</h3>
264
+ </header>
265
+
266
+
267
+ <div id="method-i-get_vnode_id" class="method-detail ">
268
+
269
+ <div class="method-heading">
270
+ <span class="method-name">get_vnode_id</span><span
271
+ class="method-args">(d)</span>
272
+
273
+ <span class="method-click-advice">click to toggle source</span>
274
+
275
+ </div>
276
+
277
+
278
+ <div class="method-description">
279
+
280
+ <p>Returns a vnode-id from digest.</p>
281
+
282
+
283
+
284
+
285
+ <div class="method-source-code" id="get_vnode_id-source">
286
+ <pre><span class="ruby-comment"># File lib/roma/client/client_rttable.rb, line 37</span>
287
+ <span class="ruby-keyword">def</span> <span class="ruby-identifier">get_vnode_id</span>(<span class="ruby-identifier">d</span>)
288
+ <span class="ruby-identifier">d</span> <span class="ruby-operator">&amp;</span> <span class="ruby-ivar">@search_mask</span>
289
+ <span class="ruby-keyword">end</span></pre>
290
+ </div>
291
+
292
+ </div>
293
+
294
+
295
+
296
+
297
+ </div>
298
+
299
+
300
+ <div id="method-i-nodes" class="method-detail ">
301
+
302
+ <div class="method-heading">
303
+ <span class="method-name">nodes</span><span
304
+ class="method-args">()</span>
305
+
306
+ <span class="method-click-advice">click to toggle source</span>
307
+
308
+ </div>
309
+
310
+
311
+ <div class="method-description">
312
+
313
+
314
+
315
+
316
+
317
+
318
+ <div class="method-source-code" id="nodes-source">
319
+ <pre><span class="ruby-comment"># File lib/roma/client/client_rttable.rb, line 28</span>
320
+ <span class="ruby-keyword">def</span> <span class="ruby-identifier">nodes</span>
321
+ <span class="ruby-ivar">@rd</span>.<span class="ruby-identifier">nodes</span>.<span class="ruby-identifier">clone</span>
322
+ <span class="ruby-keyword">end</span></pre>
323
+ </div>
324
+
325
+ </div>
326
+
327
+
328
+
329
+
330
+ </div>
331
+
332
+
333
+ <div id="method-i-proc_failed" class="method-detail ">
334
+
335
+ <div class="method-heading">
336
+ <span class="method-name">proc_failed</span><span
337
+ class="method-args">(nid)</span>
338
+
339
+ <span class="method-click-advice">click to toggle source</span>
340
+
341
+ </div>
342
+
343
+
344
+ <div class="method-description">
345
+
346
+
347
+
348
+
349
+
350
+
351
+ <div class="method-source-code" id="proc_failed-source">
352
+ <pre><span class="ruby-comment"># File lib/roma/client/client_rttable.rb, line 69</span>
353
+ <span class="ruby-keyword">def</span> <span class="ruby-identifier">proc_failed</span>(<span class="ruby-identifier">nid</span>)
354
+ <span class="ruby-ivar">@fail_cnt</span>[<span class="ruby-identifier">nid</span>] <span class="ruby-operator">+=</span> <span class="ruby-value">1</span>
355
+ <span class="ruby-ivar">@mklhash</span> = <span class="ruby-value">0</span>
356
+ <span class="ruby-keyword">end</span></pre>
357
+ </div>
358
+
359
+ </div>
360
+
361
+
362
+
363
+
364
+ </div>
365
+
366
+
367
+ <div id="method-i-search_node" class="method-detail ">
368
+
369
+ <div class="method-heading">
370
+ <span class="method-name">search_node</span><span
371
+ class="method-args">(key)</span>
372
+
373
+ <span class="method-click-advice">click to toggle source</span>
374
+
375
+ </div>
376
+
377
+
378
+ <div class="method-description">
379
+
380
+
381
+
382
+
383
+
384
+
385
+ <div class="method-source-code" id="search_node-source">
386
+ <pre><span class="ruby-comment"># File lib/roma/client/client_rttable.rb, line 49</span>
387
+ <span class="ruby-keyword">def</span> <span class="ruby-identifier">search_node</span>(<span class="ruby-identifier">key</span>)
388
+ <span class="ruby-identifier">d</span> = <span class="ruby-constant">Digest</span><span class="ruby-operator">::</span><span class="ruby-constant">SHA1</span>.<span class="ruby-identifier">hexdigest</span>(<span class="ruby-identifier">key</span>).<span class="ruby-identifier">hex</span> <span class="ruby-operator">%</span> <span class="ruby-ivar">@hbits</span>
389
+ <span class="ruby-identifier">nodes</span> = <span class="ruby-ivar">@rd</span>.<span class="ruby-identifier">v_idx</span>[<span class="ruby-identifier">d</span> <span class="ruby-operator">&amp;</span> <span class="ruby-ivar">@search_mask</span>]
390
+ <span class="ruby-identifier">nodes</span>.<span class="ruby-identifier">each_index</span> { <span class="ruby-operator">|</span><span class="ruby-identifier">i</span><span class="ruby-operator">|</span>
391
+ <span class="ruby-keyword">return</span> [<span class="ruby-identifier">nodes</span>[<span class="ruby-identifier">i</span>], <span class="ruby-identifier">d</span>] <span class="ruby-keyword">if</span> <span class="ruby-ivar">@fail_cnt</span>[<span class="ruby-identifier">nodes</span>[<span class="ruby-identifier">i</span>]] <span class="ruby-operator">==</span> <span class="ruby-value">0</span>
392
+ }
393
+ <span class="ruby-comment"># for expecting an auto assign process</span>
394
+ <span class="ruby-identifier">svn</span> = <span class="ruby-identifier">vn</span> = <span class="ruby-identifier">d</span> <span class="ruby-operator">&amp;</span> <span class="ruby-ivar">@search_mask</span>
395
+ <span class="ruby-keyword">while</span>( (<span class="ruby-identifier">vn</span> = <span class="ruby-ivar">@rd</span>.<span class="ruby-identifier">next_vnode</span>(<span class="ruby-identifier">vn</span>)) <span class="ruby-operator">!=</span> <span class="ruby-identifier">svn</span> )
396
+ <span class="ruby-identifier">nodes</span> = <span class="ruby-ivar">@rd</span>.<span class="ruby-identifier">v_idx</span>[<span class="ruby-identifier">vn</span>]
397
+ <span class="ruby-identifier">nodes</span>.<span class="ruby-identifier">each_index</span> { <span class="ruby-operator">|</span><span class="ruby-identifier">i</span><span class="ruby-operator">|</span>
398
+ <span class="ruby-keyword">return</span> [<span class="ruby-identifier">nodes</span>[<span class="ruby-identifier">i</span>], <span class="ruby-identifier">d</span>] <span class="ruby-keyword">if</span> <span class="ruby-ivar">@fail_cnt</span>[<span class="ruby-identifier">nodes</span>[<span class="ruby-identifier">i</span>]] <span class="ruby-operator">==</span> <span class="ruby-value">0</span>
399
+ }
400
+ <span class="ruby-keyword">end</span>
401
+ <span class="ruby-keyword">nil</span>
402
+ <span class="ruby-keyword">rescue</span> =<span class="ruby-operator">&gt;</span> <span class="ruby-identifier">e</span>
403
+ <span class="ruby-identifier">p</span> <span class="ruby-identifier">e</span>
404
+ <span class="ruby-keyword">nil</span>
405
+ <span class="ruby-keyword">end</span></pre>
406
+ </div>
407
+
408
+ </div>
409
+
410
+
411
+
412
+
413
+ </div>
414
+
415
+
416
+ <div id="method-i-search_nodes" class="method-detail ">
417
+
418
+ <div class="method-heading">
419
+ <span class="method-name">search_nodes</span><span
420
+ class="method-args">(vn)</span>
421
+
422
+ <span class="method-click-advice">click to toggle source</span>
423
+
424
+ </div>
425
+
426
+
427
+ <div class="method-description">
428
+
429
+ <p>Returns a node-is list at the vnode. <code>vn</code>: vnode-id</p>
430
+
431
+
432
+
433
+
434
+ <div class="method-source-code" id="search_nodes-source">
435
+ <pre><span class="ruby-comment"># File lib/roma/client/client_rttable.rb, line 43</span>
436
+ <span class="ruby-keyword">def</span> <span class="ruby-identifier">search_nodes</span>(<span class="ruby-identifier">vn</span>)
437
+ <span class="ruby-ivar">@rd</span>.<span class="ruby-identifier">v_idx</span>[<span class="ruby-identifier">vn</span>].<span class="ruby-identifier">clone</span>
438
+ <span class="ruby-keyword">rescue</span>
439
+ <span class="ruby-keyword">nil</span>
440
+ <span class="ruby-keyword">end</span></pre>
441
+ </div>
442
+
443
+ </div>
444
+
445
+
446
+
447
+
448
+ </div>
449
+
450
+
451
+ <div id="method-i-vnodes" class="method-detail ">
452
+
453
+ <div class="method-heading">
454
+ <span class="method-name">vnodes</span><span
455
+ class="method-args">()</span>
456
+
457
+ <span class="method-click-advice">click to toggle source</span>
458
+
459
+ </div>
460
+
461
+
462
+ <div class="method-description">
463
+
464
+
465
+
466
+
467
+
468
+
469
+ <div class="method-source-code" id="vnodes-source">
470
+ <pre><span class="ruby-comment"># File lib/roma/client/client_rttable.rb, line 32</span>
471
+ <span class="ruby-keyword">def</span> <span class="ruby-identifier">vnodes</span>
472
+ <span class="ruby-ivar">@rd</span>.<span class="ruby-identifier">v_idx</span>.<span class="ruby-identifier">keys</span>
473
+ <span class="ruby-keyword">end</span></pre>
474
+ </div>
475
+
476
+ </div>
477
+
478
+
479
+
480
+
481
+ </div>
482
+
483
+
484
+ </section>
485
+
486
+ </section>
487
+ </main>
488
+
489
+
490
+ <footer id="validator-badges" role="contentinfo">
491
+ <p><a href="http://validator.w3.org/check/referer">Validate</a>
492
+ <p>Generated by <a href="http://docs.seattlerb.org/rdoc/">RDoc</a> 4.2.2.
493
+ <p>Based on <a href="http://deveiate.org/projects/Darkfish-RDoc/">Darkfish</a> by <a href="http://deveiate.org">Michael Granger</a>.
494
+ </footer>
495
+