Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(Prover CLI): status l1 command #1706

Merged
merged 73 commits into from
May 8, 2024
Merged
Show file tree
Hide file tree
Changes from 23 commits
Commits
Show all changes
73 commits
Select commit Hold shift + click to select a range
17e564c
fmt
ColoCarletti Apr 8, 2024
245b0a4
wip
ColoCarletti Apr 8, 2024
8e84243
add cargo.toml cargo.lock
ColoCarletti Apr 8, 2024
17517b1
go back to anihow
ColoCarletti Apr 8, 2024
4ab7ce8
fmt
ColoCarletti Apr 8, 2024
4655201
rm tool workspace
ColoCarletti Apr 9, 2024
c32d1aa
fmt
ColoCarletti Apr 10, 2024
8e49e04
zk fmt
ColoCarletti Apr 10, 2024
80e13da
fix typo
ColoCarletti Apr 10, 2024
0f2ebd8
move query to prover_dal
ColoCarletti Apr 12, 2024
69d2104
remove --all flag
Apr 15, 2024
c9e6e5e
change command name
ColoCarletti Apr 16, 2024
83fab40
merge main
ColoCarletti Apr 16, 2024
cdbb467
fmt
ColoCarletti Apr 16, 2024
d1f3994
add sqlx query json
ColoCarletti Apr 16, 2024
4ee3ff2
Merge branch 'main' into prover_cli_status_command
ilitteri Apr 16, 2024
fff3910
update README
ColoCarletti Apr 16, 2024
ef906b9
zk fmt
ColoCarletti Apr 16, 2024
3758547
Merge branch 'prover_cli_status_command' of github.com:matter-labs/zk…
ColoCarletti Apr 16, 2024
b3051b2
remove eol
ColoCarletti Apr 16, 2024
0e4841c
command setup
ColoCarletti Apr 16, 2024
3d3d57d
add l1 contracts calls
ColoCarletti Apr 16, 2024
ee9d35b
Move jobs cmd to status cmd module
Apr 16, 2024
82faf32
Refactor status cmd
Apr 16, 2024
aa44864
Update Cargo.lock
Apr 16, 2024
3fe32b6
zk fmt
Apr 16, 2024
2a82aec
add state keeper querys
ColoCarletti Apr 16, 2024
d43dd15
Merge pull request #1705 from matter-labs/il-refactor-prover-cli-stat…
ilitteri Apr 17, 2024
70b0348
Merge branch 'main' into prover_cli_status_command
ilitteri Apr 17, 2024
fb1183e
add print
ColoCarletti Apr 17, 2024
e7c2326
small refactor
ColoCarletti Apr 17, 2024
585059b
Merge branch 'main' into prover_cli_status_command
ilitteri Apr 17, 2024
8aa01ca
add verification keys comparison
ColoCarletti Apr 17, 2024
9977e95
Refactor
Apr 18, 2024
74f6f8c
refactor contract calls
ColoCarletti Apr 18, 2024
ee88cfe
Merge branch 'main' into prover_cli_status_command
ilitteri Apr 18, 2024
0801d9e
add command name print
ColoCarletti Apr 18, 2024
14abe2d
fix print
ColoCarletti Apr 18, 2024
00fac77
rm unused import
ColoCarletti Apr 18, 2024
a29a9e8
fix print
ColoCarletti Apr 18, 2024
872edc2
merge branch prover_cli_status_command
ColoCarletti Apr 18, 2024
7cf62ff
fix status l1 command
ColoCarletti Apr 18, 2024
1e9c3ed
fix query
ColoCarletti Apr 18, 2024
b8b4582
add error handle
ColoCarletti Apr 18, 2024
e06a96f
change query return
ColoCarletti Apr 18, 2024
d2c0dc9
update README
ColoCarletti Apr 19, 2024
ad3445c
fix typos
ColoCarletti Apr 19, 2024
dba8ef1
fmt
ColoCarletti Apr 19, 2024
fabac61
zk spellcheck
ColoCarletti Apr 19, 2024
3999d59
remove batch cmd
ColoCarletti Apr 25, 2024
4348459
rm sqlx old query
ColoCarletti Apr 25, 2024
9039737
Merge branch 'main' into prover_cli_status_l1
ColoCarletti Apr 25, 2024
62ee2d3
Merge branch 'main' into prover_cli_status_l1
ilitteri Apr 30, 2024
720e69b
Merge branch 'main' into prover_cli_status_l1
ilitteri Apr 30, 2024
586161b
Merge branch 'main' of github.com:matter-labs/zksync-era into prover_…
ilitteri Apr 30, 2024
8605afe
zk lint rust
ilitteri Apr 30, 2024
66d232f
Fix import
ilitteri Apr 30, 2024
21c4741
fix README
ColoCarletti Apr 30, 2024
202e04e
Merge branch 'main' into prover_cli_status_l1
ilitteri May 2, 2024
bec81f3
Merge branch 'main' into prover_cli_status_l1
ilitteri May 2, 2024
03a843a
Merge branch 'main' into prover_cli_status_l1
ilitteri May 2, 2024
fa3e0b2
Merge branch 'main' into prover_cli_status_l1
EmilLuta May 3, 2024
5f30839
fix hyperchain contract call
ColoCarletti May 3, 2024
73854f1
merge main
ColoCarletti May 3, 2024
cc9ec3c
fix merge error
ColoCarletti May 3, 2024
485b81b
add tracing
ColoCarletti May 3, 2024
32d781f
Use anyhow instead of thiserror
ilitteri May 6, 2024
a45ba48
merge main
ColoCarletti May 7, 2024
a0d6f70
Merge branch 'main' into prover_cli_status_l1
ilitteri May 8, 2024
33eef67
Add Cargo.lock
ilitteri May 8, 2024
7821eda
fix eth_client
ColoCarletti May 8, 2024
c2a4a07
Merge branch 'main' into prover_cli_status_l1
EmilLuta May 8, 2024
fa2f370
Merge branch 'main' into prover_cli_status_l1
ilitteri May 8, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
37 changes: 37 additions & 0 deletions prover/Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 2 additions & 0 deletions prover/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,8 @@ zksync_state = { path = "../core/lib/state" }
zksync_system_constants = { path = "../core/lib/constants" }
zksync_types = { path = "../core/lib/types" }
zksync_utils = { path = "../core/lib/utils" }
zksync_eth_client = { path = "../core/lib/eth_client" }
zksync_contracts = { path = "../core/lib/contracts" }

