sessionm-cassandra 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/CHANGELOG +135 -0
- data/Gemfile +8 -0
- data/LICENSE +202 -0
- data/Manifest +94 -0
- data/README.md +373 -0
- data/Rakefile +195 -0
- data/bin/cassandra_helper +16 -0
- data/conf/0.6/cassandra.in.sh +47 -0
- data/conf/0.6/log4j.properties +38 -0
- data/conf/0.6/schema.json +57 -0
- data/conf/0.6/storage-conf.xml +352 -0
- data/conf/0.7/cassandra.in.sh +46 -0
- data/conf/0.7/cassandra.yaml +336 -0
- data/conf/0.7/log4j-server.properties +41 -0
- data/conf/0.7/schema.json +57 -0
- data/conf/0.7/schema.txt +45 -0
- data/conf/0.8/cassandra.in.sh +41 -0
- data/conf/0.8/cassandra.yaml +61 -0
- data/conf/0.8/log4j-server.properties +40 -0
- data/conf/0.8/schema.json +72 -0
- data/conf/0.8/schema.txt +57 -0
- data/conf/1.0/cassandra.in.sh +41 -0
- data/conf/1.0/cassandra.yaml +415 -0
- data/conf/1.0/log4j-server.properties +40 -0
- data/conf/1.0/schema.json +72 -0
- data/conf/1.0/schema.txt +57 -0
- data/conf/1.1/cassandra.in.sh +41 -0
- data/conf/1.1/cassandra.yaml +567 -0
- data/conf/1.1/log4j-server.properties +44 -0
- data/conf/1.1/schema.json +72 -0
- data/conf/1.1/schema.txt +57 -0
- data/ext/cassandra_native.c +34 -0
- data/ext/extconf.rb +9 -0
- data/lib/cassandra/0.6/cassandra.rb +113 -0
- data/lib/cassandra/0.6/columns.rb +78 -0
- data/lib/cassandra/0.6/protocol.rb +91 -0
- data/lib/cassandra/0.6.rb +7 -0
- data/lib/cassandra/0.7/cassandra.rb +2 -0
- data/lib/cassandra/0.7/columns.rb +4 -0
- data/lib/cassandra/0.7/protocol.rb +5 -0
- data/lib/cassandra/0.7.rb +7 -0
- data/lib/cassandra/0.8/cassandra.rb +51 -0
- data/lib/cassandra/0.8/columns.rb +28 -0
- data/lib/cassandra/0.8/protocol.rb +10 -0
- data/lib/cassandra/0.8.rb +7 -0
- data/lib/cassandra/1.0/cassandra.rb +1 -0
- data/lib/cassandra/1.0/columns.rb +1 -0
- data/lib/cassandra/1.0/protocol.rb +1 -0
- data/lib/cassandra/1.0.rb +7 -0
- data/lib/cassandra/1.1/cassandra.rb +1 -0
- data/lib/cassandra/1.1/columns.rb +1 -0
- data/lib/cassandra/1.1/protocol.rb +1 -0
- data/lib/cassandra/1.1.rb +7 -0
- data/lib/cassandra/array.rb +8 -0
- data/lib/cassandra/batch.rb +41 -0
- data/lib/cassandra/cassandra.rb +1088 -0
- data/lib/cassandra/column_family.rb +3 -0
- data/lib/cassandra/columns.rb +172 -0
- data/lib/cassandra/comparable.rb +28 -0
- data/lib/cassandra/composite.rb +140 -0
- data/lib/cassandra/constants.rb +11 -0
- data/lib/cassandra/debug.rb +9 -0
- data/lib/cassandra/dynamic_composite.rb +96 -0
- data/lib/cassandra/helpers.rb +41 -0
- data/lib/cassandra/keyspace.rb +3 -0
- data/lib/cassandra/long.rb +58 -0
- data/lib/cassandra/mock.rb +525 -0
- data/lib/cassandra/ordered_hash.rb +192 -0
- data/lib/cassandra/protocol.rb +137 -0
- data/lib/cassandra/time.rb +11 -0
- data/lib/cassandra.rb +41 -0
- data/sessionm-cassandra.gemspec +47 -0
- data/test/cassandra_client_test.rb +20 -0
- data/test/cassandra_mock_test.rb +128 -0
- data/test/cassandra_test.rb +1353 -0
- data/test/comparable_types_test.rb +45 -0
- data/test/composite_type_test.rb +64 -0
- data/test/eventmachine_test.rb +42 -0
- data/test/ordered_hash_test.rb +386 -0
- data/test/test_helper.rb +19 -0
- data/vendor/0.6/gen-rb/cassandra.rb +1481 -0
- data/vendor/0.6/gen-rb/cassandra_constants.rb +12 -0
- data/vendor/0.6/gen-rb/cassandra_types.rb +482 -0
- data/vendor/0.7/gen-rb/cassandra.rb +1936 -0
- data/vendor/0.7/gen-rb/cassandra_constants.rb +12 -0
- data/vendor/0.7/gen-rb/cassandra_types.rb +681 -0
- data/vendor/0.8/gen-rb/cassandra.rb +2215 -0
- data/vendor/0.8/gen-rb/cassandra_constants.rb +12 -0
- data/vendor/0.8/gen-rb/cassandra_types.rb +824 -0
- data/vendor/1.0/gen-rb/cassandra.rb +2215 -0
- data/vendor/1.0/gen-rb/cassandra_constants.rb +12 -0
- data/vendor/1.0/gen-rb/cassandra_types.rb +857 -0
- data/vendor/1.1/gen-rb/cassandra.rb +2571 -0
- data/vendor/1.1/gen-rb/cassandra_constants.rb +12 -0
- data/vendor/1.1/gen-rb/cassandra_types.rb +928 -0
- metadata +287 -0
data/CHANGELOG
ADDED
@@ -0,0 +1,135 @@
|
|
1
|
+
v0.17.0
|
2
|
+
- multi_get_columns with only one query (courtesy @christian-blades-cb)
|
3
|
+
- documentation fixes for get and multi_get (issue #136, courtesy @christian-blades-cb)
|
4
|
+
|
5
|
+
v0.16.0
|
6
|
+
- New :queue_size option for batch mode (courtesy @vicentllongo)
|
7
|
+
- Cassandra 1.1 support (courtesy @hawknewton)
|
8
|
+
|
9
|
+
v0.15.0
|
10
|
+
- Fixes for ruby 1.8 (issue #158, courtesy @jarib)
|
11
|
+
- get_indexed_slices returns an OrderedHash (issue #110)
|
12
|
+
|
13
|
+
v0.14.0
|
14
|
+
- Numerous performance improvements (courtesy @nearbuy)
|
15
|
+
- Fixed many 0.6 bugs
|
16
|
+
- Added batch counter update support to Cassandra::Mock
|
17
|
+
- Add support DynamicComposite columns (issue #154, courtesy @nearbuy)
|
18
|
+
- API cleanup in get_indexed_slices (issue #155, courtesy @mcmire)
|
19
|
+
|
20
|
+
v0.13.0
|
21
|
+
- Support for new thrift gem versions
|
22
|
+
- Updated all links to point to new github repo
|
23
|
+
- Batch support for counter updates (courtesy @nearbuy)
|
24
|
+
- Counter super column support in get and get_range (courtesy @behrangj)
|
25
|
+
- Composite columns (courtesy @nearbuy)
|
26
|
+
- Gemspec cleanup
|
27
|
+
|
28
|
+
v0.12.2
|
29
|
+
- Respect the start_key in get_range. Resolves Issue #127.
|
30
|
+
- Fix issue with differences in gemspec and what is required. Resolves Issue #125.
|
31
|
+
- Update to Cassandra 0.8.7 and 1.0.2.
|
32
|
+
|
33
|
+
v0.12.1
|
34
|
+
- Fix issue with simple_uuid dependency.
|
35
|
+
- Fix issue with get_range & get_range_batch keeping all results when a block is given. Resolves Issue# 112.
|
36
|
+
|
37
|
+
v0.12.0 Changed thrift_client dependency to 0.7.0
|
38
|
+
|
39
|
+
v0.11.4
|
40
|
+
- Fix get_range to invoke blocks
|
41
|
+
- Fix current distribution urls in Rakfile. Resolves Issue# 97.
|
42
|
+
|
43
|
+
v0.11.3
|
44
|
+
- Fix login after reconnect
|
45
|
+
|
46
|
+
v0.11.2
|
47
|
+
- Update thrift_client gem to deal with failover bug.
|
48
|
+
|
49
|
+
v0.11.1
|
50
|
+
- Add counter support for Cassandra 0.8. (Thanks Swrve team!)
|
51
|
+
- Add additional rake tasks to start and stop cassandra in the background.
|
52
|
+
- Fix issue with non-utf8 column names not being encoded/decoded properly.
|
53
|
+
- Add way to specify a default read/write consistency.
|
54
|
+
- Consolidate 0.7 and 0.8 functions, and move 0.6 specific functions into lib/cassandra/0.6/
|
55
|
+
- Use 0.8-rc1 as 0.8 install target.
|
56
|
+
- Updated get_index_slices API to allow passing an array of hashes instead of IndexClause instance. (Maintains backward compatibility.)
|
57
|
+
- Fix permissions issue.
|
58
|
+
|
59
|
+
v0.11.0
|
60
|
+
- Remove direct thrift dependency. Allow thrift_client to require it.
|
61
|
+
- Add functions for each and each_key to iterate through key ranges.
|
62
|
+
- Add function for get_range_keys which returns an array of keys in a given range.
|
63
|
+
- Changed the return value of get_range to an OrderedHash.
|
64
|
+
- Change get_range to accept both a range of keys and a range of columns.
|
65
|
+
- Add batched range support to get_range and add get_range_batch.
|
66
|
+
|
67
|
+
v0.10.0 Major Update (rjackson)
|
68
|
+
- Update Rakefile to install 0.6.13, 0.7.4, 0.8.0-beta1 to ~/cassandra/cassandra-VERSION
|
69
|
+
- Add data:load task to Rakefile for creating the schema required for the tests
|
70
|
+
- Default the Rakefile to use 0.8-beta1
|
71
|
+
- Setup test suite to work on 0.6.13, 0.7.4, and 0.8.0-beta1
|
72
|
+
- All tests pass for all supported (0.6.13, 0.7.4, 0.8.0-beta1) versions.
|
73
|
+
- Added Support for 0.8-beta1
|
74
|
+
- Changed get_index_slices to return a hash of rows
|
75
|
+
- Updated Cassandra::Mock to pass all tests for each Cassandra version
|
76
|
+
|
77
|
+
v0.9.2 fix bug with deletions in batch mutations
|
78
|
+
|
79
|
+
v0.9.1 Support for secondary indexing. (jhermes)
|
80
|
+
Fix bug in mock where we didn't support range queries. (therealadam)
|
81
|
+
Support deletes in batch mutations. [blanquer]
|
82
|
+
|
83
|
+
v0.9.0 cassandra 0.7 compat
|
84
|
+
|
85
|
+
v0.8.2 Renamed :thrift_client_class option, UUID fix, 0.6 update, fixing cassanda install, much Mock fixes
|
86
|
+
|
87
|
+
v0.8.1 Adding the ability to compose ThriftClient classes.
|
88
|
+
|
89
|
+
v0.8.0 Compatibility with Cassandra 0.6 betas (no longer compatible with 0.5); assorted bugfixes.
|
90
|
+
|
91
|
+
v0.7.6 Bugfixes.
|
92
|
+
|
93
|
+
v0.7.5 Another packaging error.
|
94
|
+
|
95
|
+
v0.7.4 Fix thrift_client dependency
|
96
|
+
|
97
|
+
v0.7.3 New Cassandra::Mock - a pure ruby mock of cassanra; bugfixes.
|
98
|
+
|
99
|
+
v0.7.2 Switch to newly-extraced simple_uuid gem, minor bugfixes.
|
100
|
+
|
101
|
+
v0.7.1 update thrift-generated code to 0.5
|
102
|
+
|
103
|
+
v0.7 Various improvements.
|
104
|
+
- Compatibility with Cassandra 0.5.
|
105
|
+
- performance improvements
|
106
|
+
|
107
|
+
v0.6. Use thrift_client gem.
|
108
|
+
|
109
|
+
v0.5.6.2. Release process was busted.
|
110
|
+
|
111
|
+
v0.5.6. Real multiget.
|
112
|
+
|
113
|
+
v0.5.5. to_guid for Long. Don't continually re-checkout the Git mirror. Use curl instead of wget, sigh. Use new unified insert API.
|
114
|
+
|
115
|
+
v0.5.4. Use wget instead of curl.
|
116
|
+
|
117
|
+
v0.5.3. Update Multiblog sample schema.
|
118
|
+
|
119
|
+
v0.5.2. Update server version so CommitLog replay is fixed.
|
120
|
+
|
121
|
+
v0.5.1. Add bin/cassandra_helper script, to build and start the server for you. Improve build error reporting.
|
122
|
+
|
123
|
+
v0.5. More API changes. Working temporal comparators.
|
124
|
+
|
125
|
+
v0.4. Use new comparator API. Namespace Thrift bindings; rename gem and class to Cassandra. Make tokens and limits actually work. Retry UnavailableExceptions.
|
126
|
+
|
127
|
+
v0.3. Use new Thrift API.
|
128
|
+
|
129
|
+
v0.2.2. Use nil for empty byte array, not empty string. Improves API.
|
130
|
+
|
131
|
+
v0.2.1. Don't write serialization overhead on nulls.
|
132
|
+
|
133
|
+
v0.2. Re-factor table vs. column family interface per discussion with jbellis.
|
134
|
+
|
135
|
+
v0.1. First release.
|
data/Gemfile
ADDED
data/LICENSE
ADDED
@@ -0,0 +1,202 @@
|
|
1
|
+
|
2
|
+
Apache License
|
3
|
+
Version 2.0, January 2004
|
4
|
+
http://www.apache.org/licenses/
|
5
|
+
|
6
|
+
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
7
|
+
|
8
|
+
1. Definitions.
|
9
|
+
|
10
|
+
"License" shall mean the terms and conditions for use, reproduction,
|
11
|
+
and distribution as defined by Sections 1 through 9 of this document.
|
12
|
+
|
13
|
+
"Licensor" shall mean the copyright owner or entity authorized by
|
14
|
+
the copyright owner that is granting the License.
|
15
|
+
|
16
|
+
"Legal Entity" shall mean the union of the acting entity and all
|
17
|
+
other entities that control, are controlled by, or are under common
|
18
|
+
control with that entity. For the purposes of this definition,
|
19
|
+
"control" means (i) the power, direct or indirect, to cause the
|
20
|
+
direction or management of such entity, whether by contract or
|
21
|
+
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
22
|
+
outstanding shares, or (iii) beneficial ownership of such entity.
|
23
|
+
|
24
|
+
"You" (or "Your") shall mean an individual or Legal Entity
|
25
|
+
exercising permissions granted by this License.
|
26
|
+
|
27
|
+
"Source" form shall mean the preferred form for making modifications,
|
28
|
+
including but not limited to software source code, documentation
|
29
|
+
source, and configuration files.
|
30
|
+
|
31
|
+
"Object" form shall mean any form resulting from mechanical
|
32
|
+
transformation or translation of a Source form, including but
|
33
|
+
not limited to compiled object code, generated documentation,
|
34
|
+
and conversions to other media types.
|
35
|
+
|
36
|
+
"Work" shall mean the work of authorship, whether in Source or
|
37
|
+
Object form, made available under the License, as indicated by a
|
38
|
+
copyright notice that is included in or attached to the work
|
39
|
+
(an example is provided in the Appendix below).
|
40
|
+
|
41
|
+
"Derivative Works" shall mean any work, whether in Source or Object
|
42
|
+
form, that is based on (or derived from) the Work and for which the
|
43
|
+
editorial revisions, annotations, elaborations, or other modifications
|
44
|
+
represent, as a whole, an original work of authorship. For the purposes
|
45
|
+
of this License, Derivative Works shall not include works that remain
|
46
|
+
separable from, or merely link (or bind by name) to the interfaces of,
|
47
|
+
the Work and Derivative Works thereof.
|
48
|
+
|
49
|
+
"Contribution" shall mean any work of authorship, including
|
50
|
+
the original version of the Work and any modifications or additions
|
51
|
+
to that Work or Derivative Works thereof, that is intentionally
|
52
|
+
submitted to Licensor for inclusion in the Work by the copyright owner
|
53
|
+
or by an individual or Legal Entity authorized to submit on behalf of
|
54
|
+
the copyright owner. For the purposes of this definition, "submitted"
|
55
|
+
means any form of electronic, verbal, or written communication sent
|
56
|
+
to the Licensor or its representatives, including but not limited to
|
57
|
+
communication on electronic mailing lists, source code control systems,
|
58
|
+
and issue tracking systems that are managed by, or on behalf of, the
|
59
|
+
Licensor for the purpose of discussing and improving the Work, but
|
60
|
+
excluding communication that is conspicuously marked or otherwise
|
61
|
+
designated in writing by the copyright owner as "Not a Contribution."
|
62
|
+
|
63
|
+
"Contributor" shall mean Licensor and any individual or Legal Entity
|
64
|
+
on behalf of whom a Contribution has been received by Licensor and
|
65
|
+
subsequently incorporated within the Work.
|
66
|
+
|
67
|
+
2. Grant of Copyright License. Subject to the terms and conditions of
|
68
|
+
this License, each Contributor hereby grants to You a perpetual,
|
69
|
+
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
70
|
+
copyright license to reproduce, prepare Derivative Works of,
|
71
|
+
publicly display, publicly perform, sublicense, and distribute the
|
72
|
+
Work and such Derivative Works in Source or Object form.
|
73
|
+
|
74
|
+
3. Grant of Patent License. Subject to the terms and conditions of
|
75
|
+
this License, each Contributor hereby grants to You a perpetual,
|
76
|
+
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
77
|
+
(except as stated in this section) patent license to make, have made,
|
78
|
+
use, offer to sell, sell, import, and otherwise transfer the Work,
|
79
|
+
where such license applies only to those patent claims licensable
|
80
|
+
by such Contributor that are necessarily infringed by their
|
81
|
+
Contribution(s) alone or by combination of their Contribution(s)
|
82
|
+
with the Work to which such Contribution(s) was submitted. If You
|
83
|
+
institute patent litigation against any entity (including a
|
84
|
+
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
85
|
+
or a Contribution incorporated within the Work constitutes direct
|
86
|
+
or contributory patent infringement, then any patent licenses
|
87
|
+
granted to You under this License for that Work shall terminate
|
88
|
+
as of the date such litigation is filed.
|
89
|
+
|
90
|
+
4. Redistribution. You may reproduce and distribute copies of the
|
91
|
+
Work or Derivative Works thereof in any medium, with or without
|
92
|
+
modifications, and in Source or Object form, provided that You
|
93
|
+
meet the following conditions:
|
94
|
+
|
95
|
+
(a) You must give any other recipients of the Work or
|
96
|
+
Derivative Works a copy of this License; and
|
97
|
+
|
98
|
+
(b) You must cause any modified files to carry prominent notices
|
99
|
+
stating that You changed the files; and
|
100
|
+
|
101
|
+
(c) You must retain, in the Source form of any Derivative Works
|
102
|
+
that You distribute, all copyright, patent, trademark, and
|
103
|
+
attribution notices from the Source form of the Work,
|
104
|
+
excluding those notices that do not pertain to any part of
|
105
|
+
the Derivative Works; and
|
106
|
+
|
107
|
+
(d) If the Work includes a "NOTICE" text file as part of its
|
108
|
+
distribution, then any Derivative Works that You distribute must
|
109
|
+
include a readable copy of the attribution notices contained
|
110
|
+
within such NOTICE file, excluding those notices that do not
|
111
|
+
pertain to any part of the Derivative Works, in at least one
|
112
|
+
of the following places: within a NOTICE text file distributed
|
113
|
+
as part of the Derivative Works; within the Source form or
|
114
|
+
documentation, if provided along with the Derivative Works; or,
|
115
|
+
within a display generated by the Derivative Works, if and
|
116
|
+
wherever such third-party notices normally appear. The contents
|
117
|
+
of the NOTICE file are for informational purposes only and
|
118
|
+
do not modify the License. You may add Your own attribution
|
119
|
+
notices within Derivative Works that You distribute, alongside
|
120
|
+
or as an addendum to the NOTICE text from the Work, provided
|
121
|
+
that such additional attribution notices cannot be construed
|
122
|
+
as modifying the License.
|
123
|
+
|
124
|
+
You may add Your own copyright statement to Your modifications and
|
125
|
+
may provide additional or different license terms and conditions
|
126
|
+
for use, reproduction, or distribution of Your modifications, or
|
127
|
+
for any such Derivative Works as a whole, provided Your use,
|
128
|
+
reproduction, and distribution of the Work otherwise complies with
|
129
|
+
the conditions stated in this License.
|
130
|
+
|
131
|
+
5. Submission of Contributions. Unless You explicitly state otherwise,
|
132
|
+
any Contribution intentionally submitted for inclusion in the Work
|
133
|
+
by You to the Licensor shall be under the terms and conditions of
|
134
|
+
this License, without any additional terms or conditions.
|
135
|
+
Notwithstanding the above, nothing herein shall supersede or modify
|
136
|
+
the terms of any separate license agreement you may have executed
|
137
|
+
with Licensor regarding such Contributions.
|
138
|
+
|
139
|
+
6. Trademarks. This License does not grant permission to use the trade
|
140
|
+
names, trademarks, service marks, or product names of the Licensor,
|
141
|
+
except as required for reasonable and customary use in describing the
|
142
|
+
origin of the Work and reproducing the content of the NOTICE file.
|
143
|
+
|
144
|
+
7. Disclaimer of Warranty. Unless required by applicable law or
|
145
|
+
agreed to in writing, Licensor provides the Work (and each
|
146
|
+
Contributor provides its Contributions) on an "AS IS" BASIS,
|
147
|
+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
148
|
+
implied, including, without limitation, any warranties or conditions
|
149
|
+
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
150
|
+
PARTICULAR PURPOSE. You are solely responsible for determining the
|
151
|
+
appropriateness of using or redistributing the Work and assume any
|
152
|
+
risks associated with Your exercise of permissions under this License.
|
153
|
+
|
154
|
+
8. Limitation of Liability. In no event and under no legal theory,
|
155
|
+
whether in tort (including negligence), contract, or otherwise,
|
156
|
+
unless required by applicable law (such as deliberate and grossly
|
157
|
+
negligent acts) or agreed to in writing, shall any Contributor be
|
158
|
+
liable to You for damages, including any direct, indirect, special,
|
159
|
+
incidental, or consequential damages of any character arising as a
|
160
|
+
result of this License or out of the use or inability to use the
|
161
|
+
Work (including but not limited to damages for loss of goodwill,
|
162
|
+
work stoppage, computer failure or malfunction, or any and all
|
163
|
+
other commercial damages or losses), even if such Contributor
|
164
|
+
has been advised of the possibility of such damages.
|
165
|
+
|
166
|
+
9. Accepting Warranty or Additional Liability. While redistributing
|
167
|
+
the Work or Derivative Works thereof, You may choose to offer,
|
168
|
+
and charge a fee for, acceptance of support, warranty, indemnity,
|
169
|
+
or other liability obligations and/or rights consistent with this
|
170
|
+
License. However, in accepting such obligations, You may act only
|
171
|
+
on Your own behalf and on Your sole responsibility, not on behalf
|
172
|
+
of any other Contributor, and only if You agree to indemnify,
|
173
|
+
defend, and hold each Contributor harmless for any liability
|
174
|
+
incurred by, or claims asserted against, such Contributor by reason
|
175
|
+
of your accepting any such warranty or additional liability.
|
176
|
+
|
177
|
+
END OF TERMS AND CONDITIONS
|
178
|
+
|
179
|
+
APPENDIX: How to apply the Apache License to your work.
|
180
|
+
|
181
|
+
To apply the Apache License to your work, attach the following
|
182
|
+
boilerplate notice, with the fields enclosed by brackets "[]"
|
183
|
+
replaced with your own identifying information. (Don't include
|
184
|
+
the brackets!) The text should be enclosed in the appropriate
|
185
|
+
comment syntax for the file format. We also recommend that a
|
186
|
+
file or class name and description of purpose be included on the
|
187
|
+
same "printed page" as the copyright notice for easier
|
188
|
+
identification within third-party archives.
|
189
|
+
|
190
|
+
Copyright [yyyy] [name of copyright owner]
|
191
|
+
|
192
|
+
Licensed under the Apache License, Version 2.0 (the "License");
|
193
|
+
you may not use this file except in compliance with the License.
|
194
|
+
You may obtain a copy of the License at
|
195
|
+
|
196
|
+
http://www.apache.org/licenses/LICENSE-2.0
|
197
|
+
|
198
|
+
Unless required by applicable law or agreed to in writing, software
|
199
|
+
distributed under the License is distributed on an "AS IS" BASIS,
|
200
|
+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
201
|
+
See the License for the specific language governing permissions and
|
202
|
+
limitations under the License.
|
data/Manifest
ADDED
@@ -0,0 +1,94 @@
|
|
1
|
+
CHANGELOG
|
2
|
+
Gemfile
|
3
|
+
LICENSE
|
4
|
+
Manifest
|
5
|
+
README.md
|
6
|
+
Rakefile
|
7
|
+
bin/cassandra_helper
|
8
|
+
conf/0.6/cassandra.in.sh
|
9
|
+
conf/0.6/log4j.properties
|
10
|
+
conf/0.6/schema.json
|
11
|
+
conf/0.6/storage-conf.xml
|
12
|
+
conf/0.7/cassandra.in.sh
|
13
|
+
conf/0.7/cassandra.yaml
|
14
|
+
conf/0.7/log4j-server.properties
|
15
|
+
conf/0.7/schema.json
|
16
|
+
conf/0.7/schema.txt
|
17
|
+
conf/0.8/cassandra.in.sh
|
18
|
+
conf/0.8/cassandra.yaml
|
19
|
+
conf/0.8/log4j-server.properties
|
20
|
+
conf/0.8/schema.json
|
21
|
+
conf/0.8/schema.txt
|
22
|
+
conf/1.0/cassandra.in.sh
|
23
|
+
conf/1.0/cassandra.yaml
|
24
|
+
conf/1.0/log4j-server.properties
|
25
|
+
conf/1.0/schema.json
|
26
|
+
conf/1.0/schema.txt
|
27
|
+
conf/1.1/cassandra.in.sh
|
28
|
+
conf/1.1/cassandra.yaml
|
29
|
+
conf/1.1/log4j-server.properties
|
30
|
+
conf/1.1/schema.json
|
31
|
+
conf/1.1/schema.txt
|
32
|
+
ext/cassandra_native.c
|
33
|
+
ext/extconf.rb
|
34
|
+
lib/cassandra.rb
|
35
|
+
lib/cassandra/0.6.rb
|
36
|
+
lib/cassandra/0.6/cassandra.rb
|
37
|
+
lib/cassandra/0.6/columns.rb
|
38
|
+
lib/cassandra/0.6/protocol.rb
|
39
|
+
lib/cassandra/0.7.rb
|
40
|
+
lib/cassandra/0.7/cassandra.rb
|
41
|
+
lib/cassandra/0.7/columns.rb
|
42
|
+
lib/cassandra/0.7/protocol.rb
|
43
|
+
lib/cassandra/0.8.rb
|
44
|
+
lib/cassandra/0.8/cassandra.rb
|
45
|
+
lib/cassandra/0.8/columns.rb
|
46
|
+
lib/cassandra/0.8/protocol.rb
|
47
|
+
lib/cassandra/1.0.rb
|
48
|
+
lib/cassandra/1.0/cassandra.rb
|
49
|
+
lib/cassandra/1.0/columns.rb
|
50
|
+
lib/cassandra/1.0/protocol.rb
|
51
|
+
lib/cassandra/1.1.rb
|
52
|
+
lib/cassandra/1.1/cassandra.rb
|
53
|
+
lib/cassandra/1.1/columns.rb
|
54
|
+
lib/cassandra/1.1/protocol.rb
|
55
|
+
lib/cassandra/array.rb
|
56
|
+
lib/cassandra/batch.rb
|
57
|
+
lib/cassandra/cassandra.rb
|
58
|
+
lib/cassandra/column_family.rb
|
59
|
+
lib/cassandra/columns.rb
|
60
|
+
lib/cassandra/comparable.rb
|
61
|
+
lib/cassandra/composite.rb
|
62
|
+
lib/cassandra/constants.rb
|
63
|
+
lib/cassandra/debug.rb
|
64
|
+
lib/cassandra/dynamic_composite.rb
|
65
|
+
lib/cassandra/helpers.rb
|
66
|
+
lib/cassandra/keyspace.rb
|
67
|
+
lib/cassandra/long.rb
|
68
|
+
lib/cassandra/mock.rb
|
69
|
+
lib/cassandra/ordered_hash.rb
|
70
|
+
lib/cassandra/protocol.rb
|
71
|
+
lib/cassandra/time.rb
|
72
|
+
test/cassandra_client_test.rb
|
73
|
+
test/cassandra_mock_test.rb
|
74
|
+
test/cassandra_test.rb
|
75
|
+
test/comparable_types_test.rb
|
76
|
+
test/composite_type_test.rb
|
77
|
+
test/eventmachine_test.rb
|
78
|
+
test/ordered_hash_test.rb
|
79
|
+
test/test_helper.rb
|
80
|
+
vendor/0.6/gen-rb/cassandra.rb
|
81
|
+
vendor/0.6/gen-rb/cassandra_constants.rb
|
82
|
+
vendor/0.6/gen-rb/cassandra_types.rb
|
83
|
+
vendor/0.7/gen-rb/cassandra.rb
|
84
|
+
vendor/0.7/gen-rb/cassandra_constants.rb
|
85
|
+
vendor/0.7/gen-rb/cassandra_types.rb
|
86
|
+
vendor/0.8/gen-rb/cassandra.rb
|
87
|
+
vendor/0.8/gen-rb/cassandra_constants.rb
|
88
|
+
vendor/0.8/gen-rb/cassandra_types.rb
|
89
|
+
vendor/1.0/gen-rb/cassandra.rb
|
90
|
+
vendor/1.0/gen-rb/cassandra_constants.rb
|
91
|
+
vendor/1.0/gen-rb/cassandra_types.rb
|
92
|
+
vendor/1.1/gen-rb/cassandra.rb
|
93
|
+
vendor/1.1/gen-rb/cassandra_constants.rb
|
94
|
+
vendor/1.1/gen-rb/cassandra_types.rb
|
data/README.md
ADDED
@@ -0,0 +1,373 @@
|
|
1
|
+
# cassandra
|
2
|
+
A Ruby client for the Cassandra distributed database.
|
3
|
+
|
4
|
+
Supports 1.8.7, 1.9.2, and rubinius on Cassandra 0.6.13, 0.7.9, 0.8.6, 1.0.0-rc2, 1.1.5.
|
5
|
+
|
6
|
+
## Getting Started
|
7
|
+
|
8
|
+
Here is a quick sample of the general use (more details in Read/Write
|
9
|
+
API below):
|
10
|
+
|
11
|
+
require 'cassandra'
|
12
|
+
client = Cassandra.new('Twitter', '127.0.0.1:9160')
|
13
|
+
client.insert(:Users, "5", {'screen_name' => "buttonscat"})
|
14
|
+
|
15
|
+
## License
|
16
|
+
|
17
|
+
Copyright 2009-2011 Twitter, Inc. See included LICENSE file. Portions copyright 2004-2009 David Heinemeier Hansson, and used with permission.
|
18
|
+
|
19
|
+
## Cassandra Version
|
20
|
+
|
21
|
+
The Cassandra project is under very active development, and as such
|
22
|
+
there are a few different versions that you may need to use this gem
|
23
|
+
with. We have set up an easy sure fire mechanism for selecting the
|
24
|
+
specific version that you are connecting to while requiring the gem.
|
25
|
+
|
26
|
+
#### Require Method
|
27
|
+
The default version is the currently stable release of cassandra. (0.8
|
28
|
+
at this time.)
|
29
|
+
|
30
|
+
To use the default version simply use a normal require:
|
31
|
+
|
32
|
+
require 'cassandra'
|
33
|
+
|
34
|
+
To use a specific version (1.0 in this example) you would use a
|
35
|
+
slightly differently formatted require:
|
36
|
+
|
37
|
+
require 'cassandra/1.0'
|
38
|
+
|
39
|
+
#### Environment Variable Method
|
40
|
+
These mechanisms work well when you are using the cassandra gem in your
|
41
|
+
own projects or irb, but if you would rather not hard code your app to a
|
42
|
+
specific version you can always specify an environment variable with the
|
43
|
+
version you are using:
|
44
|
+
|
45
|
+
export CASSANDRA_VERSION=0.8
|
46
|
+
|
47
|
+
Then you would use the default require as listed above:
|
48
|
+
|
49
|
+
require 'cassandra'
|
50
|
+
|
51
|
+
## Read/Write API Method Reference
|
52
|
+
|
53
|
+
### insert
|
54
|
+
|
55
|
+
* column\_family - The column\_family that you are inserting into.
|
56
|
+
* key - The row key to insert.
|
57
|
+
* hash - The columns or super columns to insert.
|
58
|
+
* options - Valid options are:
|
59
|
+
* :timestamp - Uses the current time if none specified.
|
60
|
+
* :consistency - Uses the default write consistency if none specified.
|
61
|
+
* :ttl - If specified this is the number of seconds after the insert that this value will be available.
|
62
|
+
|
63
|
+
This is the main method used to insert rows into cassandra. If the
|
64
|
+
column\_family that you are inserting into is a SuperColumnFamily then
|
65
|
+
the hash passed in should be a nested hash, otherwise it should be a
|
66
|
+
flat hash.
|
67
|
+
|
68
|
+
This method can also be called while in batch mode. If in batch mode
|
69
|
+
then we queue up the mutations (an insert in this case) and pass them to
|
70
|
+
cassandra in a single batch at the end of the block.
|
71
|
+
|
72
|
+
Example:
|
73
|
+
|
74
|
+
@client.insert(:Statuses, key, {'body' => 'v', 'user' => 'v'})
|
75
|
+
|
76
|
+
columns = {@uuids[1] => 'v1', @uuids[2] => 'v2'}
|
77
|
+
@client.insert(:StatusRelationships, key, {'user_timelines' => columns})
|
78
|
+
|
79
|
+
|
80
|
+
### remove
|
81
|
+
|
82
|
+
* column\_family - The column\_family that you are working with.
|
83
|
+
* key - The row key to remove (or remove columns from).
|
84
|
+
* columns - Either a single super_column or a list of columns to remove.
|
85
|
+
* sub_columns - The list of sub\_columns to remove.
|
86
|
+
* options - Valid options are:
|
87
|
+
* :timestamp - Uses the current time if none specified.
|
88
|
+
* :consistency - Uses the default write consistency if none specified.
|
89
|
+
|
90
|
+
This method is used to delete (actually marking them as deleted with a
|
91
|
+
tombstone) rows, columns, or super columns depending on the parameters
|
92
|
+
passed. If only a key is passed the entire row will be marked as deleted.
|
93
|
+
If a column name is passed in that column will be deleted.
|
94
|
+
|
95
|
+
Example:
|
96
|
+
|
97
|
+
@client.insert(:Statuses, key, {'body' => 'v', 'subject' => 'v'})
|
98
|
+
|
99
|
+
@client.remove(:Statuses, key, 'body') # removes the 'body' column
|
100
|
+
@client.remove(:Statuses, key) # removes the row
|
101
|
+
|
102
|
+
### count\_columns
|
103
|
+
|
104
|
+
Count the columns for the provided parameters.
|
105
|
+
|
106
|
+
* column\_family - The column\_family that you are working with.
|
107
|
+
* key - The row key.
|
108
|
+
* columns - Either a single super_column or a list of columns.
|
109
|
+
* sub_columns - The list of sub\_columns to select.
|
110
|
+
* options - Valid options are:
|
111
|
+
* :start - The column name to start from.
|
112
|
+
* :stop - The column name to stop at.
|
113
|
+
* :count - The maximum count of columns to return. (By default cassandra will count up to 100 columns)
|
114
|
+
* :consistency - Uses the default read consistency if none specified.
|
115
|
+
|
116
|
+
Example:
|
117
|
+
|
118
|
+
@client.insert(:Statuses, key, {'body' => 'v1', 'user' => 'v2'})
|
119
|
+
@client.count_columns(:Statuses, key) # returns 2
|
120
|
+
|
121
|
+
### get
|
122
|
+
|
123
|
+
Return a hash (actually, a Cassandra::OrderedHash) or a single value
|
124
|
+
representing the element at the column_family:key:[column]:[sub_column]
|
125
|
+
path you request.
|
126
|
+
|
127
|
+
* column\_family - The column\_family that you are working with.
|
128
|
+
* key - The row key to select.
|
129
|
+
* columns - Either a single super\_column or a list of columns.
|
130
|
+
* sub\_columns - The list of sub\_columns to select.
|
131
|
+
* options - Valid options are:
|
132
|
+
* :count - The number of columns requested to be returned.
|
133
|
+
* :start - The starting value for selecting a range of columns.
|
134
|
+
* :finish - The final value for selecting a range of columns.
|
135
|
+
* :reversed - If set to true the results will be returned in
|
136
|
+
reverse order.
|
137
|
+
* :consistency - Uses the default read consistency if none specified.
|
138
|
+
|
139
|
+
Example:
|
140
|
+
|
141
|
+
@client.insert(:Users, key, {'body' => 'v', 'user' => 'v'})
|
142
|
+
@client.get(:Users, key)) # returns {'body' => 'v', 'user' => 'v'}
|
143
|
+
|
144
|
+
### multi\_get
|
145
|
+
|
146
|
+
Multi-key version of Cassandra#get.
|
147
|
+
|
148
|
+
This method allows you to select multiple rows with a single query.
|
149
|
+
If a key that is passed in doesn't exist an empty hash will be
|
150
|
+
returned.
|
151
|
+
|
152
|
+
Supports the same parameters as Cassandra#get.
|
153
|
+
|
154
|
+
* column_family - The column_family that you are working with.
|
155
|
+
* key - An array of keys to select.
|
156
|
+
* columns - Either a single super_column or a list of columns.
|
157
|
+
* sub_columns - The list of sub\_columns to select.
|
158
|
+
* options - Valid options are:
|
159
|
+
* :count - The number of columns requested to be returned.
|
160
|
+
* :start - The starting value for selecting a range of columns.
|
161
|
+
* :finish - The final value for selecting a range of columns.
|
162
|
+
* :reversed - If set to true the results will be returned in reverse order.
|
163
|
+
* :consistency - Uses the default read consistency if none specified.
|
164
|
+
|
165
|
+
Example:
|
166
|
+
|
167
|
+
@client.insert(:Users, '1', {'body' => 'v1', 'user' => 'v1'})
|
168
|
+
@client.insert(:Users, '2', {'body' => 'v2', 'user' => 'v2'})
|
169
|
+
|
170
|
+
expected = OrderedHash[
|
171
|
+
'1', {'body' => 'v1', 'user' => 'v1'},
|
172
|
+
'2', {'body' => 'v2', 'user' => 'v2'},
|
173
|
+
'bogus', {}
|
174
|
+
]
|
175
|
+
result = @client.multi_get(:Users, ['1', '2', 'bogus'])
|
176
|
+
|
177
|
+
### exists?
|
178
|
+
|
179
|
+
Return true if the column\_family:key:[column]:[sub\_column] path you
|
180
|
+
request exists.
|
181
|
+
|
182
|
+
If passed in only a row key it will query for any columns (limiting
|
183
|
+
to 1) for that row key. If a column is passed in it will query for
|
184
|
+
that specific column/super column.
|
185
|
+
|
186
|
+
This method will return true or false.
|
187
|
+
|
188
|
+
* column\_family - The column\_family that you are working with.
|
189
|
+
* key - The row key to check.
|
190
|
+
* columns - Either a single super\_column or a list of columns.
|
191
|
+
* sub\_columns - The list of sub\_columns to check.
|
192
|
+
* options - Valid options are:
|
193
|
+
* :consistency - Uses the default read consistency if none specified.
|
194
|
+
|
195
|
+
Example:
|
196
|
+
|
197
|
+
@client.insert(:Statuses, 'key', {'body' => 'v'})
|
198
|
+
@client.exists?(:Statuses, 'key') # returns true
|
199
|
+
@client.exists?(:Statuses, 'bogus') # returns false
|
200
|
+
@client.exists?(:Statuses, 'key', 'body') # returns true
|
201
|
+
@client.exists?(:Statuses, 'key', 'bogus') # returns false
|
202
|
+
|
203
|
+
### get\_range
|
204
|
+
Return an Cassandra::OrderedHash containing the columns specified for the given
|
205
|
+
range of keys in the column\_family you request.
|
206
|
+
|
207
|
+
This method is just a convenience wrapper around Cassandra#get_range_single
|
208
|
+
and Cassandra#get\_range\_batch. If :key\_size, :batch\_size, or a block
|
209
|
+
is passed in Cassandra#get\_range\_batch will be called. Otherwise
|
210
|
+
Cassandra#get\_range\_single will be used.
|
211
|
+
|
212
|
+
The start\_key and finish\_key parameters are only useful for iterating of all records
|
213
|
+
as is done in the Cassandra#each and Cassandra#each\_key methods if you are using the
|
214
|
+
RandomPartitioner.
|
215
|
+
|
216
|
+
If the table is partitioned with OrderPreservingPartitioner you may
|
217
|
+
use the start\_key and finish\_key params to select all records with
|
218
|
+
the same prefix value.
|
219
|
+
|
220
|
+
If a block is passed in we will yield the row key and columns for
|
221
|
+
each record returned.
|
222
|
+
|
223
|
+
Please note that Cassandra returns a row for each row that has existed in the
|
224
|
+
system since gc\_grace\_seconds. This is because deleted row keys are marked as
|
225
|
+
deleted, but left in the system until the cluster has had resonable time to replicate the deletion.
|
226
|
+
This function attempts to suppress deleted rows (actually any row returned without
|
227
|
+
columns is suppressed).
|
228
|
+
|
229
|
+
* column\_family - The column\_family that you are working with.
|
230
|
+
* options - Valid options are:
|
231
|
+
* :start\_key - The starting value for selecting a range of keys (only useful with OPP).
|
232
|
+
* :finish\_key - The final value for selecting a range of keys (only useful with OPP).
|
233
|
+
* :key\_count - The total number of keys to return from the query. (see note regarding deleted records)
|
234
|
+
* :batch\_size - The maximum number of keys to return per query. If specified will loop until :key\_count is obtained or all records have been returned.
|
235
|
+
* :columns - A list of columns to return.
|
236
|
+
* :count - The number of columns requested to be returned.
|
237
|
+
* :start - The starting value for selecting a range of columns.
|
238
|
+
* :finish - The final value for selecting a range of columns.
|
239
|
+
* :reversed - If set to true the results will be returned in reverse order.
|
240
|
+
* :consistency - Uses the default read consistency if none specified.
|
241
|
+
|
242
|
+
Example:
|
243
|
+
|
244
|
+
10.times do |i|
|
245
|
+
@client.insert(:Statuses, i.to_s, {'body' => '1'})
|
246
|
+
end
|
247
|
+
|
248
|
+
@client.get_range_keys(:Statuses, :key_count => 4)
|
249
|
+
|
250
|
+
# returns:
|
251
|
+
#{
|
252
|
+
# '0' => {'body' => '1'},
|
253
|
+
# '1' => {'body' => '1'},
|
254
|
+
# '2' => {'body' => '1'},
|
255
|
+
# '3' => {'body' => '1'}
|
256
|
+
#}
|
257
|
+
|
258
|
+
### count\_range
|
259
|
+
|
260
|
+
Return an Array containing all of the keys within a given range.
|
261
|
+
|
262
|
+
This method just calls Cassandra#get\_range and returns the
|
263
|
+
row keys for the records returned.
|
264
|
+
|
265
|
+
See Cassandra#get\_range for options.
|
266
|
+
|
267
|
+
### get\_range\_keys
|
268
|
+
|
269
|
+
Return an Array containing all of the keys within a given range.
|
270
|
+
|
271
|
+
This method just calls Cassandra#get\_range and returns the
|
272
|
+
row keys for the records returned.
|
273
|
+
|
274
|
+
See Cassandra#get\_range for options.
|
275
|
+
|
276
|
+
### each\_key
|
277
|
+
Iterate through each key within the given range parameters. This function can be
|
278
|
+
used to iterate over each key in the given column family.
|
279
|
+
|
280
|
+
This method just calls Cassandra#get\_range and yields each row key.
|
281
|
+
|
282
|
+
See Cassandra#get\_range for options.
|
283
|
+
|
284
|
+
Example:
|
285
|
+
10.times do |i|
|
286
|
+
@client.insert(:Statuses, k + i.to_s, {"body-#{i.to_s}" => 'v'})
|
287
|
+
end
|
288
|
+
|
289
|
+
@client.each_key(:Statuses) do |key|
|
290
|
+
print key
|
291
|
+
end
|
292
|
+
|
293
|
+
# returns 0123456789
|
294
|
+
|
295
|
+
### each
|
296
|
+
Iterate through each row within the given column\_family.
|
297
|
+
|
298
|
+
This method just calls Cassandra#get\_range and yields the key and
|
299
|
+
columns.
|
300
|
+
|
301
|
+
See Cassandra#get\_range for options.
|
302
|
+
|
303
|
+
### get\_index\_slices
|
304
|
+
This method is used to query a secondary index with a set of
|
305
|
+
provided search parameters
|
306
|
+
|
307
|
+
Please note that you can either specify a
|
308
|
+
CassandraThrift::IndexClause or an array of hashes with the
|
309
|
+
format as below.
|
310
|
+
|
311
|
+
* column\_family - The Column Family this operation will be run on.
|
312
|
+
* index\_clause - This can either be a CassandraThrift::IndexClause or an array of hashes with the following keys:
|
313
|
+
* :column\_name - Column to be compared
|
314
|
+
* :value - Value to compare against
|
315
|
+
* :comparison - Type of comparison to do.
|
316
|
+
* options
|
317
|
+
* :key\_count - Set maximum number of rows to return. (Only works if CassandraThrift::IndexClause is not passed in.)
|
318
|
+
* :key\_start - Set starting row key for search. (Only works if CassandraThrift::IndexClause is not passed in.)
|
319
|
+
* :consistency
|
320
|
+
|
321
|
+
Example:
|
322
|
+
|
323
|
+
@client.create_index('Twitter', 'Statuses', 'x', 'LongType')
|
324
|
+
|
325
|
+
@client.insert(:Statuses, 'row1', { 'x' => [0,10].pack("NN") })
|
326
|
+
|
327
|
+
(2..10).to_a.each do |i|
|
328
|
+
@twitter.insert(:Statuses, 'row' + i.to_s, { 'x' => [0,20].pack("NN"), 'non_indexed' => [i].pack('N*') })
|
329
|
+
end
|
330
|
+
|
331
|
+
@client.insert(:Statuses, 'row11', { 'x' => [0,30].pack("NN") })
|
332
|
+
|
333
|
+
expressions = [{:column_name => 'x', :value => [0,20].pack("NN"), :comparison => "=="}]
|
334
|
+
|
335
|
+
# verify multiples will be returned
|
336
|
+
@client.get_indexed_slices(:Statuses, expressions).length # returns 9
|
337
|
+
|
338
|
+
# verify that GT and LT queries perform properly
|
339
|
+
expressions = [
|
340
|
+
{ :column_name => 'x',
|
341
|
+
:value => [0,20].pack("NN"),
|
342
|
+
:comparison => "=="},
|
343
|
+
{ :column_name => 'non_indexed',
|
344
|
+
:value => [5].pack("N*"),
|
345
|
+
:comparison => ">"}
|
346
|
+
]
|
347
|
+
|
348
|
+
@client.get_indexed_slices(:Statuses, expressions).length # returns 5
|
349
|
+
|
350
|
+
### batch
|
351
|
+
Takes a block where all the mutations (inserts and deletions) inside it are
|
352
|
+
queued, and at the end of the block are passed to cassandra in a single batch.
|
353
|
+
|
354
|
+
If you don't want to send all the mutations inside the block in a big single
|
355
|
+
batch, you can use the :queue\_size option to send smaller batches. If the
|
356
|
+
queue is not empty at the end of the block, the remaining mutations are sent.
|
357
|
+
|
358
|
+
* options
|
359
|
+
* :consistency - Override the consistency level from individual mutations.
|
360
|
+
* :queue\_size - Maximum number of mutations to send at once.
|
361
|
+
|
362
|
+
Example:
|
363
|
+
|
364
|
+
@client.batch do
|
365
|
+
@client.insert(:Statuses, 'k1', {'body' => 'v1'})
|
366
|
+
@client.insert(:Statuses, 'k2', {'body' => 'v2'})
|
367
|
+
@client.remove(:Statuses, 'k3')
|
368
|
+
end
|
369
|
+
|
370
|
+
|
371
|
+
## Reporting Problems
|
372
|
+
|
373
|
+
The Github issue tracker is [here](http://github.com/twitter/cassandra/issues). If you have problems with this library or Cassandra itself, please use the [cassandra-user mailing list](http://mail-archives.apache.org/mod_mbox/incubator-cassandra-user/).
|