Module: Oboe::Inst::Cassandra

Included in:
Cassandra
Defined in:
lib/oboe/inst/cassandra.rb

Instance Method Summary collapse

Instance Method Details

#add_column_family_with_oboe(cf_def) ⇒ Object



230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
# File 'lib/oboe/inst/cassandra.rb', line 230

def add_column_family_with_oboe(cf_def)
  if Oboe.tracing?
    report_kvs = extract_trace_details(:add_column_family, nil, nil, nil)
    begin
      report_kvs[:Cf] = cf_def[:name] if cf_def.is_a?(Hash) and cf_def.has_key?(:name)
    rescue
    end

    Oboe::API.trace('cassandra', report_kvs) do
      add_column_family_without_oboe(cf_def)
    end
  else
    add_column_family_without_oboe(cf_def)
  end
end

#add_keyspace_with_oboe(ks_def) ⇒ Object



258
259
260
261
262
263
264
265
266
267
268
269
# File 'lib/oboe/inst/cassandra.rb', line 258

def add_keyspace_with_oboe(ks_def)
  if Oboe.tracing?
    report_kvs = extract_trace_details(:add_keyspace, nil, nil, nil)
    report_kvs[:Name] = ks_def.name rescue ""

    Oboe::API.trace('cassandra', report_kvs) do
      add_keyspace_without_oboe(ks_def)
    end
  else
    add_keyspace_without_oboe(ks_def)
  end
end

#count_columns_with_oboe(column_family, key, *columns_and_options) ⇒ Object



71
72
73
74
75
76
77
78
79
80
81
82
83
# File 'lib/oboe/inst/cassandra.rb', line 71

def count_columns_with_oboe(column_family, key, *columns_and_options)
  args = [column_family, key] + columns_and_options
  
  if Oboe.tracing?
    report_kvs = extract_trace_details(:count_columns, column_family, key, columns_and_options)

    Oboe::API.trace('cassandra', report_kvs) do
      send :count_columns_without_oboe, *args
    end
  else
    send :count_columns_without_oboe, *args
  end
end

#create_index_with_oboe(keyspace, column_family, column_name, validation_class) ⇒ Object



195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
# File 'lib/oboe/inst/cassandra.rb', line 195

def create_index_with_oboe(keyspace, column_family, column_name, validation_class)
  if Oboe.tracing?
    report_kvs = extract_trace_details(:create_index, column_family, nil, nil)
    begin
      report_kvs[:Keyspace] = keyspace.to_s
      report_kvs[:Column_name] = column_name.to_s
      report_kvs[:Validation_class] = validation_class.to_s
    rescue
    end

    Oboe::API.trace('cassandra', report_kvs) do
      create_index_without_oboe(keyspace, column_family, column_name, validation_class)
    end
  else
    create_index_without_oboe(keyspace, column_family, column_name, validation_class)
  end
end

#drop_column_family_with_oboe(column_family) ⇒ Object



246
247
248
249
250
251
252
253
254
255
256
# File 'lib/oboe/inst/cassandra.rb', line 246

def drop_column_family_with_oboe(column_family)
  if Oboe.tracing?
    report_kvs = extract_trace_details(:drop_column_family, column_family, nil, nil)

    Oboe::API.trace('cassandra', report_kvs) do
      drop_column_family_without_oboe(column_family)
    end
  else
    drop_column_family_without_oboe(column_family)
  end
end

#drop_index_with_oboe(keyspace, column_family, column_name) ⇒ Object



213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
# File 'lib/oboe/inst/cassandra.rb', line 213

def drop_index_with_oboe(keyspace, column_family, column_name)
  if Oboe.tracing?
    report_kvs = extract_trace_details(:drop_index, column_family, nil, nil)
    begin
      report_kvs[:Keyspace] = keyspace.to_s
      report_kvs[:Column_name] = column_name.to_s
    rescue
    end

    Oboe::API.trace('cassandra', report_kvs) do
      drop_index_without_oboe(keyspace, column_family, column_name)
    end
  else
    drop_index_without_oboe(keyspace, column_family, column_name)
  end
end

#drop_keyspace_with_oboe(keyspace) ⇒ Object



