Commit edf6df27 authored by Jan Provaznik's avatar Jan Provaznik

Merge branch 'align-schema-ordering-for-jh' into 'master'

Align the ordering of partitioned tables

See merge request gitlab-org/gitlab!72697
parents 89543370 fa7ed8b6
...@@ -10,6 +10,29 @@ if Gitlab.ee? ...@@ -10,6 +10,29 @@ if Gitlab.ee?
IncidentManagement::PendingEscalations::Alert, IncidentManagement::PendingEscalations::Alert,
IncidentManagement::PendingEscalations::Issue IncidentManagement::PendingEscalations::Issue
]) ])
else
Gitlab::Database::Partitioning.register_tables([
{
table_name: 'incident_management_pending_alert_escalations',
partitioned_column: :process_at, strategy: :monthly
},
{
table_name: 'incident_management_pending_issue_escalations',
partitioned_column: :process_at, strategy: :monthly
}
])
end
# The following tables are already defined as models
unless Gitlab.jh?
Gitlab::Database::Partitioning.register_tables([
# This should be synchronized with the following model:
# https://gitlab.com/gitlab-jh/gitlab/-/blob/main-jh/jh/app/models/phone/verification_code.rb
{
table_name: 'verification_codes',
partitioned_column: :created_at, strategy: :monthly
}
])
end end
begin begin
......
...@@ -135,6 +135,19 @@ CREATE TABLE incident_management_pending_issue_escalations ( ...@@ -135,6 +135,19 @@ CREATE TABLE incident_management_pending_issue_escalations (
) )
PARTITION BY RANGE (process_at); PARTITION BY RANGE (process_at);
CREATE TABLE verification_codes (
created_at timestamp with time zone DEFAULT now() NOT NULL,
visitor_id_code text NOT NULL,
code text NOT NULL,
phone text NOT NULL,
CONSTRAINT check_9b84e6aaff CHECK ((char_length(code) <= 8)),
CONSTRAINT check_ccc542256b CHECK ((char_length(visitor_id_code) <= 64)),
CONSTRAINT check_f5684c195b CHECK ((char_length(phone) <= 32))
)
PARTITION BY RANGE (created_at);
COMMENT ON TABLE verification_codes IS 'JiHu-specific table';
CREATE TABLE web_hook_logs ( CREATE TABLE web_hook_logs (
id bigint NOT NULL, id bigint NOT NULL,
web_hook_id integer NOT NULL, web_hook_id integer NOT NULL,
...@@ -20185,19 +20198,6 @@ CREATE SEQUENCE users_statistics_id_seq ...@@ -20185,19 +20198,6 @@ CREATE SEQUENCE users_statistics_id_seq
ALTER SEQUENCE users_statistics_id_seq OWNED BY users_statistics.id; ALTER SEQUENCE users_statistics_id_seq OWNED BY users_statistics.id;
CREATE TABLE verification_codes (
created_at timestamp with time zone DEFAULT now() NOT NULL,
visitor_id_code text NOT NULL,
code text NOT NULL,
phone text NOT NULL,
CONSTRAINT check_9b84e6aaff CHECK ((char_length(code) <= 8)),
CONSTRAINT check_ccc542256b CHECK ((char_length(visitor_id_code) <= 64)),
CONSTRAINT check_f5684c195b CHECK ((char_length(phone) <= 32))
)
PARTITION BY RANGE (created_at);
COMMENT ON TABLE verification_codes IS 'JiHu-specific table';
CREATE TABLE vulnerabilities ( CREATE TABLE vulnerabilities (
id bigint NOT NULL, id bigint NOT NULL,
milestone_id bigint, milestone_id bigint,
...@@ -3,40 +3,73 @@ ...@@ -3,40 +3,73 @@
module Gitlab module Gitlab
module Database module Database
module Partitioning module Partitioning
def self.register_models(models) class TableWithoutModel
registered_models.merge(models) include PartitionedTable::ClassMethods
end
attr_reader :table_name
def self.registered_models def initialize(table_name:, partitioned_column:, strategy:)
@registered_models ||= Set.new @table_name = table_name
partitioned_by(partitioned_column, strategy: strategy)
end
def connection
Gitlab::Database::SharedModel.connection
end
end end
def self.sync_partitions(models_to_sync = registered_models) class << self
Gitlab::AppLogger.info(message: 'Syncing dynamic postgres partitions') def register_models(models)
registered_models.merge(models)
end
Gitlab::Database::EachDatabase.each_model_connection(models_to_sync) do |model| def register_tables(tables)
PartitionManager.new(model).sync_partitions registered_tables.merge(tables)
end end
Gitlab::AppLogger.info(message: 'Finished sync of dynamic postgres partitions') def sync_partitions(models_to_sync = registered_for_sync)
end Gitlab::AppLogger.info(message: 'Syncing dynamic postgres partitions')
def self.report_metrics(models_to_monitor = registered_models) Gitlab::Database::EachDatabase.each_model_connection(models_to_sync) do |model|
partition_monitoring = PartitionMonitoring.new PartitionManager.new(model).sync_partitions
end
Gitlab::Database::EachDatabase.each_model_connection(models_to_monitor) do |model| Gitlab::AppLogger.info(message: 'Finished sync of dynamic postgres partitions')
partition_monitoring.report_metrics_for_model(model)
end end
end
def self.drop_detached_partitions def report_metrics(models_to_monitor = registered_models)
Gitlab::AppLogger.info(message: 'Dropping detached postgres partitions') partition_monitoring = PartitionMonitoring.new
Gitlab::Database::EachDatabase.each_model_connection(models_to_monitor) do |model|
partition_monitoring.report_metrics_for_model(model)
end
end
def drop_detached_partitions
Gitlab::AppLogger.info(message: 'Dropping detached postgres partitions')
Gitlab::Database::EachDatabase.each_database_connection do
DetachedPartitionDropper.new.perform
end
Gitlab::Database::EachDatabase.each_database_connection do Gitlab::AppLogger.info(message: 'Finished dropping detached postgres partitions')
DetachedPartitionDropper.new.perform
end end
Gitlab::AppLogger.info(message: 'Finished dropping detached postgres partitions') private
def registered_models
@registered_models ||= Set.new
end
def registered_tables
@registered_tables ||= Set.new
end
def registered_for_sync
registered_models + registered_tables.map do |table|
TableWithoutModel.new(**table)
end
end
end end
end end
end end
......
...@@ -45,8 +45,13 @@ RSpec.describe Gitlab::Database::Partitioning do ...@@ -45,8 +45,13 @@ RSpec.describe Gitlab::Database::Partitioning do
let(:model) { double('model') } let(:model) { double('model') }
it 'manages partitions for each registered model' do it 'manages partitions for each registered model' do
registered_for_sync = described_class.__send__(:registered_for_sync)
allow(described_class).to receive(:registered_for_sync)
.and_return(registered_for_sync)
expect(Gitlab::Database::EachDatabase).to receive(:each_model_connection) expect(Gitlab::Database::EachDatabase).to receive(:each_model_connection)
.with(described_class.registered_models) .with(registered_for_sync)
.and_yield(model) .and_yield(model)
expect(partition_manager_class).to receive(:new).with(model).and_return(partition_manager) expect(partition_manager_class).to receive(:new).with(model).and_return(partition_manager)
...@@ -71,7 +76,7 @@ RSpec.describe Gitlab::Database::Partitioning do ...@@ -71,7 +76,7 @@ RSpec.describe Gitlab::Database::Partitioning do
end end
expect(Gitlab::Database::EachDatabase).to receive(:each_model_connection) expect(Gitlab::Database::EachDatabase).to receive(:each_model_connection)
.with(described_class.registered_models) .with(described_class.__send__(:registered_models))
.and_yield(model1) .and_yield(model1)
.and_yield(model2) .and_yield(model2)
...@@ -123,7 +128,7 @@ RSpec.describe Gitlab::Database::Partitioning do ...@@ -123,7 +128,7 @@ RSpec.describe Gitlab::Database::Partitioning do
context 'ensure that the registered models have partitioning strategy' do context 'ensure that the registered models have partitioning strategy' do
it 'fails when partitioning_strategy is not specified for the model' do it 'fails when partitioning_strategy is not specified for the model' do
expect(described_class.registered_models).to all(respond_to(:partitioning_strategy)) expect(described_class.__send__(:registered_models)).to all(respond_to(:partitioning_strategy))
end end
end end
end end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment