memory-monitoring 0.0.5

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 247d7bcb9aea01083c596d41d3fbea19b7f52615
4
+ data.tar.gz: 3bd494bab71aad5a7d189e3f66d9ba79fa392167
5
+ SHA512:
6
+ metadata.gz: 2c38447d7d7383b41a75f2c7876dae8de559c20900958b69928e50338bc138254d2cb38dc7c0e7c6caf52c052e8afee4dea94d87ce3d8900b436326b4bbd682a
7
+ data.tar.gz: 7c5ff2b53a852c40ce8542fcd1268dd9ba1fcdffc8f1c0431a0de2ead76f7caa3f5e17479e7383ae9118f0fb533de36e4c5cbcdb41055f2a827740eb2e8b70e5
@@ -0,0 +1,14 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /Gemfile.lock
4
+ /_yardoc/
5
+ /coverage/
6
+ /doc/
7
+ /pkg/
8
+ /spec/reports/
9
+ /tmp/
10
+ *.bundle
11
+ *.so
12
+ *.o
13
+ *.a
14
+ mkmf.log
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in memory-monitoring.gemspec
4
+ gemspec
@@ -0,0 +1,22 @@
1
+ Copyright (c) 2014 Howl王
2
+
3
+ MIT License
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ "Software"), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
@@ -0,0 +1,48 @@
1
+ # MemoryMonitoring Middleware
2
+
3
+ `MemoryMonitoring::Rack` provides support for Memory monitor for Rack compatible web applications.
4
+
5
+ ## Installation
6
+
7
+ Add this line to your application's Gemfile:
8
+
9
+ ```ruby
10
+ gem 'memory-monitoring'
11
+ ```
12
+
13
+ And then execute:
14
+
15
+ $ bundle
16
+
17
+ Or install it yourself as:
18
+
19
+ $ gem install memory-monitoring
20
+
21
+ ## Configuration
22
+
23
+ ### Rack
24
+
25
+ In `config.ru`, configure `MemoryMonitoring::Rack` by passing a block to the `use` command:
26
+
27
+ ```ruby
28
+ use MemoryMonitoring::Rack
29
+ ```
30
+
31
+ Or Padrino, Sinatra:
32
+ ```ruby
33
+ run MemoryMonitoring::Rack.new(Padrino.application)
34
+ ```
35
+ ### Rails
36
+ Put something like the code below in `config/application.rb` of your Rails application. For example, this will allow GET, POST or OPTIONS requests from any origin on any resource.
37
+
38
+ ```ruby
39
+ module YourApp
40
+ class Application < Rails::Application
41
+
42
+ # ...
43
+
44
+ config.middleware.use MemoryMonitoring::Rack
45
+
46
+ end
47
+ end
48
+ ```
@@ -0,0 +1,2 @@
1
+ require "bundler/gem_tasks"
2
+
@@ -0,0 +1,2 @@
1
+ # coding: utf-8
2
+ require 'memory_monitoring'
@@ -0,0 +1,6 @@
1
+ # coding: utf-8
2
+ require 'awesome_print' if ENV['RAILS_ENV'] || ENV['RACK_ENV'] == 'development'
3
+ require 'memory_monitoring/version'
4
+ require 'memory_monitoring/simple_formatter'
5
+ require 'memory_monitoring/injector'
6
+ require 'memory_monitoring/rack'
@@ -0,0 +1,46 @@
1
+ # coding: utf-8
2
+ require 'json' unless defined?(::JSON)
3
+
4
+ module MemoryMonitoring
5
+ class Injector # 注入
6
+ def initialize(messages)
7
+ @messages = messages
8
+ end
9
+
10
+ # 注入
11
+ def injection(type, body)
12
+ case type
13
+ when /text\/html/, '*/*'
14
+ html_injection(body)
15
+ when /application\/json/
16
+ json_injection(body)
17
+ when /text\/javascript/
18
+ js_injection(body)
19
+ else
20
+ puts type
21
+ puts '_'*88
22
+ puts body
23
+ puts '_'*88
24
+ body
25
+ end
26
+ end
27
+
28
+ private
29
+
30
+ def js_injection(body)
31
+ body = "console.log('#{@messages.join(', ')}');\n" + body
32
+ end
33
+
34
+ def html_injection(body)
35
+ body = "<!-- #{ @messages.join(', ') } -->\n" + body
36
+ end
37
+
38
+ def json_injection(body)
39
+ body = ::JSON.load(body)
40
+ @messages = @messages.map { |m| m.split(': ') }.flatten
41
+ body[:debug] = Hash[*@messages]
42
+ body = ::JSON.dump(body)
43
+ end
44
+
45
+ end
46
+ end
@@ -0,0 +1,68 @@
1
+ # coding: utf-8
2
+ require 'logger' unless defined?(::Logger)
3
+
4
+ module MemoryMonitoring
5
+ class Rack # 中间件 Middleware
6
+ def initialize(app)
7
+ @app = app
8
+ logger.formatter = SimpleFormatter.new
9
+ reset # 重置计数器
10
+ end
11
+
12
+ def call(env)
13
+ request_uri = env['HTTP_HOST'] + env['PATH_INFO']
14
+ @messages = []
15
+ # 除静态文件外,读取当前内存
16
+ unless request_uri =~ /\/(assets|uploads|images|fonts|js|css)|.(js|css|png|gif|jpg|jpeg|woff|txt|ico|eot|map|svg|ttf)/
17
+ @start_rss = current_memory
18
+ @start_at = Time.now
19
+ end
20
+ # 获取输出内容
21
+ status, headers, response = @app.call(env)
22
+ # rescue => e # 出错了
23
+ ensure
24
+ unless messages.empty?
25
+ @level = :error if status.nil? || status.between?(400, 600)
26
+ logger.send @level, (@messages + [ request_uri ]).join("\t")
27
+ unless response.nil?
28
+ body = (response.respond_to?(:body) ? response.body : response).first
29
+ injector = Injector.new(@messages)
30
+ return [status, headers, [injector.injection(env['HTTP_ACCEPT'], body)]]
31
+ end
32
+ end
33
+ end
34
+
35
+ private
36
+
37
+ def messages
38
+ if @start_rss > 0
39
+ @ended_rss = current_memory
40
+ @ended_at = Time.now
41
+ if distance > 0
42
+ @messages << "Response Time: #{(@ended_at - @start_at).round(3)} sec."
43
+ @messages << "Consume Memory: #{distance} MB."
44
+ @messages << "Now: #{@ended_rss} MB."
45
+ end
46
+ reset # 重置计数器
47
+ end
48
+ @messages
49
+ end
50
+
51
+ def reset
52
+ @level = :info
53
+ @start_rss = @ended_rss = 0
54
+ end
55
+
56
+ def distance # 内存差
57
+ (@ended_rss - @start_rss).round(2)
58
+ end
59
+
60
+ def current_memory
61
+ (`ps -o rss= -p #{$$}`.to_f / 1024).round(2)
62
+ end
63
+
64
+ def logger
65
+ @logger ||= ::Logger.new './log/memory.log', 'daily'
66
+ end
67
+ end
68
+ end
@@ -0,0 +1,22 @@
1
+ # coding: utf-8
2
+
3
+ module MemoryMonitoring
4
+ class SimpleFormatter # 日志格式
5
+ SEVERITY_TO_TAG_MAP = { 'DEBUG'=>'meh', 'INFO'=>'fyi', 'WARN'=>'hmm', 'ERROR'=>'wtf', 'FATAL'=>'omg', 'UNKNOWN'=>'???' }
6
+ SEVERITY_TO_COLOR_MAP = { 'DEBUG'=>'0;37', 'INFO'=>'32', 'WARN'=>'33', 'ERROR'=>'31', 'FATAL'=>'31', 'UNKNOWN'=>'37' }
7
+ USE_HUMOROUS_SEVERITIES = true
8
+
9
+ def call(severity, time, progname, msg)
10
+ if USE_HUMOROUS_SEVERITIES
11
+ formatted_severity = sprintf("%-3s", SEVERITY_TO_TAG_MAP[severity])
12
+ else
13
+ formatted_severity = sprintf("%-5s", severity)
14
+ end
15
+
16
+ formatted_time = time.strftime("%Y-%m-%d %H:%M:%S.") << time.usec.to_s[0..2].rjust(3)
17
+ color = SEVERITY_TO_COLOR_MAP[severity]
18
+
19
+ "\033[0;37m#{formatted_time}\033[0m [\033[#{color}m#{formatted_severity}\033[0m] #{msg.strip} (pid:#{$$})\n"
20
+ end
21
+ end
22
+ end
@@ -0,0 +1,5 @@
1
+ # coding: utf-8
2
+
3
+ module MemoryMonitoring
4
+ VERSION = "0.0.5"
5
+ end
@@ -0,0 +1,26 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'memory_monitoring/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "memory-monitoring"
8
+ spec.version = MemoryMonitoring::VERSION
9
+ spec.authors = ["Howl王"]
10
+ spec.email = ["howl.wong@gmail.com"]
11
+ spec.summary = %q{ Memory Monitoring }
12
+ spec.description = %q{ Provides support for Memory monitor for Rack compatible web applications. }
13
+ spec.homepage = "https://github.com/mimosa/memory-monitoring"
14
+ spec.license = "MIT"
15
+
16
+ spec.files = `git ls-files -z`.split("\x0")
17
+ spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) }
18
+ spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
19
+ spec.require_paths = ["lib"]
20
+
21
+ spec.add_runtime_dependency 'json', '~> 1.8', '>= 1.8.0'
22
+
23
+ spec.add_development_dependency 'bundler', '~> 1.7'
24
+ spec.add_development_dependency 'rake', '~> 10.0'
25
+ spec.add_development_dependency 'awesome_print', '~> 1.2'
26
+ end
metadata ADDED
@@ -0,0 +1,118 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: memory-monitoring
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.5
5
+ platform: ruby
6
+ authors:
7
+ - Howl王
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2014-12-21 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: json
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '1.8'
20
+ - - ">="
21
+ - !ruby/object:Gem::Version
22
+ version: 1.8.0
23
+ type: :runtime
24
+ prerelease: false
25
+ version_requirements: !ruby/object:Gem::Requirement
26
+ requirements:
27
+ - - "~>"
28
+ - !ruby/object:Gem::Version
29
+ version: '1.8'
30
+ - - ">="
31
+ - !ruby/object:Gem::Version
32
+ version: 1.8.0
33
+ - !ruby/object:Gem::Dependency
34
+ name: bundler
35
+ requirement: !ruby/object:Gem::Requirement
36
+ requirements:
37
+ - - "~>"
38
+ - !ruby/object:Gem::Version
39
+ version: '1.7'
40
+ type: :development
41
+ prerelease: false
42
+ version_requirements: !ruby/object:Gem::Requirement
43
+ requirements:
44
+ - - "~>"
45
+ - !ruby/object:Gem::Version
46
+ version: '1.7'
47
+ - !ruby/object:Gem::Dependency
48
+ name: rake
49
+ requirement: !ruby/object:Gem::Requirement
50
+ requirements:
51
+ - - "~>"
52
+ - !ruby/object:Gem::Version
53
+ version: '10.0'
54
+ type: :development
55
+ prerelease: false
56
+ version_requirements: !ruby/object:Gem::Requirement
57
+ requirements:
58
+ - - "~>"
59
+ - !ruby/object:Gem::Version
60
+ version: '10.0'
61
+ - !ruby/object:Gem::Dependency
62
+ name: awesome_print
63
+ requirement: !ruby/object:Gem::Requirement
64
+ requirements:
65
+ - - "~>"
66
+ - !ruby/object:Gem::Version
67
+ version: '1.2'
68
+ type: :development
69
+ prerelease: false
70
+ version_requirements: !ruby/object:Gem::Requirement
71
+ requirements:
72
+ - - "~>"
73
+ - !ruby/object:Gem::Version
74
+ version: '1.2'
75
+ description: " Provides support for Memory monitor for Rack compatible web applications. "
76
+ email:
77
+ - howl.wong@gmail.com
78
+ executables: []
79
+ extensions: []
80
+ extra_rdoc_files: []
81
+ files:
82
+ - ".gitignore"
83
+ - Gemfile
84
+ - LICENSE.txt
85
+ - README.md
86
+ - Rakefile
87
+ - lib/memory-monitoring.rb
88
+ - lib/memory_monitoring.rb
89
+ - lib/memory_monitoring/injector.rb
90
+ - lib/memory_monitoring/rack.rb
91
+ - lib/memory_monitoring/simple_formatter.rb
92
+ - lib/memory_monitoring/version.rb
93
+ - memory-monitoring.gemspec
94
+ homepage: https://github.com/mimosa/memory-monitoring
95
+ licenses:
96
+ - MIT
97
+ metadata: {}
98
+ post_install_message:
99
+ rdoc_options: []
100
+ require_paths:
101
+ - lib
102
+ required_ruby_version: !ruby/object:Gem::Requirement
103
+ requirements:
104
+ - - ">="
105
+ - !ruby/object:Gem::Version
106
+ version: '0'
107
+ required_rubygems_version: !ruby/object:Gem::Requirement
108
+ requirements:
109
+ - - ">="
110
+ - !ruby/object:Gem::Version
111
+ version: '0'
112
+ requirements: []
113
+ rubyforge_project:
114
+ rubygems_version: 2.4.2
115
+ signing_key:
116
+ specification_version: 4
117
+ summary: Memory Monitoring
118
+ test_files: []