# for `perf` profiling
[profile.perf]
Expand Down
4 changes: 3 additions & 1 deletion prover/prover_cli/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -29,4 +29,6 @@ zksync_types.workspace = true
zksync_prover_fri_types.workspace = true
zksync_prover_interface.workspace = true
prover_dal.workspace = true

zksync_eth_client.workspace = true
zksync_contracts.workspace = true
zksync_dal.workspace = true
52 changes: 49 additions & 3 deletions prover/prover_cli/README.md
Original file line number Diff line number Diff line change
@@ -1,14 +1,60 @@
# CLI to better understand and debug provers

For now, it has only one command 'file-info'
## Usage

> Note: For now, its necesary to use the 'zk f' tool to set up the environment. The main command will later be changed
> to `pli`.

```bash
Usage: zk f cargo run --release -- <COMMAND>

Commands:
file-info
status-jobs
help Print this message or the help of the given subcommand(s)

Options:
-h, --help Print help
-V, --version Print version
```

### Status-jobs

You can get the progress for some batch proof, for a bunch of batches the `status-jobs` command:

```bash
# Displays the proof progress of the batch 1
zk f cargo run -- status-jobs --batch 1
# Displays the proof progress of the batches 1 and 2
zk f cargo run -- status-jobs --batch 1 2
# Displays the proof progress of the batch 3, with additional information
zk f cargo run -- status-jobs --batch 3 --verbose
```

