mirror of https://github.com/tootsuite/mastodon
				
				
				
			Track historical space stats in PgHero to determine PostgreSQL growth (#8906)
							parent
							
								
									d4b7d75968
								
							
						
					
					
						commit
						7f9dd92a27
					
				|  | @ -0,0 +1,11 @@ | |||
| # frozen_string_literal: true | ||||
| 
 | ||||
| class Scheduler::PgheroScheduler | ||||
|   include Sidekiq::Worker | ||||
| 
 | ||||
|   sidekiq_options unique: :until_executed, retry: 0 | ||||
| 
 | ||||
|   def perform | ||||
|     PgHero.capture_space_stats | ||||
|   end | ||||
| end | ||||
|  | @ -33,3 +33,6 @@ | |||
|   backup_cleanup_scheduler: | ||||
|     cron: '<%= Random.rand(0..59) %> <%= Random.rand(3..5) %> * * *' | ||||
|     class: Scheduler::BackupCleanupScheduler | ||||
|   pghero_scheduler: | ||||
|     cron: '0 0 * * *' | ||||
|     class: Scheduler::PgheroScheduler | ||||
|  |  | |||
|  | @ -0,0 +1,13 @@ | |||
| class CreatePgheroSpaceStats < ActiveRecord::Migration[5.2] | ||||
|   def change | ||||
|     create_table :pghero_space_stats do |t| | ||||
|       t.text :database | ||||
|       t.text :schema | ||||
|       t.text :relation | ||||
|       t.integer :size, limit: 8 | ||||
|       t.timestamp :captured_at | ||||
|     end | ||||
| 
 | ||||
|     add_index :pghero_space_stats, [:database, :captured_at] | ||||
|   end | ||||
| end | ||||
							
								
								
									
										11
									
								
								db/schema.rb
								
								
								
								
							
							
						
						
									
										11
									
								
								db/schema.rb
								
								
								
								
							|  | @ -10,7 +10,7 @@ | |||
| # | ||||
| # It's strongly recommended that you check this file into your version control system. | ||||
| 
 | ||||
| ActiveRecord::Schema.define(version: 2018_09_29_222014) do | ||||
| ActiveRecord::Schema.define(version: 2018_10_07_025445) do | ||||
| 
 | ||||
|   # These are extensions that must be enabled in order to support this database | ||||
|   enable_extension "plpgsql" | ||||
|  | @ -372,6 +372,15 @@ ActiveRecord::Schema.define(version: 2018_09_29_222014) do | |||
|     t.index ["uid"], name: "index_oauth_applications_on_uid", unique: true | ||||
|   end | ||||
| 
 | ||||
|   create_table "pghero_space_stats", force: :cascade do |t| | ||||
|     t.text "database" | ||||
|     t.text "schema" | ||||
|     t.text "relation" | ||||
|     t.bigint "size" | ||||
|     t.datetime "captured_at" | ||||
|     t.index ["database", "captured_at"], name: "index_pghero_space_stats_on_database_and_captured_at" | ||||
|   end | ||||
| 
 | ||||
|   create_table "preview_cards", force: :cascade do |t| | ||||
|     t.string "url", default: "", null: false | ||||
|     t.string "title", default: "", null: false | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Eugen Rochko
						Eugen Rochko