From 712cd925e666f5b2eac6bc26087c59eedb3973d7 Mon Sep 17 00:00:00 2001 From: Danil Date: Fri, 7 Jun 2024 15:40:36 +0400 Subject: [PATCH 1/4] fix(config): Split object stores Signed-off-by: Danil --- core/bin/zksync_server/src/main.rs | 3 +- core/bin/zksync_server/src/node_builder.rs | 2 +- core/lib/config/src/configs/fri_prover.rs | 4 +- core/lib/config/src/testonly.rs | 4 +- core/lib/env_config/src/fri_prover.rs | 42 +++++- .../src/proto/config/prover.proto | 134 +++++++++--------- core/lib/protobuf_config/src/prover.rs | 20 ++- core/lib/zksync_core_leftovers/src/lib.rs | 4 +- .../src/temp_config_store/mod.rs | 3 +- prover/prover_fri_gateway/src/main.rs | 2 +- prover/witness_generator/src/main.rs | 2 +- 11 files changed, 134 insertions(+), 86 deletions(-) diff --git a/core/bin/zksync_server/src/main.rs b/core/bin/zksync_server/src/main.rs index f1eedd592386..cb50a1c47527 100644 --- a/core/bin/zksync_server/src/main.rs +++ b/core/bin/zksync_server/src/main.rs @@ -17,7 +17,7 @@ use zksync_config::{ ProtectiveReadsWriterConfig, Secrets, }, ApiConfig, ContractVerifierConfig, DBConfig, EthConfig, EthWatchConfig, GasAdjusterConfig, - GenesisConfig, ObjectStoreConfig, PostgresConfig, SnapshotsCreatorConfig, + GenesisConfig, PostgresConfig, SnapshotsCreatorConfig, }; use zksync_core_leftovers::{ genesis_init, initialize_components, is_genesis_needed, setup_sigint_handler, @@ -304,7 +304,6 @@ fn load_env_config() -> anyhow::Result { eth_sender_config: EthConfig::from_env().ok(), eth_watch_config: EthWatchConfig::from_env().ok(), gas_adjuster_config: GasAdjusterConfig::from_env().ok(), - object_store_config: ObjectStoreConfig::from_env().ok(), observability: ObservabilityConfig::from_env().ok(), snapshot_creator: SnapshotsCreatorConfig::from_env().ok(), protective_reads_writer_config: ProtectiveReadsWriterConfig::from_env().ok(), diff --git a/core/bin/zksync_server/src/node_builder.rs b/core/bin/zksync_server/src/node_builder.rs index d67b898c95ca..e283549e14f8 100644 --- a/core/bin/zksync_server/src/node_builder.rs +++ b/core/bin/zksync_server/src/node_builder.rs @@ -150,7 +150,7 @@ impl MainNodeBuilder { fn add_object_store_layer(mut self) -> anyhow::Result { let object_store_config = try_load_config!(self.configs.prover_config) - .object_store + .core_object_store .context("object_store_config")?; self.node .add_layer(ObjectStoreLayer::new(object_store_config)); diff --git a/core/lib/config/src/configs/fri_prover.rs b/core/lib/config/src/configs/fri_prover.rs index b19d72e40b8d..2aa9a7fc89f3 100644 --- a/core/lib/config/src/configs/fri_prover.rs +++ b/core/lib/config/src/configs/fri_prover.rs @@ -26,7 +26,9 @@ pub struct FriProverConfig { // whether to write to public GCS bucket for https://github.com/matter-labs/era-boojum-validator-cli pub shall_save_to_public_bucket: bool, - pub object_store: Option, + pub core_object_store: Option, + pub prover_object_store: Option, + pub public_object_store: Option, } impl FriProverConfig { diff --git a/core/lib/config/src/testonly.rs b/core/lib/config/src/testonly.rs index aba67acab484..458ed3390940 100644 --- a/core/lib/config/src/testonly.rs +++ b/core/lib/config/src/testonly.rs @@ -442,7 +442,9 @@ impl Distribution for EncodeDist { zone_read_url: self.sample(rng), shall_save_to_public_bucket: self.sample(rng), availability_check_interval_in_secs: self.sample(rng), - object_store: self.sample(rng), + core_object_store: self.sample(rng), + prover_object_store: self.sample(rng), + public_object_store: self.sample(rng), } } } diff --git a/core/lib/env_config/src/fri_prover.rs b/core/lib/env_config/src/fri_prover.rs index 413004024963..f51bcd27d254 100644 --- a/core/lib/env_config/src/fri_prover.rs +++ b/core/lib/env_config/src/fri_prover.rs @@ -1,11 +1,17 @@ -use zksync_config::configs::FriProverConfig; +use zksync_config::{configs::FriProverConfig, ObjectStoreConfig}; -use crate::{envy_load, object_store::ProverObjectStoreConfig, FromEnv}; +use crate::{ + envy_load, + object_store::{ProverObjectStoreConfig, PublicObjectStoreConfig}, + FromEnv, +}; impl FromEnv for FriProverConfig { fn from_env() -> anyhow::Result { let mut prover: FriProverConfig = envy_load("fri_prover", "FRI_PROVER_")?; - prover.object_store = ProverObjectStoreConfig::from_env().map(|a| a.0).ok(); + prover.prover_object_store = ProverObjectStoreConfig::from_env().map(|a| a.0).ok(); + prover.public_object_store = PublicObjectStoreConfig::from_env().map(|a| a.0).ok(); + prover.core_object_store = ObjectStoreConfig::from_env().ok(); Ok(prover) } } @@ -35,10 +41,26 @@ mod tests { zone_read_url: "http://metadata.google.internal/computeMetadata/v1/instance/zone" .to_string(), shall_save_to_public_bucket: true, - object_store: Some(ObjectStoreConfig { + prover_object_store: Some(ObjectStoreConfig { mode: ObjectStoreMode::GCSWithCredentialFile { bucket_base_url: "/base/url".to_owned(), - gcs_credential_file_path: "/path/to/credentials.json".to_owned(), + gcs_credential_file_path: "/path/to/credentials1.json".to_owned(), + }, + max_retries: 5, + local_mirror_path: None, + }), + public_object_store: Some(ObjectStoreConfig { + mode: ObjectStoreMode::GCSWithCredentialFile { + bucket_base_url: "/base/url".to_owned(), + gcs_credential_file_path: "/path/to/credentials2.json".to_owned(), + }, + max_retries: 5, + local_mirror_path: None, + }), + core_object_store: Some(ObjectStoreConfig { + mode: ObjectStoreMode::GCSWithCredentialFile { + bucket_base_url: "/base/url".to_owned(), + gcs_credential_file_path: "/path/to/credentials3.json".to_owned(), }, max_retries: 5, local_mirror_path: None, @@ -64,8 +86,16 @@ mod tests { FRI_PROVER_AVAILABILITY_CHECK_INTERVAL_IN_SECS="1800" PROVER_OBJECT_STORE_BUCKET_BASE_URL="/base/url" PROVER_OBJECT_STORE_MODE="GCSWithCredentialFile" - PROVER_OBJECT_STORE_GCS_CREDENTIAL_FILE_PATH="/path/to/credentials.json" + PROVER_OBJECT_STORE_GCS_CREDENTIAL_FILE_PATH="/path/to/credentials1.json" PROVER_OBJECT_STORE_MAX_RETRIES="5" + OBJECT_STORE_BUCKET_BASE_URL="/base/url" + OBJECT_STORE_MODE="GCSWithCredentialFile" + OBJECT_STORE_GCS_CREDENTIAL_FILE_PATH="/path/to/credentials3.json" + OBJECT_STORE_MAX_RETRIES="5" + PUBLIC_OBJECT_STORE_BUCKET_BASE_URL="/base/url" + PUBLIC_OBJECT_STORE_MODE="GCSWithCredentialFile" + PUBLIC_OBJECT_STORE_GCS_CREDENTIAL_FILE_PATH="/path/to/credentials2.json" + PUBLIC_OBJECT_STORE_MAX_RETRIES="5" "#; lock.set_env(config); diff --git a/core/lib/protobuf_config/src/proto/config/prover.proto b/core/lib/protobuf_config/src/proto/config/prover.proto index 87c30ef0001d..a648dec78d31 100644 --- a/core/lib/protobuf_config/src/proto/config/prover.proto +++ b/core/lib/protobuf_config/src/proto/config/prover.proto @@ -5,97 +5,99 @@ import "zksync/config/object_store.proto"; package zksync.config.prover; message ProofCompressor { - optional uint32 compression_mode = 1; // required; u8 - optional uint32 prometheus_listener_port = 2; // required; u16 - optional string prometheus_pushgateway_url = 3; // required - optional uint64 prometheus_push_interval_ms = 4; // optional; ms - optional uint32 generation_timeout_in_secs = 5; // required; s - optional uint32 max_attempts = 6; // required - optional string universal_setup_path = 7; // required; fs path - optional string universal_setup_download_url = 8; // required - optional bool verify_wrapper_proof = 9; // required + optional uint32 compression_mode = 1; // required; u8 + optional uint32 prometheus_listener_port = 2; // required; u16 + optional string prometheus_pushgateway_url = 3; // required + optional uint64 prometheus_push_interval_ms = 4; // optional; ms + optional uint32 generation_timeout_in_secs = 5; // required; s + optional uint32 max_attempts = 6; // required + optional string universal_setup_path = 7; // required; fs path + optional string universal_setup_download_url = 8; // required + optional bool verify_wrapper_proof = 9; // required } enum SetupLoadMode { - FROM_DISK = 0; - FROM_MEMORY = 1; + FROM_DISK = 0; + FROM_MEMORY = 1; } message Prover { - optional string setup_data_path = 1; // required; fs path? - optional uint32 prometheus_port = 2; // required; u16 - optional uint32 max_attempts = 3; // required - optional uint32 generation_timeout_in_secs = 4; // required; s - optional SetupLoadMode setup_load_mode = 7; // required - optional uint32 specialized_group_id = 8; // required; u8 - optional uint64 queue_capacity = 10; // required - optional uint32 witness_vector_receiver_port = 11; // required; u16 - optional string zone_read_url = 12; // required - optional uint32 availability_check_interval_in_secs = 21; // optional; s - optional bool shall_save_to_public_bucket = 13; // required - optional config.object_store.ObjectStore object_store = 20; - reserved 5, 6, 9; reserved "base_layer_circuit_ids_to_be_verified", "recursive_layer_circuit_ids_to_be_verified", "witness_vector_generator_thread_count"; + optional string setup_data_path = 1; // required; fs path? + optional uint32 prometheus_port = 2; // required; u16 + optional uint32 max_attempts = 3; // required + optional uint32 generation_timeout_in_secs = 4; // required; s + optional SetupLoadMode setup_load_mode = 7; // required + optional uint32 specialized_group_id = 8; // required; u8 + optional uint64 queue_capacity = 10; // required + optional uint32 witness_vector_receiver_port = 11; // required; u16 + optional string zone_read_url = 12; // required + optional uint32 availability_check_interval_in_secs = 21; // optional; s + optional bool shall_save_to_public_bucket = 13; // required + optional config.object_store.ObjectStore object_store = 20; + optional config.object_store.ObjectStore public_object_store = 22; + optional config.object_store.ObjectStore prover_object_store = 23; + reserved 5, 6, 9; reserved "base_layer_circuit_ids_to_be_verified", "recursive_layer_circuit_ids_to_be_verified", "witness_vector_generator_thread_count"; } message CircuitIdRoundTuple { - optional uint32 circuit_id = 1; // required; u8 - optional uint32 aggregation_round = 2; // required; u8 + optional uint32 circuit_id = 1; // required; u8 + optional uint32 aggregation_round = 2; // required; u8 } message ProverGroup { - repeated CircuitIdRoundTuple group_0 = 1; - repeated CircuitIdRoundTuple group_1 = 2; - repeated CircuitIdRoundTuple group_2 = 3; - repeated CircuitIdRoundTuple group_3 = 4; - repeated CircuitIdRoundTuple group_4 = 5; - repeated CircuitIdRoundTuple group_5 = 6; - repeated CircuitIdRoundTuple group_6 = 7; - repeated CircuitIdRoundTuple group_7 = 8; - repeated CircuitIdRoundTuple group_8 = 9; - repeated CircuitIdRoundTuple group_9 = 10; - repeated CircuitIdRoundTuple group_10 = 11; - repeated CircuitIdRoundTuple group_11 = 12; - repeated CircuitIdRoundTuple group_12 = 13; - repeated CircuitIdRoundTuple group_13 = 14; - repeated CircuitIdRoundTuple group_14 = 15; + repeated CircuitIdRoundTuple group_0 = 1; + repeated CircuitIdRoundTuple group_1 = 2; + repeated CircuitIdRoundTuple group_2 = 3; + repeated CircuitIdRoundTuple group_3 = 4; + repeated CircuitIdRoundTuple group_4 = 5; + repeated CircuitIdRoundTuple group_5 = 6; + repeated CircuitIdRoundTuple group_6 = 7; + repeated CircuitIdRoundTuple group_7 = 8; + repeated CircuitIdRoundTuple group_8 = 9; + repeated CircuitIdRoundTuple group_9 = 10; + repeated CircuitIdRoundTuple group_10 = 11; + repeated CircuitIdRoundTuple group_11 = 12; + repeated CircuitIdRoundTuple group_12 = 13; + repeated CircuitIdRoundTuple group_13 = 14; + repeated CircuitIdRoundTuple group_14 = 15; } message ProverGateway { - optional string api_url = 1; // required - optional uint32 api_poll_duration_secs = 2; // required; s - optional uint32 prometheus_listener_port = 3; // required; u16 - optional string prometheus_pushgateway_url = 4; // required - optional uint64 prometheus_push_interval_ms = 5; // optional; ms + optional string api_url = 1; // required + optional uint32 api_poll_duration_secs = 2; // required; s + optional uint32 prometheus_listener_port = 3; // required; u16 + optional string prometheus_pushgateway_url = 4; // required + optional uint64 prometheus_push_interval_ms = 5; // optional; ms } message WitnessGenerator { - optional uint32 generation_timeout_in_secs = 1; // required; - optional uint32 max_attempts = 2; // required; - optional uint32 last_l1_batch_to_process = 5; // optional - optional bool shall_save_to_public_bucket = 7; // required - optional uint32 basic_generation_timeout_in_secs = 8; // optional; - optional uint32 leaf_generation_timeout_in_secs = 9; // optional; - optional uint32 node_generation_timeout_in_secs = 10; // optional; - optional uint32 scheduler_generation_timeout_in_secs = 11; // optional; - optional uint32 recursion_tip_timeout_in_secs = 12; // optional; - reserved 3, 4, 6; - reserved "dump_arguments_for_blocks", "force_process_block", "blocks_proving_percentage"; + optional uint32 generation_timeout_in_secs = 1; // required; + optional uint32 max_attempts = 2; // required; + optional uint32 last_l1_batch_to_process = 5; // optional + optional bool shall_save_to_public_bucket = 7; // required + optional uint32 basic_generation_timeout_in_secs = 8; // optional; + optional uint32 leaf_generation_timeout_in_secs = 9; // optional; + optional uint32 node_generation_timeout_in_secs = 10; // optional; + optional uint32 scheduler_generation_timeout_in_secs = 11; // optional; + optional uint32 recursion_tip_timeout_in_secs = 12; // optional; + reserved 3, 4, 6; + reserved "dump_arguments_for_blocks", "force_process_block", "blocks_proving_percentage"; } message WitnessVectorGenerator { - optional uint32 max_prover_reservation_duration_in_secs = 1; // required; s - optional uint32 prover_instance_wait_timeout_in_secs = 2; // required; s - optional uint32 prover_instance_poll_time_in_milli_secs = 3; // required; ms - optional uint32 prometheus_listener_port = 4; // required; u16 - optional string prometheus_pushgateway_url = 5; // required - optional uint64 prometheus_push_interval_ms = 6; // optional; ms - optional uint32 specialized_group_id = 7; // required; u8 + optional uint32 max_prover_reservation_duration_in_secs = 1; // required; s + optional uint32 prover_instance_wait_timeout_in_secs = 2; // required; s + optional uint32 prover_instance_poll_time_in_milli_secs = 3; // required; ms + optional uint32 prometheus_listener_port = 4; // required; u16 + optional string prometheus_pushgateway_url = 5; // required + optional uint64 prometheus_push_interval_ms = 6; // optional; ms + optional uint32 specialized_group_id = 7; // required; u8 } message ProofDataHandler { - optional uint32 http_port = 1; // required; u16 - optional uint32 proof_generation_timeout_in_secs = 2; // required; s + optional uint32 http_port = 1; // required; u16 + optional uint32 proof_generation_timeout_in_secs = 2; // required; s } diff --git a/core/lib/protobuf_config/src/prover.rs b/core/lib/protobuf_config/src/prover.rs index b956749a596a..b917a4a6c89c 100644 --- a/core/lib/protobuf_config/src/prover.rs +++ b/core/lib/protobuf_config/src/prover.rs @@ -289,7 +289,17 @@ impl proto::SetupLoadMode { impl ProtoRepr for proto::Prover { type Type = configs::FriProverConfig; fn read(&self) -> anyhow::Result { - let object_store = if let Some(object_store) = &self.object_store { + let core_object_store = if let Some(object_store) = &self.object_store { + Some(object_store.read()?) + } else { + None + }; + let public_object_store = if let Some(object_store) = &self.public_object_store { + Some(object_store.read()?) + } else { + None + }; + let prover_object_store = if let Some(object_store) = &self.prover_object_store { Some(object_store.read()?) } else { None @@ -325,7 +335,9 @@ impl ProtoRepr for proto::Prover { availability_check_interval_in_secs: self.availability_check_interval_in_secs, shall_save_to_public_bucket: *required(&self.shall_save_to_public_bucket) .context("shall_save_to_public_bucket")?, - object_store, + core_object_store, + public_object_store, + prover_object_store, }) } @@ -342,7 +354,9 @@ impl ProtoRepr for proto::Prover { zone_read_url: Some(this.zone_read_url.clone()), availability_check_interval_in_secs: this.availability_check_interval_in_secs, shall_save_to_public_bucket: Some(this.shall_save_to_public_bucket), - object_store: this.object_store.as_ref().map(ProtoRepr::build), + object_store: this.core_object_store.as_ref().map(ProtoRepr::build), + prover_object_store: this.prover_object_store.as_ref().map(ProtoRepr::build), + public_object_store: this.public_object_store.as_ref().map(ProtoRepr::build), } } } diff --git a/core/lib/zksync_core_leftovers/src/lib.rs b/core/lib/zksync_core_leftovers/src/lib.rs index d2012de83126..409117fb6b12 100644 --- a/core/lib/zksync_core_leftovers/src/lib.rs +++ b/core/lib/zksync_core_leftovers/src/lib.rs @@ -475,9 +475,9 @@ pub async fn initialize_components( .prover_config .clone() .context("Prover")? - .object_store + .core_object_store .clone() - .context("object_store_config")?; + .context("core_object_store_config")?; let store_factory = ObjectStoreFactory::new(object_store_config); if components.contains(&Component::StateKeeper) { diff --git a/core/lib/zksync_core_leftovers/src/temp_config_store/mod.rs b/core/lib/zksync_core_leftovers/src/temp_config_store/mod.rs index 0da3cfd548f3..65c7148d2747 100644 --- a/core/lib/zksync_core_leftovers/src/temp_config_store/mod.rs +++ b/core/lib/zksync_core_leftovers/src/temp_config_store/mod.rs @@ -13,7 +13,7 @@ use zksync_config::{ ObservabilityConfig, PrometheusConfig, ProofDataHandlerConfig, ProtectiveReadsWriterConfig, }, ApiConfig, ContractVerifierConfig, DBConfig, EthConfig, EthWatchConfig, GasAdjusterConfig, - ObjectStoreConfig, PostgresConfig, SnapshotsCreatorConfig, + PostgresConfig, SnapshotsCreatorConfig, }; use zksync_protobuf::{repr::ProtoRepr, ProtoFmt}; @@ -58,7 +58,6 @@ pub struct TempConfigStore { pub eth_sender_config: Option, pub eth_watch_config: Option, pub gas_adjuster_config: Option, - pub object_store_config: Option, pub observability: Option, pub snapshot_creator: Option, pub protective_reads_writer_config: Option, diff --git a/prover/prover_fri_gateway/src/main.rs b/prover/prover_fri_gateway/src/main.rs index 0d083f79a612..f7e7af763afb 100644 --- a/prover/prover_fri_gateway/src/main.rs +++ b/prover/prover_fri_gateway/src/main.rs @@ -60,7 +60,7 @@ async fn main() -> anyhow::Result<()> { general_config .prover_config .context("prover config")? - .object_store + .prover_object_store .context("object store")?, ); let store_factory = ObjectStoreFactory::new(object_store_config.0); diff --git a/prover/witness_generator/src/main.rs b/prover/witness_generator/src/main.rs index 9116042c79a5..6a4cc4fc33eb 100644 --- a/prover/witness_generator/src/main.rs +++ b/prover/witness_generator/src/main.rs @@ -115,7 +115,7 @@ async fn main() -> anyhow::Result<()> { general_config .prover_config .context("prover config")? - .object_store + .prover_object_store .context("object store")?, ); let store_factory = ObjectStoreFactory::new(object_store_config.0); From c4b27d24600813092674d388feff6bbc692130f0 Mon Sep 17 00:00:00 2001 From: Danil Date: Fri, 7 Jun 2024 15:40:36 +0400 Subject: [PATCH 2/4] fix(config): Split object stores Signed-off-by: Danil --- prover/config/src/lib.rs | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/prover/config/src/lib.rs b/prover/config/src/lib.rs index 8614f1677bda..b21cb1c4be41 100644 --- a/prover/config/src/lib.rs +++ b/prover/config/src/lib.rs @@ -13,7 +13,7 @@ use zksync_config::{ ObservabilityConfig, PrometheusConfig, ProofDataHandlerConfig, ProtectiveReadsWriterConfig, }, ApiConfig, ContractVerifierConfig, DBConfig, EthConfig, EthWatchConfig, GasAdjusterConfig, - ObjectStoreConfig, PostgresConfig, SnapshotsCreatorConfig, + PostgresConfig, SnapshotsCreatorConfig, }; use zksync_core_leftovers::temp_config_store::{decode_yaml_repr, TempConfigStore}; use zksync_env_config::FromEnv; @@ -45,7 +45,6 @@ fn load_env_config() -> anyhow::Result { eth_sender_config: EthConfig::from_env().ok(), eth_watch_config: EthWatchConfig::from_env().ok(), gas_adjuster_config: GasAdjusterConfig::from_env().ok(), - object_store_config: ObjectStoreConfig::from_env().ok(), observability: ObservabilityConfig::from_env().ok(), snapshot_creator: SnapshotsCreatorConfig::from_env().ok(), protective_reads_writer_config: ProtectiveReadsWriterConfig::from_env().ok(), From db52bf355bc9471ec3f92a645f18993b337fb2df Mon Sep 17 00:00:00 2001 From: Danil Date: Fri, 7 Jun 2024 16:24:40 +0400 Subject: [PATCH 3/4] Move object store Signed-off-by: Danil --- core/bin/zksync_server/src/main.rs | 3 ++- core/bin/zksync_server/src/node_builder.rs | 4 +--- core/lib/config/src/configs/fri_prover.rs | 1 - core/lib/config/src/configs/general.rs | 4 +++- core/lib/config/src/testonly.rs | 1 - core/lib/env_config/src/fri_prover.rs | 15 +-------------- core/lib/protobuf_config/src/general.rs | 5 ++++- .../src/proto/config/general.proto | 2 ++ .../protobuf_config/src/proto/config/prover.proto | 1 - core/lib/protobuf_config/src/prover.rs | 7 ------- core/lib/zksync_core_leftovers/src/lib.rs | 3 --- .../src/temp_config_store/mod.rs | 4 +++- prover/config/src/lib.rs | 4 +++- 13 files changed, 19 insertions(+), 35 deletions(-) diff --git a/core/bin/zksync_server/src/main.rs b/core/bin/zksync_server/src/main.rs index cb50a1c47527..c51cc5380253 100644 --- a/core/bin/zksync_server/src/main.rs +++ b/core/bin/zksync_server/src/main.rs @@ -17,7 +17,7 @@ use zksync_config::{ ProtectiveReadsWriterConfig, Secrets, }, ApiConfig, ContractVerifierConfig, DBConfig, EthConfig, EthWatchConfig, GasAdjusterConfig, - GenesisConfig, PostgresConfig, SnapshotsCreatorConfig, + GenesisConfig, ObjectStoreConfig, PostgresConfig, SnapshotsCreatorConfig, }; use zksync_core_leftovers::{ genesis_init, initialize_components, is_genesis_needed, setup_sigint_handler, @@ -307,5 +307,6 @@ fn load_env_config() -> anyhow::Result { observability: ObservabilityConfig::from_env().ok(), snapshot_creator: SnapshotsCreatorConfig::from_env().ok(), protective_reads_writer_config: ProtectiveReadsWriterConfig::from_env().ok(), + core_object_store: ObjectStoreConfig::from_env().ok(), }) } diff --git a/core/bin/zksync_server/src/node_builder.rs b/core/bin/zksync_server/src/node_builder.rs index e283549e14f8..904e260dcbd4 100644 --- a/core/bin/zksync_server/src/node_builder.rs +++ b/core/bin/zksync_server/src/node_builder.rs @@ -149,9 +149,7 @@ impl MainNodeBuilder { } fn add_object_store_layer(mut self) -> anyhow::Result { - let object_store_config = try_load_config!(self.configs.prover_config) - .core_object_store - .context("object_store_config")?; + let object_store_config = try_load_config!(self.configs.core_object_store); self.node .add_layer(ObjectStoreLayer::new(object_store_config)); Ok(self) diff --git a/core/lib/config/src/configs/fri_prover.rs b/core/lib/config/src/configs/fri_prover.rs index 2aa9a7fc89f3..99e3d354536e 100644 --- a/core/lib/config/src/configs/fri_prover.rs +++ b/core/lib/config/src/configs/fri_prover.rs @@ -26,7 +26,6 @@ pub struct FriProverConfig { // whether to write to public GCS bucket for https://github.com/matter-labs/era-boojum-validator-cli pub shall_save_to_public_bucket: bool, - pub core_object_store: Option, pub prover_object_store: Option, pub public_object_store: Option, } diff --git a/core/lib/config/src/configs/general.rs b/core/lib/config/src/configs/general.rs index ef02f557bc18..9f249d655f57 100644 --- a/core/lib/config/src/configs/general.rs +++ b/core/lib/config/src/configs/general.rs @@ -8,7 +8,8 @@ use crate::{ FriWitnessGeneratorConfig, FriWitnessVectorGeneratorConfig, ObservabilityConfig, PrometheusConfig, ProofDataHandlerConfig, }, - ApiConfig, ContractVerifierConfig, DBConfig, EthConfig, PostgresConfig, SnapshotsCreatorConfig, + ApiConfig, ContractVerifierConfig, DBConfig, EthConfig, ObjectStoreConfig, PostgresConfig, + SnapshotsCreatorConfig, }; #[derive(Debug)] @@ -34,4 +35,5 @@ pub struct GeneralConfig { pub snapshot_creator: Option, pub observability: Option, pub protective_reads_writer_config: Option, + pub core_object_store: Option, } diff --git a/core/lib/config/src/testonly.rs b/core/lib/config/src/testonly.rs index 458ed3390940..87c3bd2a1294 100644 --- a/core/lib/config/src/testonly.rs +++ b/core/lib/config/src/testonly.rs @@ -442,7 +442,6 @@ impl Distribution for EncodeDist { zone_read_url: self.sample(rng), shall_save_to_public_bucket: self.sample(rng), availability_check_interval_in_secs: self.sample(rng), - core_object_store: self.sample(rng), prover_object_store: self.sample(rng), public_object_store: self.sample(rng), } diff --git a/core/lib/env_config/src/fri_prover.rs b/core/lib/env_config/src/fri_prover.rs index f51bcd27d254..96069d6514ea 100644 --- a/core/lib/env_config/src/fri_prover.rs +++ b/core/lib/env_config/src/fri_prover.rs @@ -1,4 +1,4 @@ -use zksync_config::{configs::FriProverConfig, ObjectStoreConfig}; +use zksync_config::configs::FriProverConfig; use crate::{ envy_load, @@ -11,7 +11,6 @@ impl FromEnv for FriProverConfig { let mut prover: FriProverConfig = envy_load("fri_prover", "FRI_PROVER_")?; prover.prover_object_store = ProverObjectStoreConfig::from_env().map(|a| a.0).ok(); prover.public_object_store = PublicObjectStoreConfig::from_env().map(|a| a.0).ok(); - prover.core_object_store = ObjectStoreConfig::from_env().ok(); Ok(prover) } } @@ -57,14 +56,6 @@ mod tests { max_retries: 5, local_mirror_path: None, }), - core_object_store: Some(ObjectStoreConfig { - mode: ObjectStoreMode::GCSWithCredentialFile { - bucket_base_url: "/base/url".to_owned(), - gcs_credential_file_path: "/path/to/credentials3.json".to_owned(), - }, - max_retries: 5, - local_mirror_path: None, - }), availability_check_interval_in_secs: Some(1_800), } } @@ -88,10 +79,6 @@ mod tests { PROVER_OBJECT_STORE_MODE="GCSWithCredentialFile" PROVER_OBJECT_STORE_GCS_CREDENTIAL_FILE_PATH="/path/to/credentials1.json" PROVER_OBJECT_STORE_MAX_RETRIES="5" - OBJECT_STORE_BUCKET_BASE_URL="/base/url" - OBJECT_STORE_MODE="GCSWithCredentialFile" - OBJECT_STORE_GCS_CREDENTIAL_FILE_PATH="/path/to/credentials3.json" - OBJECT_STORE_MAX_RETRIES="5" PUBLIC_OBJECT_STORE_BUCKET_BASE_URL="/base/url" PUBLIC_OBJECT_STORE_MODE="GCSWithCredentialFile" PUBLIC_OBJECT_STORE_GCS_CREDENTIAL_FILE_PATH="/path/to/credentials2.json" diff --git a/core/lib/protobuf_config/src/general.rs b/core/lib/protobuf_config/src/general.rs index ba2076a09a14..834977759ae2 100644 --- a/core/lib/protobuf_config/src/general.rs +++ b/core/lib/protobuf_config/src/general.rs @@ -38,7 +38,9 @@ impl ProtoRepr for proto::GeneralConfig { .context("snapshot_creator")?, observability: read_optional_repr(&self.observability).context("observability")?, protective_reads_writer_config: read_optional_repr(&self.protective_reads_writer) - .context("vm_runner")?, + .context("protective_reads_writer")?, + core_object_store: read_optional_repr(&self.core_object_store) + .context("core_object_store")?, }) } @@ -74,6 +76,7 @@ impl ProtoRepr for proto::GeneralConfig { .protective_reads_writer_config .as_ref() .map(ProtoRepr::build), + core_object_store: this.core_object_store.as_ref().map(ProtoRepr::build), } } } diff --git a/core/lib/protobuf_config/src/proto/config/general.proto b/core/lib/protobuf_config/src/proto/config/general.proto index b606417d129a..fdfe257aecf1 100644 --- a/core/lib/protobuf_config/src/proto/config/general.proto +++ b/core/lib/protobuf_config/src/proto/config/general.proto @@ -14,6 +14,7 @@ import "zksync/config/observability.proto"; import "zksync/config/snapshots_creator.proto"; import "zksync/config/utils.proto"; import "zksync/config/vm_runner.proto"; +import "zksync/config/object_store.proto"; message GeneralConfig { optional config.database.Postgres postgres = 1; @@ -37,4 +38,5 @@ message GeneralConfig { optional config.snapshot_creator.SnapshotsCreator snapshot_creator = 31; optional config.observability.Observability observability = 32; optional config.vm_runner.ProtectiveReadsWriter protective_reads_writer = 33; + optional config.object_store.ObjectStore core_object_store = 34; } diff --git a/core/lib/protobuf_config/src/proto/config/prover.proto b/core/lib/protobuf_config/src/proto/config/prover.proto index a648dec78d31..d5d131fc157b 100644 --- a/core/lib/protobuf_config/src/proto/config/prover.proto +++ b/core/lib/protobuf_config/src/proto/config/prover.proto @@ -33,7 +33,6 @@ message Prover { optional string zone_read_url = 12; // required optional uint32 availability_check_interval_in_secs = 21; // optional; s optional bool shall_save_to_public_bucket = 13; // required - optional config.object_store.ObjectStore object_store = 20; optional config.object_store.ObjectStore public_object_store = 22; optional config.object_store.ObjectStore prover_object_store = 23; reserved 5, 6, 9; reserved "base_layer_circuit_ids_to_be_verified", "recursive_layer_circuit_ids_to_be_verified", "witness_vector_generator_thread_count"; diff --git a/core/lib/protobuf_config/src/prover.rs b/core/lib/protobuf_config/src/prover.rs index b917a4a6c89c..9a41e433433c 100644 --- a/core/lib/protobuf_config/src/prover.rs +++ b/core/lib/protobuf_config/src/prover.rs @@ -289,11 +289,6 @@ impl proto::SetupLoadMode { impl ProtoRepr for proto::Prover { type Type = configs::FriProverConfig; fn read(&self) -> anyhow::Result { - let core_object_store = if let Some(object_store) = &self.object_store { - Some(object_store.read()?) - } else { - None - }; let public_object_store = if let Some(object_store) = &self.public_object_store { Some(object_store.read()?) } else { @@ -335,7 +330,6 @@ impl ProtoRepr for proto::Prover { availability_check_interval_in_secs: self.availability_check_interval_in_secs, shall_save_to_public_bucket: *required(&self.shall_save_to_public_bucket) .context("shall_save_to_public_bucket")?, - core_object_store, public_object_store, prover_object_store, }) @@ -354,7 +348,6 @@ impl ProtoRepr for proto::Prover { zone_read_url: Some(this.zone_read_url.clone()), availability_check_interval_in_secs: this.availability_check_interval_in_secs, shall_save_to_public_bucket: Some(this.shall_save_to_public_bucket), - object_store: this.core_object_store.as_ref().map(ProtoRepr::build), prover_object_store: this.prover_object_store.as_ref().map(ProtoRepr::build), public_object_store: this.public_object_store.as_ref().map(ProtoRepr::build), } diff --git a/core/lib/zksync_core_leftovers/src/lib.rs b/core/lib/zksync_core_leftovers/src/lib.rs index 409117fb6b12..649a859cfd78 100644 --- a/core/lib/zksync_core_leftovers/src/lib.rs +++ b/core/lib/zksync_core_leftovers/src/lib.rs @@ -472,9 +472,6 @@ pub async fn initialize_components( } let object_store_config = configs - .prover_config - .clone() - .context("Prover")? .core_object_store .clone() .context("core_object_store_config")?; diff --git a/core/lib/zksync_core_leftovers/src/temp_config_store/mod.rs b/core/lib/zksync_core_leftovers/src/temp_config_store/mod.rs index 65c7148d2747..1f4c410ed9c1 100644 --- a/core/lib/zksync_core_leftovers/src/temp_config_store/mod.rs +++ b/core/lib/zksync_core_leftovers/src/temp_config_store/mod.rs @@ -13,7 +13,7 @@ use zksync_config::{ ObservabilityConfig, PrometheusConfig, ProofDataHandlerConfig, ProtectiveReadsWriterConfig, }, ApiConfig, ContractVerifierConfig, DBConfig, EthConfig, EthWatchConfig, GasAdjusterConfig, - PostgresConfig, SnapshotsCreatorConfig, + ObjectStoreConfig, PostgresConfig, SnapshotsCreatorConfig, }; use zksync_protobuf::{repr::ProtoRepr, ProtoFmt}; @@ -61,6 +61,7 @@ pub struct TempConfigStore { pub observability: Option, pub snapshot_creator: Option, pub protective_reads_writer_config: Option, + pub core_object_store: Option, } impl TempConfigStore { @@ -87,6 +88,7 @@ impl TempConfigStore { snapshot_creator: self.snapshot_creator.clone(), observability: self.observability.clone(), protective_reads_writer_config: self.protective_reads_writer_config.clone(), + core_object_store: self.core_object_store.clone(), } } diff --git a/prover/config/src/lib.rs b/prover/config/src/lib.rs index b21cb1c4be41..f501dd2d6e06 100644 --- a/prover/config/src/lib.rs +++ b/prover/config/src/lib.rs @@ -10,7 +10,8 @@ use zksync_config::{ house_keeper::HouseKeeperConfig, DatabaseSecrets, FriProofCompressorConfig, FriProverConfig, FriProverGatewayConfig, FriWitnessGeneratorConfig, FriWitnessVectorGeneratorConfig, GeneralConfig, - ObservabilityConfig, PrometheusConfig, ProofDataHandlerConfig, ProtectiveReadsWriterConfig, + ObjectStoreConfig, ObservabilityConfig, PrometheusConfig, ProofDataHandlerConfig, + ProtectiveReadsWriterConfig, }, ApiConfig, ContractVerifierConfig, DBConfig, EthConfig, EthWatchConfig, GasAdjusterConfig, PostgresConfig, SnapshotsCreatorConfig, @@ -48,6 +49,7 @@ fn load_env_config() -> anyhow::Result { observability: ObservabilityConfig::from_env().ok(), snapshot_creator: SnapshotsCreatorConfig::from_env().ok(), protective_reads_writer_config: ProtectiveReadsWriterConfig::from_env().ok(), + core_object_store: ObjectStoreConfig::from_env().ok(), }) } From 34a0f5e45817ecfaa37d10800aba7114c9a11491 Mon Sep 17 00:00:00 2001 From: Danil Date: Fri, 7 Jun 2024 17:07:59 +0400 Subject: [PATCH 4/4] Fix yaml Signed-off-by: Danil --- etc/env/file_based/general.yaml | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/etc/env/file_based/general.yaml b/etc/env/file_based/general.yaml index c6b9288a1f12..4145a04f292c 100644 --- a/etc/env/file_based/general.yaml +++ b/etc/env/file_based/general.yaml @@ -156,7 +156,11 @@ snapshot_creator: prover: - object_store: + prover_object_store: + file_backed: + file_backed_base_path: artifacts + max_retries: 10 + public_object_store: file_backed: file_backed_base_path: artifacts max_retries: 10