mirror of
				https://github.com/discourse/discourse.git
				synced 2025-02-25 18:55:32 -06:00 
			
		
		
		
	memory profiling script
This commit is contained in:
		
							
								
								
									
										30
									
								
								script/test_mem.rb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								script/test_mem.rb
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | ||||
| start = Time.now | ||||
| require 'objspace' | ||||
| require File.expand_path("../../config/environment", __FILE__) | ||||
|  | ||||
| # preload stuff | ||||
| I18n.t(:posts) | ||||
|  | ||||
| # load up all models and schema | ||||
| (ActiveRecord::Base.connection.tables - %w[schema_migrations]).each do |table| | ||||
| table.classify.constantize.first rescue nil | ||||
| end | ||||
|  | ||||
| # router warm up | ||||
| Rails.application.routes.recognize_path('abc') rescue nil | ||||
|  | ||||
| puts "Ruby version #{RUBY_VERSION} p#{RUBY_PATCHLEVEL}" | ||||
|  | ||||
| puts "Bootup time: #{Time.now - start} secs" | ||||
|  | ||||
| GC.start | ||||
|  | ||||
| puts "RSS: #{`ps -o rss -p #{$$}`.chomp.split("\n").last.to_i} KB" | ||||
|  | ||||
| s = ObjectSpace.each_object(String).map do |o| | ||||
|   ObjectSpace.memsize_of(o) + 40 # rvalue size on x64 | ||||
| end | ||||
|  | ||||
| puts "Total strings: #{s.count} space used: #{s.sum} bytes" | ||||
|  | ||||
|  | ||||
		Reference in New Issue
	
	Block a user