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 batch command #1638

Merged
merged 84 commits into from
May 3, 2024
Merged
Show file tree
Hide file tree
Changes from 9 commits
Commits
Show all changes
84 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
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
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
585059b
Merge branch 'main' into prover_cli_status_command
ilitteri Apr 17, 2024
9977e95
Refactor
Apr 18, 2024
ee88cfe
Merge branch 'main' into prover_cli_status_command
ilitteri Apr 18, 2024
075e6dc
Merge branch 'main' into prover_cli_status_command
ColoCarletti Apr 19, 2024
0120a09
fix typo
ColoCarletti Apr 19, 2024
9a11a94
modify query to include aggregation_round
ColoCarletti Apr 19, 2024
1c92e95
change query return type
ColoCarletti Apr 24, 2024
05e1636
Update Cargo files
Apr 24, 2024
58d47ad
Setle status cmd baseline
Apr 24, 2024
f778759
Add status cmd utils
Apr 24, 2024
e945df2
Add status utils
Apr 24, 2024
6585378
zk fmt
Apr 24, 2024
47df898
Document enums
Apr 24, 2024
ceae289
Add BatchDataBuilder struct
Apr 24, 2024
f6d7b9a
Add TaskStatus::Custom enum variant
Apr 24, 2024
8e16d35
Fix BatchDataBuilder
Apr 24, 2024
a76cb32
Rollback
Apr 24, 2024
c460029
impl From<ProofCompressionJobStatus> for TaskStatus
Apr 24, 2024
e76da1f
Fix TaskStatus::Custom fmt
Apr 24, 2024
4be214e
Add query for getting proof compression job info for a batch
Apr 25, 2024
e9e197f
Add query for getting proof compression job info for a batch
Apr 25, 2024
7c9a499
Handle proof compression job status for batches
Apr 25, 2024
17b5875
Fix get_proof_compression_job_status_for_batch
Apr 25, 2024
3fdc055
Remove BatchDataBuilder struct
Apr 25, 2024
a2ad3f9
Merge branch 'prover_cli_status_command' of github.com:matter-labs/zk…
Apr 25, 2024
3093cde
Fix
Apr 25, 2024
fde3be1
Move prover_dal types to basic_types::prover_dal module
ilitteri Apr 25, 2024
efd70ac
Refactor query
ilitteri Apr 25, 2024
6ec0ac3
Merge pull request #1789 from matter-labs/prover_cli_compressor_status
ilitteri Apr 25, 2024
1830ced
add bwg query
ColoCarletti Apr 25, 2024
a6105b8
merge compresor job
ColoCarletti Apr 25, 2024
bbe5dc3
add status for prover jobs
ColoCarletti Apr 26, 2024
111884b
add title for prover jobs
ColoCarletti Apr 26, 2024
9fef23d
Refactor
ilitteri Apr 26, 2024
01ecd2f
add leaf query
ColoCarletti Apr 29, 2024
25e089b
Merge branch 'prover_cli_status_command' into prover_cli_status_comma…
ColoCarletti Apr 29, 2024
590c58b
fix merge
ColoCarletti Apr 29, 2024
e08b05e
add querys
ColoCarletti Apr 29, 2024
cf069b9
fix witnes jobs status
ColoCarletti Apr 30, 2024
6ad5566
rm comments
ColoCarletti Apr 30, 2024
a3f1938
Fix & refactors
ilitteri Apr 30, 2024
78c7cd8
zk lint rust
ilitteri Apr 30, 2024
33729b8
Fix import
ilitteri Apr 30, 2024
1efde33
Merge branch 'prover_cli_status_command' of github.com:matter-labs/zk…
ilitteri Apr 30, 2024
112ae93
fix import
ColoCarletti Apr 30, 2024
e1854fa
zk lint rust
ilitteri Apr 30, 2024
ccab3d3
Merge branch 'prover_cli_status_command_lwg' of github.com:matter-lab…
ColoCarletti Apr 30, 2024
fa26c26
fix wg task types
ColoCarletti Apr 30, 2024
dbaf3b4
Merge pull request #1830 from matter-labs/prover_cli_status_command_lwg
ColoCarletti Apr 30, 2024
4124f63
Merge main
ColoCarletti Apr 30, 2024
a4fde1f
update README
ColoCarletti Apr 30, 2024
10fdcb9
fix EIP Blob use
ColoCarletti Apr 30, 2024
8a1101f
fix typos
ColoCarletti Apr 30, 2024
c1282a5
Merge branch 'main' into prover_cli_status_command
ilitteri May 2, 2024
1bbde93
Fix typo
ilitteri May 2, 2024
16be778
Merge branch 'main' into prover_cli_status_command
ilitteri May 2, 2024
1810ae0
Merge branch 'main' into prover_cli_status_command
ilitteri May 2, 2024
6f45f43
update cargo.toml
ColoCarletti May 2, 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
71 changes: 57 additions & 14 deletions prover/Cargo.lock

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

