waterdrop 0.2.1 → 0.3.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 3ceca692ac4b8b16fe33f636d44f3cda6ebb2be7
4
- data.tar.gz: 16385fd05baf2dd90deff2b6c7c6a6b4ca585bdd
3
+ metadata.gz: 787b506aa11e17d65df6abb198bbd86b750b95a8
4
+ data.tar.gz: 248d7a49d44adb5379940b64e7d5fd27b3821557
5
5
  SHA512:
6
- metadata.gz: 48c546123bcd03a06cda425d00e78c5fa235a59d19a87e20142962b6f5d41e4e671a63a5b882425481ab59bae20a684ef52ca7ca229828ae3c878972bc1de0ad
7
- data.tar.gz: 1f25b37359947f74dc1cd85dd8b34728ac629b9a6cc3bce311656fb0aefae69a47c6d4f898cc9b1ef353b8e8a85e2be1d50ef0e17cf820553e82fe1eb21e2cf7
6
+ metadata.gz: b161ff34041a2471d19fea75d770c3f4e2eb1e5bdccd6ddca10863cc08444846c31aef795a3b69c779e239f1579e823326857ea78ab74d728570af69d0a0c397
7
+ data.tar.gz: 1713e4c8d7556c7d66d1ec76a848fcfbd8eb5b38ed7230f1b4518606f30232314a69915bf5bafc3a1bc8c038f267518bc23642e2d60293c810281e567d352845
data/CHANGELOG.md CHANGED
@@ -1,5 +1,8 @@
1
1
  # WaterDrop changelog
2
2
 
3
+ ## 0.3.0
4
+ - Driver change from Poseidon (not maintained) to Ruby-Kafka
5
+
3
6
  ## 0.2.0
4
7
  - Version dump - this WaterDrop version no longer relies on Aspector to work
5
8
  - #17 - Logger for Aspector - WaterDrop no longer depends on Aspector
data/Gemfile.lock CHANGED
@@ -1,58 +1,49 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- waterdrop (0.2.1)
4
+ waterdrop (0.3.0)
5
5
  bundler
6
6
  connection_pool
7
7
  null-logger
8
- poseidon
9
8
  rake
9
+ ruby-kafka
10
10
 
11
11
  GEM
12
12
  remote: https://rubygems.org/
13
13
  specs:
14
- abstract_type (0.0.7)
15
- activemodel (4.2.5)
16
- activesupport (= 4.2.5)
14
+ activemodel (4.2.6)
15
+ activesupport (= 4.2.6)
17
16
  builder (~> 3.1)
18
- activesupport (4.2.5)
17
+ activesupport (4.2.6)
19
18
  i18n (~> 0.7)
20
19
  json (~> 1.7, >= 1.7.7)
21
20
  minitest (~> 5.1)
22
21
  thread_safe (~> 0.3, >= 0.3.4)
23
22
  tzinfo (~> 1.1)
24
- adamantium (0.2.0)
25
- ice_nine (~> 0.11.0)
26
- memoizable (~> 0.4.0)
23
+ addressable (2.4.0)
27
24
  ast (2.2.0)
28
- astrolabe (1.3.1)
29
- parser (~> 2.2)
30
25
  axiom-types (0.1.1)
31
26
  descendants_tracker (~> 0.0.4)
32
27
  ice_nine (~> 0.11.0)
33
28
  thread_safe (~> 0.3, >= 0.3.1)
34
- brakeman (3.1.4)
29
+ brakeman (3.2.1)
35
30
  erubis (~> 2.6)
36
- fastercsv (~> 1.5)
37
31
  haml (>= 3.0, < 5.0)
38
32
  highline (>= 1.6.20, < 2.0)
39
- multi_json (~> 1.2)
40
- ruby2ruby (>= 2.1.1, < 2.3.0)
41
- ruby_parser (~> 3.7.0)
33
+ ruby2ruby (~> 2.3.0)
34
+ ruby_parser (~> 3.8.1)
42
35
  safe_yaml (>= 1.0)
43
36
  sass (~> 3.0)