271
272
273
274
275
276
277
278
279
280
281
282
# File 'lib/oboe/inst/cassandra.rb', line 271

def drop_keyspace_with_oboe(keyspace)
  if Oboe.tracing?
    report_kvs = extract_trace_details(:drop_keyspace, nil, nil, nil)
    report_kvs[:Name] = keyspace.to_s rescue ""

    Oboe::API.trace('cassandra', report_kvs) do
      drop_keyspace_without_oboe(keyspace)
    end
  else
    drop_keyspace_without_oboe(keyspace)
  end
end

#exists_with_oboe?(column_family, key, *columns_and_options) ⇒ Boolean

Returns:

  • (Boolean)


141
142
143
144
145
146
147
148
149
150
151
152
153
# File 'lib/oboe/inst/cassandra.rb', line 141

def exists_with_oboe?(column_family, key, *columns_and_options)
  args = [column_family, key] + columns_and_options
  
  if Oboe.tracing?
    report_kvs = extract_trace_details(:exists?, column_family, key, columns_and_options)

    Oboe::API.trace('cassandra', report_kvs) do
      send :exists_without_oboe?, *args
    end
  else
    send :exists_without_oboe?, *args
  end
end

#extract_trace_details(op, column_family, keys, args, options = {}) ⇒ Object



7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
# File 'lib/oboe/inst/cassandra.rb', line 7

def extract_trace_details(op, column_family, keys, args, options = {})
  report_kvs = {}

  begin
    report_kvs[:Op] = op.to_s
    report_kvs[:Cf] = column_family.to_s if column_family
    report_kvs[:Key] = keys.inspect if keys
   
    # Open issue - how to handle multiple Cassandra servers
    report_kvs[:RemoteHost], report_kvs[:RemotePort] = @servers.first.split(":")

    report_kvs[:Backtrace] = Oboe::API.backtrace if Oboe::Config[:cassandra][:collect_backtraces]

    if options.empty? and args.is_a?(Array)
      options = args.last if args.last.is_a?(Hash)
    end
    
    unless options.empty?
      [:start_key, :finish_key, :key_count, :batch_size, :columns, :count, :start,
       :stop, :finish, :finished, :reversed, :consistency, :ttl].each do |k|
        report_kvs[k.to_s.capitalize] = options[k] if options.has_key?(k)
      end

      if op == :get_indexed_slices
        index_clause = columns_and_options[:index_clause] || {}
        unless index_clause.empty?
          [:column_name, :value, :comparison].each do |k|
            report_kvs[k.to_s.capitalize] = index_clause[k] if index_clause.has_key?(k)
          end
        end
      end
    end
  rescue
  end

  report_kvs
end

#get_columns_with_oboe(column_family, key, *columns_and_options) ⇒ Object



85
86
87
88
89
90
91
92
93
94
95
96
97
# File 'lib/oboe/inst/cassandra.rb', line 85

def get_columns_with_oboe(column_family, key, *columns_and_options)
  args = [column_family, key] + columns_and_options
  
  if Oboe.tracing? and not Oboe::Context.tracing_layer_op?(:multi_get_columns)
    report_kvs = extract_trace_details(:get_columns, column_family, key, columns_and_options)

    Oboe::API.trace('cassandra', report_kvs) do
      send :get_columns_without_oboe, *args
    end
  else
    send :get_columns_without_oboe, *args
  end
end

#get_indexed_slices_with_oboe(column_family, index_clause, *columns_and_options) ⇒ Object



181
182
183
184
185
186
187
188
189
190
191
192
193
# File 'lib/oboe/inst/cassandra.rb', line 181

def get_indexed_slices_with_oboe(column_family, index_clause, *columns_and_options)
  args = [column_family, index_clause] + columns_and_options
  
  if Oboe.tracing?
    report_kvs = extract_trace_details(:get_indexed_slices, column_family, nil, columns_and_options)

    Oboe::API.trace('cassandra', report_kvs) do
      send :get_indexed_slices_without_oboe, *args
    end
  else
    send :get_indexed_slices_without_oboe, *args
  end
end

#get_range_batch_with_oboe(column_family, options = {}) ⇒ Object



168
169
170
171
172
173
174
175
176
177
178
179
# File 'lib/oboe/inst/cassandra.rb', line 168