Example:

```bash
$ zk f cargo run -- status-jobs --batch 1 --verbose

Batch number: 1
Progress: 34.88% (45/129)
In progress: 1
Queued: 83
Successful: 45
Failed: 0
```

### File-Info

Displays the information about a given file:

```bash
cargo run -- file-info --file-path /zksync-era/prover/artifacts/proofs_fri/l1_batch_proof_1.bin
```

Example outputs:

```
```bash
L1 proof
AUX info:
L1 msg linear hash: [163, 243, 172, 16, 189, 59, 100, 227, 249, 46, 226, 220, 82, 135, 213, 208, 221, 228, 49, 46, 121, 136, 78, 163, 15, 155, 199, 82, 64, 24, 172, 198]
Expand All @@ -18,7 +64,7 @@ AUX info:
Inputs: [Fr(0x00000000775db828700e0ebbe0384f8a017598a271dfb6c96ebb2baf22a7a572)]
```

```
```bash
== Circuit ==
Type: basic. Id: 1 (Scheduler)
Geometry: CSGeometry { num_columns_under_copy_permutation: 130, num_witness_columns: 0, num_constant_columns: 4, max_allowed_constraint_degree: 8 }
Expand Down
6 changes: 5 additions & 1 deletion prover/prover_cli/src/cli.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
use clap::{command, Parser, Subcommand};

use crate::commands::get_file_info;
use crate::commands::{get_file_info, jobs_status, l1_status};

pub const VERSION_STRING: &str = env!("CARGO_PKG_VERSION");

Expand All @@ -14,12 +14,16 @@ struct ProverCLI {
#[derive(Subcommand)]
enum ProverCommand {
FileInfo(get_file_info::Args),
StatusJobs(jobs_status::Args),
StatusL1,
}

pub async fn start() -> anyhow::Result<()> {
let ProverCLI { command } = ProverCLI::parse();
match command {
ProverCommand::FileInfo(args) => get_file_info::run(args).await?,
ProverCommand::StatusJobs(args) => jobs_status::run(args).await?,
ProverCommand::StatusL1 => l1_status::run().await?,
};

Ok(())
Expand Down
63 changes: 63 additions & 0 deletions prover/prover_cli/src/commands/jobs_status.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
use anyhow::Context as _;
use clap::Args as ClapArgs;
use prover_dal::{ConnectionPool, Prover, ProverDal};
use zksync_basic_types::{prover_dal::JobCountStatistics, L1BatchNumber};
use zksync_config::PostgresConfig;
use zksync_env_config::FromEnv;

#[derive(ClapArgs)]
pub(crate) struct Args {
#[clap(short, long, num_args = 0..)]
batch: Vec<L1BatchNumber>,
#[clap(short, long, default_value("false"))]
verbose: bool,
}

fn pretty_print_job_status(
l1_batch_number: &L1BatchNumber,
statistics: &JobCountStatistics,
verbose: bool,
) {
let total_jobs =
statistics.queued + statistics.in_progress + statistics.failed + statistics.successful;
let progress = (statistics.successful as f32 / total_jobs as f32) * 100.0;
println!("Batch number: {}", l1_batch_number);
println!(
"Progress: {:.2}% ({}/{})",
progress, statistics.successful, total_jobs
);
if verbose {
println!("In progress: {}", statistics.in_progress);
println!("Queued: {}", statistics.in_progress);
println!("Successful: {}", statistics.in_progress);
}
println!("Failed: {}", statistics.failed);
}

pub(crate) async fn run(args: Args) -> anyhow::Result<()> {
let postgres_config = PostgresConfig::from_env().context("PostgresConfig::from_env()")?;

let prover_connection_pool = ConnectionPool::<Prover>::builder(
postgres_config.prover_url()?,
postgres_config.max_connections()?,
)
.build()
.await
.context("failed to build a prover_connection_pool")?;

let mut conn = prover_connection_pool.connection().await.unwrap();
let stats = conn
.fri_prover_jobs_dal()
.get_prover_jobs_stats_for_batch(args.batch)
.await;
if stats.len() > 0 {
for row in &stats {
let (l1_batch_number, statistics) = row;

pretty_print_job_status(l1_batch_number, statistics, args.verbose)
}
} else {
println!("No batches found.")
}
Ok(())
}
68 changes: 68 additions & 0 deletions prover/prover_cli/src/commands/l1_status.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
use anyhow::Context as _;
use zksync_basic_types::L1BatchNumber;
use zksync_config::{ContractsConfig, EthConfig, PostgresConfig};
use zksync_dal::{ConnectionPool, Core, CoreDal};
use zksync_env_config::FromEnv;
use zksync_eth_client::{clients::QueryClient, CallFunctionArgs, EthInterface};

// fn pretty_print_l1_status(
// total_batches_committed: Vec<Token>,
// total_batches_verified: Vec<Token>,
// first_state_keeper_l1_batch: L1BatchNumber,
// last_state_keeper_l1_batch: L1BatchNumber
// ) {
// println!("HOLIS");
// }

pub(crate) async fn run() -> anyhow::Result<()> {
let contracts_config = ContractsConfig::from_env()?;
let eth_config = EthConfig::from_env()?;
let query_client = QueryClient::new(&eth_config.web3_url).unwrap();

let args_for_total_batches_committed: zksync_eth_client::ContractCall =
CallFunctionArgs::new("getTotalBatchesCommitted", ()).for_contract(
contracts_config.diamond_proxy_addr,
zksync_contracts::zksync_contract(),
);
let total_batches_committed = query_client
.call_contract_function(args_for_total_batches_committed)
.await?;

let args_for_total_batches_verified: zksync_eth_client::ContractCall =
CallFunctionArgs::new("getTotalBatchesVerified", ()).for_contract(
contracts_config.diamond_proxy_addr,
zksync_contracts::zksync_contract(),
);
let total_batches_verified = query_client
.call_contract_function(args_for_total_batches_verified)
.await?;

let postgres_config = PostgresConfig::from_env().context("PostgresConfig::from_env()")?;

let connection_pool = ConnectionPool::<Core>::builder(
postgres_config.replica_url()?,
postgres_config.max_connections()?,
)
.build()
.await?;

let mut conn = connection_pool.connection().await?;

// Using unwrap() safely as there will always be at least one block.
let first_state_keeper_l1_batch = conn
.blocks_dal()
.get_earliest_l1_batch_number()
.await
.unwrap()
.unwrap();
let last_state_keeper_l1_batch = conn
.blocks_dal()
.get_sealed_l1_batch_number()
.await
.unwrap()
.unwrap();

// pretty_print_l1_status(total_batches_committed, total_batches_verified, first_state_keeper_l1_batch, last_state_keeper_l1_batch);

Ok(())
}
2 changes: 2 additions & 0 deletions prover/prover_cli/src/commands/mod.rs
Original file line number Diff line number Diff line change
@@ -1 +1,3 @@
pub(crate) mod get_file_info;
pub(crate) mod jobs_status;
pub(crate) mod l1_status;
5 changes: 5 additions & 0 deletions prover/prover_cli/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,11 @@ use prover_cli::cli;
#[tokio::main]
async fn main() {
env_logger::builder()
.filter_module("hyper", log::LevelFilter::Off)
.filter_module("web3", log::LevelFilter::Off)
.filter_module("zksync_db_connection", log::LevelFilter::Off)
.filter_module("sqlx", log::LevelFilter::Off)
.filter_module("reqwest", log::LevelFilter::Off)
.filter_level(log::LevelFilter::Debug)
.init();

Expand Down

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading
Loading