44
37
  slim (>= 1.3.6, < 4.0)
45
38
  terminal-table (~> 1.4)
46
- bson (4.0.0)
39
+ bson (4.0.4)
47
40
  builder (3.2.2)
48
- codeclimate-engine-rb (0.1.0)
41
+ codeclimate-engine-rb (0.3.1)
49
42
  virtus (~> 1.0)
50
- coderay (1.1.0)
43
+ coderay (1.1.1)
51
44
  coercible (1.0.0)
52
45
  descendants_tracker (~> 0.0.1)
53
- concord (0.1.5)
54
- adamantium (~> 0.2.0)
55
- equalizer (~> 0.0.9)
46
+ colorize (0.7.7)
56
47
  connection_pool (2.2.0)
57
48
  descendants_tracker (0.0.4)
58
49
  thread_safe (~> 0.3, >= 0.3.1)
@@ -60,10 +51,10 @@ GEM
60
51
  docile (1.1.5)
61
52
  equalizer (0.0.11)
62
53
  erubis (2.7.0)
63
- faker (1.6.1)
54
+ faker (1.6.3)
64
55
  i18n (~> 0.5)
65
- fastercsv (1.5.5)
66
- flay (2.6.1)
56
+ flay (2.7.0)
57
+ erubis (~> 2.7.0)
67
58
  ruby_parser (~> 3.0)
68
59
  sexp_processor (~> 4.0)
69
60
  flog (4.3.2)
@@ -77,28 +68,27 @@ GEM
77
68
  sysexits (~> 1.1)
78
69
  highline (1.7.8)
79
70
  i18n (0.7.0)
80
- ice_nine (0.11.1)
71
+ ice_nine (0.11.2)
81
72
  json (1.8.3)
82
- memoizable (0.4.2)
83
- thread_safe (~> 0.3, >= 0.3.1)
73
+ launchy (2.4.3)
74
+ addressable (~> 2.3)
84
75
  method_source (0.8.2)
85
- minitest (5.8.3)
86
- mongo (2.2.1)
76
+ minitest (5.8.4)
77
+ mongo (2.2.4)
87
78
  bson (~> 4.0)
88
- mongoid (5.0.2)
79
+ mongoid (5.1.1)
89
80
  activemodel (~> 4.0)
90
81
  mongo (~> 2.1)
91
- origin (~> 2.1)
82
+ origin (~> 2.2)
92
83
  tzinfo (>= 0.3.37)
93
84
  mongoid-rspec (3.0.0)
94
85
  mongoid (~> 5.0)
95
86
  rake
96
87
  rspec (~> 3.3)
97
- multi_json (1.11.2)
98
- null-logger (0.1.0)
99
- origin (2.1.1)
100
- parser (2.2.3.0)
101
- ast (>= 1.1, < 3.0)
88
+ null-logger (0.1.1)
89
+ origin (2.2.0)
90
+ parser (2.3.0.6)
91
+ ast (~> 2.2)
102
92
  polishgeeks-dev-tools (1.2.1)
103
93
  brakeman
104
94
  faker
@@ -112,64 +102,62 @@ GEM
112
102
  simplecov
113
103
  timecop
114
104
  yard
115
- poseidon (0.0.5)
116
105
  powerpack (0.1.1)
117
- private_attr (1.1.0)
118
- procto (0.0.2)
119
106
  pry (0.10.3)
120
107
  coderay (~> 1.1.0)
121
108
  method_source (~> 0.8.1)
122
109
  slop (~> 3.4)
123
- rainbow (2.0.0)
124
- rake (10.4.2)
125
- reek (3.7.1)
126
- codeclimate-engine-rb (~> 0.1.0)
127
- parser (~> 2.2, >= 2.2.2.5)
128
- private_attr (~> 1.1)
110
+ rainbow (2.1.0)
111
+ rake (11.1.1)
112
+ reek (3.11)
113
+ codeclimate-engine-rb (~> 0.3.1)
114
+ parser (~> 2.3, >= 2.3.0.6)
129
115
  rainbow (~> 2.0)