def get_range_batch_with_oboe(column_family, options = {})
  if Oboe.tracing?
    report_kvs = extract_trace_details(:get_range_batch, column_family, nil, nil)
    args = [column_family, options]

    Oboe::API.trace('cassandra', report_kvs, :get_range_batch) do
      get_range_batch_without_oboe(column_family, options)
    end
  else
    get_range_batch_without_oboe(column_family, options)
  end
end

#get_range_single_with_oboe(column_family, options = {}) ⇒ Object



155
156
157
158
159
160
161
162
163
164
165
166
# File 'lib/oboe/inst/cassandra.rb', line 155

def get_range_single_with_oboe(column_family, options = {})
  if Oboe.tracing? and not Oboe::Context.tracing_layer_op?(:get_range_batch)
    report_kvs = extract_trace_details(:get_range_single, column_family, nil, nil)
    args = [column_family, options]

    Oboe::API.trace('cassandra', report_kvs) do
      get_range_single_without_oboe(column_family, options)
    end
  else
    get_range_single_without_oboe(column_family, options)
  end
end

#get_with_oboe(column_family, key, *columns_and_options) ⇒ Object



113
114
115
116
117
118
119
120
121
122
123
124
125
# File 'lib/oboe/inst/cassandra.rb', line 113

def get_with_oboe(column_family, key, *columns_and_options)
  args = [column_family, key] + columns_and_options
  
  if Oboe.tracing?
    report_kvs = extract_trace_details(:get, column_family, key, columns_and_options)

    Oboe::API.trace('cassandra', report_kvs, :get) do
      send :get_without_oboe, *args
    end
  else
    send :get_without_oboe, *args
  end
end

#insert_with_oboe(column_family, key, hash, options = {}) ⇒ Object



45
46
47
48
49
50
51
52
53
54
55
# File 'lib/oboe/inst/cassandra.rb', line 45

def insert_with_oboe(column_family, key, hash, options = {})
  if Oboe.tracing?
    report_kvs = extract_trace_details(:insert, column_family, key, hash, options)

    Oboe::API.trace('cassandra', report_kvs) do
      insert_without_oboe(column_family, key, hash, options = {})
    end
  else
    insert_without_oboe(column_family, key, hash, options = {})
  end
end

#multi_get_columns_with_oboe(column_family, key, *columns_and_options) ⇒ Object



99
100
101
102
103
104
105
106
107
108
109
110
111
# File 'lib/oboe/inst/cassandra.rb', line 99

def multi_get_columns_with_oboe(column_family, key, *columns_and_options)
  args = [column_family, key] + columns_and_options
  
  if Oboe.tracing?
    report_kvs = extract_trace_details(:multi_get_columns, column_family, key, columns_and_options)

    Oboe::API.trace('cassandra', report_kvs, :multi_get_columns) do
      send :multi_get_columns_without_oboe, *args
    end
  else
    send :multi_get_columns_without_oboe, *args
  end
end

#multi_get_with_oboe(column_family, key, *columns_and_options) ⇒ Object



127
128
129
130
131
132
133
134
135
136
137
138
139
# File 'lib/oboe/inst/cassandra.rb', line 127

def multi_get_with_oboe(column_family, key, *columns_and_options)
  args = [column_family, key] + columns_and_options
  
  if Oboe.tracing? and not Oboe::Context.tracing_layer_op?(:get)
    report_kvs = extract_trace_details(:multi_get, column_family, key, columns_and_options)

    Oboe::API.trace('cassandra', report_kvs) do
      send :multi_get_without_oboe, *args
    end
  else
    send :multi_get_without_oboe, *args
  end
end

#remove_with_oboe(column_family, key, *columns_and_options) ⇒ Object



57
58
59
60
61
62
63
64
65
66
67
68
69
# File 'lib/oboe/inst/cassandra.rb', line 57

def remove_with_oboe(column_family, key, *columns_and_options)
  args = [column_family, key] + columns_and_options
  
  if Oboe.tracing?
    report_kvs = extract_trace_details(:remove, column_family, key, columns_and_options)

    Oboe::API.trace('cassandra', report_kvs) do
      send :remove_without_oboe, *args
    end
  else
    send :remove_without_oboe, *args
  end
end