quark 0.0.3 → 0.0.4

Sign up to get free protection for your applications and to get access to all the features.
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