130
- unparser (~> 0.2.2)
131
116
  rspec (3.4.0)
132
117
  rspec-core (~> 3.4.0)
133
118
  rspec-expectations (~> 3.4.0)
134
119
  rspec-mocks (~> 3.4.0)
135
- rspec-core (3.4.1)
120
+ rspec-core (3.4.4)
136
121
  rspec-support (~> 3.4.0)
137
122
  rspec-expectations (3.4.0)
138
123
  diff-lcs (>= 1.2.0, < 2.0)
139
124
  rspec-support (~> 3.4.0)
140
- rspec-mocks (3.4.0)
125
+ rspec-mocks (3.4.1)
141
126
  diff-lcs (>= 1.2.0, < 2.0)
142
127
  rspec-support (~> 3.4.0)
143
128
  rspec-support (3.4.1)
144
- rubocop (0.35.1)
145
- astrolabe (~> 1.3)
146
- parser (>= 2.2.3.0, < 3.0)
129
+ rubocop (0.38.0)
130
+ parser (>= 2.3.0.6, < 3.0)
147
131
  powerpack (~> 0.1)
148
132
  rainbow (>= 1.99.1, < 3.0)
149
133
  ruby-progressbar (~> 1.7)
150
- tins (<= 1.6.0)
134
+ unicode-display_width (~> 1.0, >= 1.0.1)
135
+ ruby-kafka (0.3.2)
151
136
  ruby-progressbar (1.7.5)
152
- ruby2ruby (2.2.0)
137
+ ruby2ruby (2.3.0)
153
138
  ruby_parser (~> 3.1)
154
139
  sexp_processor (~> 4.0)
155
- ruby_parser (3.7.2)
140
+ ruby_parser (3.8.1)
156
141
  sexp_processor (~> 4.1)
157
- rubycritic (2.4.0)
158
- flay (= 2.6.1)
142
+ rubycritic (2.8.0)
143
+ colorize
144
+ flay (= 2.7.0)
159
145
  flog (= 4.3.2)
160
- parser (>= 2.2.0, < 3.0)
161
- reek (= 3.7.1)
146
+ launchy (= 2.4.3)
147
+ parser (~> 2.3)
148
+ reek (= 3.11)
149
+ ruby_parser (~> 3.8)
162
150
  virtus (~> 1.0)
163
151
  safe_yaml (1.0.4)
164
- sass (3.4.20)
165
- sexp_processor (4.6.0)
152
+ sass (3.4.21)
153
+ sexp_processor (4.7.0)
166
154
  shoulda (3.5.0)
167
155
  shoulda-context (~> 1.0, >= 1.0.1)
168
156
  shoulda-matchers (>= 1.4.1, < 3.0)
169
157
  shoulda-context (1.2.1)
170
158
  shoulda-matchers (2.8.0)
171
159
  activesupport (>= 3.0.0)
172
- simplecov (0.11.1)
160
+ simplecov (0.11.2)
173
161
  docile (~> 1.1.0)
174
162
  json (~> 1.8)
175
163
  simplecov-html (~> 0.10.0)
@@ -182,19 +170,11 @@ GEM
182
170
  temple (0.7.6)
183
171
  terminal-table (1.5.2)
184
172
  thread_safe (0.3.5)
185
- tilt (2.0.1)
173
+ tilt (2.0.2)
186
174
  timecop (0.8.0)
187
- tins (1.6.0)
188
175
  tzinfo (1.2.2)
189
176
  thread_safe (~> 0.1)
190
- unparser (0.2.4)
191
- abstract_type (~> 0.0.7)
192
- adamantium (~> 0.2.0)
193
- concord (~> 0.1.5)
194
- diff-lcs (~> 1.2.5)
195
- equalizer (~> 0.0.9)
196
- parser (~> 2.2.2)
197
- procto (~> 0.0.2)
177
+ unicode-display_width (1.0.2)
198
178
  virtus (1.0.5)
199
179
  axiom-types (~> 0.1)
