quark 0.0.3 → 0.0.4

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/bin/quark CHANGED
@@ -10,6 +10,7 @@ module Quark
10
10
  Quark::Config.set("quark.address", "127.0.0.1")
11
11
  Quark::Config.set("quark.port", 12161)
12
12
  Quark::Config.set("quark.blocksize", 3600000)
13
+ Quark::Config.set("quark.udp", false)
13
14
 
14
15
  (OptionParser.new do |opts|
15
16
  opts.banner = "Usage: quark [options]"
@@ -49,6 +50,11 @@ module Quark
49
50
  Quark::Config.set("quark.blocksize", blocksize)
50
51
  end
51
52
 
53
+ # -----------------------------------------------------------------------------
54
+ opts.on('-U', '--udp', 'Create a UDP server instead of a TCP server') do
55
+ Quark::Config.set("quark.udp", true)
56
+ end
57
+
52
58
  end).parse!
53
59
 
54
60
  Quark::Server.run()
data/lib/quark.rb CHANGED
@@ -28,7 +28,14 @@ module Quark
28
28
  end
29
29
 
30
30
  def receive_data(data)
31
- command, arguments = data.chomp.split(' ',2)
31
+ # if the data perfectly resembles a graphite-formatted metric (without a command prefix)
32
+ # then assume the command is "observe"
33
+ if data =~ /^[\w\.\-]+ -?[\d\.]+ \d{10,13}$/
34
+ command = "OBSERVE"
35
+ arguments = data.chomp
36
+ else
37
+ command, arguments = data.chomp.split(' ',2)
38
+ end
32
39
 
33
40
  begin
34
41
  if methods.include?(:"process_command_#{command.downcase}")
@@ -47,6 +54,7 @@ module Quark
47
54
  else
48
55
  raise Quark::InvalidCommand.new("Unknown command '#{command.upcase}'")
49
56
  end
57
+
50
58
  rescue Quark::Error => e
51
59
  send_json({
52
60
  :success => false,
@@ -89,8 +97,13 @@ module Quark
89
97
  puts "Starting server at #{@filename}..."
90
98
  EM::start_server(@filename, Quark::SocketServer)
91
99
  else
92
- puts "Starting server on #{@address}:#{@port}..."
93
- EM::start_server(@address, @port, Quark::SocketServer)
100
+ if Quark::Config.get("quark.udp") === true
101
+ puts "Starting UDP server on #{@address}:#{@port}..."
102
+ EM::open_datagram_socket(@address, @port, Quark::SocketServer)
103
+ else
104
+ puts "Starting TCP server on #{@address}:#{@port}..."
105
+ EM::start_server(@address, @port, Quark::SocketServer)
106
+ end
94
107
  end
95
108
  end
96
109
  end
@@ -12,7 +12,10 @@ module Quark
12
12
  block = Integer(timestamp / Quark::Config.get("quark.blocksize").to_i)
13
13
 
14
14
  @redis.hset("#{@_prefix}:#{id}:#{block}", timestamp, value)
15
- return nil
15
+ return ({
16
+ :metric => id,
17
+ :block => block
18
+ })
16
19
  end
17
20
  end
18
21
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: quark
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.3
4
+ version: 0.0.4
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -13,7 +13,7 @@ date: 2014-05-06 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: multi_json
16
- requirement: &9517780 !ruby/object:Gem::Requirement
16
+ requirement: &13210860 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - =
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: 1.7.9
22
22
  type: :runtime
23
23
  prerelease: false
24
- version_requirements: *9517780
24
+ version_requirements: *13210860
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: eventmachine
27
- requirement: &9507840 !ruby/object:Gem::Requirement
27
+ requirement: &13223240 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - ~>
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: 1.0.0
33
33
  type: :runtime
34
34
  prerelease: false
35
- version_requirements: *9507840
35
+ version_requirements: *13223240
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: redis
38
- requirement: &9506400 !ruby/object:Gem::Requirement
38
+ requirement: &13232620 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ~>
@@ -43,10 +43,10 @@ dependencies:
43
43
  version: 3.0.0
44
44
  type: :runtime
45
45
  prerelease: false
46
- version_requirements: *9506400
46
+ version_requirements: *13232620
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: hiredis
49
- requirement: &9504900 !ruby/object:Gem::Requirement
49
+ requirement: &13228620 !ruby/object:Gem::Requirement
50
50
  none: false
51
51
  requirements:
52
52
  - - ~>
@@ -54,10 +54,10 @@ dependencies:
54
54
  version: 0.5.2
55
55
  type: :runtime
56
56
  prerelease: false
57
- version_requirements: *9504900
57
+ version_requirements: *13228620
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: em-synchrony
60
- requirement: &9502740 !ruby/object:Gem::Requirement
60
+ requirement: &13243440 !ruby/object:Gem::Requirement
61
61
  none: false
62
62
  requirements:
63
63
  - - ~>
@@ -65,7 +65,18 @@ dependencies:
65
65
  version: 1.0.3
66
66
  type: :runtime
67
67
  prerelease: false
68
- version_requirements: *9502740
68
+ version_requirements: *13243440
69
+ - !ruby/object:Gem::Dependency
70
+ name: hashlib
71
+ requirement: &13241340 !ruby/object:Gem::Requirement
72
+ none: false
73
+ requirements:
74
+ - - ! '>='
75
+ - !ruby/object:Gem::Version
76
+ version: 0.0.35
77
+ type: :runtime
78
+ prerelease: false
79
+ version_requirements: *13241340
69
80
  description: A small service for logging and retrieving timeseries metrics into a
70
81
  Redis server
71
82
  email: garyhetzel@gmail.com