2 changes: 1 addition & 1 deletion prover/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ members = [
"witness_vector_generator",
"prover_fri_gateway",
"proof_fri_compressor",
"tools",
"prover_cli",
]

resolver = "2"
Expand Down
44 changes: 44 additions & 0 deletions prover/prover_cli/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
[package]
name = "prover_cli"
version.workspace = true
edition.workspace = true
authors.workspace = true
homepage.workspace = true
repository.workspace = true
license.workspace = true
keywords.workspace = true
categories.workspace = true

[dependencies]
tokio = { version = "1", features = ["rt-multi-thread", "macros"] }
env_logger = "0.10"
log = "0.4"
eyre = "0.6"

clap = { workspace = true, features = ["derive"] }
tracing.workspace = true
tracing-subscriber = { workspace = true, features = ["env-filter"] }
bincode.workspace = true
colored.workspace = true
hex.workspace = true
anyhow.workspace = true
zksync_config.workspace = true
zksync_env_config.workspace = true
zksync_db_connection.workspace = true
zksync_basic_types.workspace = true
zksync_types.workspace = true
zksync_prover_fri_types.workspace = true
zksync_prover_interface.workspace = true
prover_dal.workspace = true
sqlx = { workspace = true, features = [
"runtime-tokio",
"tls-native-tls",
"macros",
"postgres",
"bigdecimal",
"rust_decimal",
"chrono",
"json",
"migrate",
"ipnetwork",
] }
4 changes: 2 additions & 2 deletions prover/tools/README.md → prover/prover_cli/README.md
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
# Tool to better understand and debug provers
# CLI to better understand and debug provers

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

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

Example outputs:
Expand Down
28 changes: 28 additions & 0 deletions prover/prover_cli/src/cli.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
use clap::{command, Parser, Subcommand};

use crate::commands::{get_file_info, get_proof_progress};

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

#[derive(Parser)]
#[command(name="prover-cli", version=VERSION_STRING, about, long_about = None)]
struct ProverCLI {
#[command(subcommand)]
command: ProverCommand,
}

#[derive(Subcommand)]
enum ProverCommand {
FileInfo(get_file_info::Args),
ProofProgress(get_proof_progress::Args),
}

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

Ok(())
}
Original file line number Diff line number Diff line change
@@ -1,8 +1,7 @@
use std::fs;