200
180
  coercible (~> 1.0)
data/README.md CHANGED
@@ -3,6 +3,7 @@
3
3
  [![Build Status](https://travis-ci.org/karafka/waterdrop.png)](https://travis-ci.org/karafka/waterdrop)
4
4
  [![Code Climate](https://codeclimate.com/github/karafka/waterdrop/badges/gpa.svg)](https://codeclimate.com/github/karafka/waterdrop)
5
5
  [![Gem Version](https://badge.fury.io/rb/waterdrop.svg)](http://badge.fury.io/rb/waterdrop)
6
+ [![Join the chat at https://gitter.im/karafka/karafka](https://badges.gitter.im/karafka/karafka.svg)](https://gitter.im/karafka/karafka?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
6
7
 
7
8
  Gem used to send messages to Kafka in an easy way.
8
9
 
@@ -18,7 +18,7 @@ module WaterDrop
18
18
  kafka_hosts
19
19
  send_messages
20
20
  raise_on_failure
21
- )
21
+ ).freeze
22
22
 
23
23
  OPTIONS.each do |attr_name|
24
24
  attr_accessor attr_name
@@ -21,11 +21,8 @@ module WaterDrop
21
21
  def send!
22
22
  return true unless ::WaterDrop.config.send_messages?
23
23
 
24
- Pool.with do |producer|
25
- producer.send_messages([
26
- Poseidon::MessageToSend.new(topic, message)
27
- ])
28
- end
24
+ Pool.with { |producer| producer.send_message(self) }
25
+
29
26
  ::WaterDrop.logger.info("Message #{message} was sent to topic '#{topic}'")
30
27
  rescue StandardError => e
31
28
  # Even if we dont reraise this exception, it should log that it happened
@@ -1,5 +1,5 @@
1
1
  module WaterDrop
2
- # Raw poseidon connection pool for WaterDrop messages delivery
2
+ # Raw Kafka producers connection pool for WaterDrop messages delivery
3
3
  module Pool
4
4
  extend SingleForwardable
5
5
  # Delegate directly to pool
@@ -1,31 +1,20 @@
1
1
  module WaterDrop
2
2
  # Proxy object for a producer (sender) objects that are inside pool
3
3
  # We use it to provide additional timeout monitoring layer
4
- # There seem to be some issues with Poseidon and usage of sockets that
5
- # are old and not used - that's why we just reinitialize connection if
6
- # the connection layer is not being used for too long
4
+ # There used to be an issue with Poseidon (previous engine for this lib)
5
+ # usage of sockets that are old and not used - that's why we just
6
+ # reinitialize connection if the connection layer is not being used for too long
7
+ # We keep this logic to avoid problems just in case. If those problems won't occure
8
+ # with Ruby-Kafka, we will drop it
7
9
  class ProducerProxy
8
10
  # How long should be object considered alive if nothing is being
9
11
  # send using it. After that time, we will recreate the connection
10
12
  LIFE_TIME = 5 * 60 # 5 minute
11
13
 
12
14
  # If sending fails - how many times we should try with a new connection
13
- # @note It works in a similar way to Poseidon internal max_send_retries option, but it will
14
- # create a new connection after failure (Poseidon tries to use the same one)
15
15
  MAX_SEND_RETRIES = 1
16
16
 
17
- # All default poseidon parameters that we want to use
18
- POSEIDON_PARAMS = {
19
- metadata_refresh_interval_ms: 5 * 60 * 1000, # 5 minutes
20
- # @see https://kafka.apache.org/08/configuration.html
21
- # Security level for producer
22
- required_acks: -1,
23
- # @see https://issues.apache.org/jira/browse/KAFKA-1494
24
- retry_backoff_ms: 1000,
25
- max_send_retries: 1
26
- }
27
-
28
- # @return [WaterDrop::ProducerProxy] proxy object to Poseidon::Producer
17
+ # @return [WaterDrop::ProducerProxy] proxy object to Kafka::Producer
29
18
  # @note To ignore @last_usage nil case - we just assume that it is being
30
19
  # first used when we create it
31
20
  def initialize
@@ -33,17 +22,16 @@ module WaterDrop
33
22
  @attempts = 0
34
23
  end
35
24
 
36
- # Sends messages to Kafka
37
- # @param messages [Array<Poseidon::MessageToSend>] array with messages that we want to send
38
- # @return [Boolean] were the messages send
39
- # @note Even if you send one message - it still needs to be in an array
25
+ # Sends message to Kafka
26
+ # @param message [WaterDrop::Message] message that we want to send
40
27
  # @note If something goes wrong it will assume that producer is corrupted and will try to
41
28
  # create a new one
42
29
  # @example Send 1 message
43
- # ProducerProxy.new.send_messages([Poseidon::MessageToSend.new(topic, message)])
44
- def send_messages(messages)
30
+ # ProducerProxy.new.send_message(WaterDrop::Message.new(topic, message))
31
+ def send_message(message)
45
32
  touch
46
- producer.send_messages(messages)
33
+ producer.produce(message.message, topic: message.topic)
34
+ producer.deliver_messages
47
35
  rescue StandardError => e
48
36
  reload!
49
37
 
@@ -61,20 +49,10 @@ module WaterDrop
61
49
  @last_usage = Time.now
62
50
  end
63
51
 
64
- # @return [Poseidon::Producer] producer instance to which we can forward method requests
52
+ # @return [Kafka::Producer] producer instance to which we can forward method requests
65
53
  def producer
66
54
  reload! if dead?
67
- # Metadata refresh interval needs to be in miliseconds
68
- @producer ||= Poseidon::Producer.new(
69
- ::WaterDrop.config.kafka_hosts,
70
- producer_id,
71
- POSEIDON_PARAMS
72
- )
73
- end
74
-
75
- # @return [String] random unique id for producer
76
- def producer_id
77
- object_id.to_s + Time.now.to_f.to_s
55
+ @producer ||= Kafka.new(seed_brokers: ::WaterDrop.config.kafka_hosts).producer
78
56
  end
79
57
 
80
58
  # @return [Boolean] true if we cannot use producer anymore because it was not used for a
@@ -85,6 +63,7 @@ module WaterDrop
85
63
 
86
64
  # Resets a producer so a new one will be created once requested
87
65
  def reload!
66
+ @producer.shutdown if @producer
88
67
  @producer = nil
89
68
  end
90
69
  end
@@ -2,5 +2,5 @@
2
2
  # WaterDrop library
3
3
  module WaterDrop
4
4
  # Current WaterDrop version
5
- VERSION = '0.2.1'.freeze
5
+ VERSION = '0.3.0'.freeze
6
6
  end
data/lib/waterdrop.rb CHANGED
@@ -6,7 +6,7 @@
6
6
  logger
7
7
  pathname
8
8
  json
9
- poseidon
9
+ kafka
10
10
  forwardable
11
11
  connection_pool
12
12
  null_logger
data/waterdrop.gemspec CHANGED
@@ -16,7 +16,7 @@ Gem::Specification.new do |spec|
16
16
 
17
17
  spec.add_dependency 'bundler', '>= 0'
18
18
  spec.add_dependency 'rake', '>= 0'
19
- spec.add_dependency 'poseidon', '>= 0'
19
+ spec.add_dependency 'ruby-kafka', '>= 0'
20
20
  spec.add_dependency 'connection_pool', '>= 0'
21
21
  spec.add_dependency 'null-logger'
22
22
 
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: waterdrop
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.2.1
4
+ version: 0.3.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Maciej Mensfeld
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2016-01-26 00:00:00.000000000 Z
12
+ date: 2016-03-21 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: bundler
@@ -40,7 +40,7 @@ dependencies:
40
40
  - !ruby/object:Gem::Version
41
41
  version: '0'
42
42
  - !ruby/object:Gem::Dependency
43
- name: poseidon
43
+ name: ruby-kafka
44
44
  requirement: !ruby/object:Gem::Requirement
45
45
  requirements:
46
46
  - - ">="