use clap::{Parser, Subcommand};
use clap::Args as ClapArgs;
use colored::Colorize;
use tracing::level_filters::LevelFilter;
use zksync_prover_fri_types::{
circuit_definitions::{
boojum::{
Expand All @@ -18,23 +17,10 @@ use zksync_prover_fri_types::{
};
use zksync_prover_interface::outputs::L1BatchProofForL1;

#[derive(Debug, Parser)]
#[command(
author = "Matter Labs",
version,
about = "Debugging tools for prover related things",
long_about = None
)]

struct Cli {
#[command(subcommand)]
command: Command,
}

#[derive(Debug, Subcommand)]
enum Command {
#[command(name = "file-info")]
FileInfo { file_path: String },
#[derive(ClapArgs)]
pub(crate) struct Args {
#[clap(short, long)]
file_path: String,
}

fn pretty_print_size_hint(size_hint: (Option<usize>, Option<usize>)) {
Expand Down Expand Up @@ -204,7 +190,8 @@ fn pretty_print_l1_proof(result: &L1BatchProofForL1) {
println!(" This proof will pass on L1, if L1 executor computes the block commitment that is matching exactly the Inputs value above");
}

fn file_info(path: String) {
pub(crate) async fn run(args: Args) -> anyhow::Result<()> {
let path = args.file_path;
println!("Reading file {} and guessing the type.", path.bold());

let bytes = fs::read(path).unwrap();
Expand All @@ -214,14 +201,14 @@ fn file_info(path: String) {
if let Some(circuit) = maybe_circuit {
println!(" Parsing file as CircuitWrapper.");
pretty_print_circuit_wrapper(&circuit);
return;
return Ok(());
}
println!(" NOT a CircuitWrapper.");
let maybe_fri_proof: Option<FriProofWrapper> = bincode::deserialize(&bytes).ok();
if let Some(fri_proof) = maybe_fri_proof {
println!(" Parsing file as FriProofWrapper.");
pretty_print_proof(&fri_proof);
return;
return Ok(());
}
println!(" NOT a FriProofWrapper.");

Expand All @@ -232,19 +219,5 @@ fn file_info(path: String) {
} else {
println!(" NOT a L1BatchProof.");
}
}

fn main() {
tracing_subscriber::fmt()
.with_env_filter(
tracing_subscriber::EnvFilter::builder()
.with_default_directive(LevelFilter::INFO.into())
.from_env_lossy(),
)
.init();

let opt = Cli::parse();
match opt.command {
Command::FileInfo { file_path } => file_info(file_path),
}
Ok(())
}
56 changes: 56 additions & 0 deletions prover/prover_cli/src/commands/get_proof_progress.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
use anyhow::Context as _;
use clap::Args as ClapArgs;
use sqlx::{postgres::PgPoolOptions, Row};
use zksync_config::PostgresConfig;
use zksync_env_config::FromEnv;

#[derive(ClapArgs)]
pub(crate) struct Args {
#[clap(short, long)]
l1_batch_number: i32,
}

pub(crate) async fn run(args: Args) -> anyhow::Result<()> {
let pool = PgPoolOptions::new()
ilitteri marked this conversation as resolved.
Show resolved Hide resolved
.max_connections(5)
.connect("postgres://postgres:notsecurepassword@localhost/prover_local")
.await?;

let query = sqlx::query(
ilitteri marked this conversation as resolved.
Show resolved Hide resolved
ilitteri marked this conversation as resolved.
Show resolved Hide resolved
"SELECT
id,
status,
error,
processing_started_at,
time_taken,
is_node_final_proof
FROM
prover_jobs_fri
WHERE
l1_batch_number = $1",
)
.bind(&args.l1_batch_number)
.fetch_all(&pool)
.await?;

let total_jobs = query.len();
let successful_jobs = query
.iter()
.filter(|row| row.get::<String, _>("status") == "successful")
.count();
let failed_jobs = query
.iter()
.filter(|row| row.get::<String, _>("status") == "failed")
.count();
let progress = (successful_jobs as f32 / total_jobs as f32) * 100.0;

println!("= Prover progress =");
println!("Batch number: {}", args.l1_batch_number);
println!(
"Progress: {:.2}% ({}/{})",
progress, successful_jobs, total_jobs
);
println!("Failed: {}", failed_jobs);

Ok(())
}
2 changes: 2 additions & 0 deletions prover/prover_cli/src/commands/mod.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
pub(crate) mod get_file_info;
pub(crate) mod get_proof_progress;
2 changes: 2 additions & 0 deletions prover/prover_cli/src/lib.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
pub mod cli;
mod commands;
10 changes: 10 additions & 0 deletions prover/prover_cli/src/main.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
use prover_cli::cli;

#[tokio::main]
async fn main() {
env_logger::builder()
.filter_level(log::LevelFilter::Debug)
.init();

cli::start().await.unwrap();
}
20 changes: 0 additions & 20 deletions prover/tools/Cargo.toml

This file was deleted.

Loading