forked from sigp/lighthouse
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Critical dependency logging (sigp#4988)
* add metrics layer * add metrics * simplify getting the target * make clippy happy * fix typos * unify deps under workspace * make import statement shorter, fix typos * enable warn by default, mark flag as deprecated * do not exit on error when initializing logging fails * revert exit on error * adjust bootnode logging * add logging layer * non blocking file writer * non blocking file writer * add tracing visitor * use target as is by default * make libp2p events register correctly * adjust repilcated cli help * refactor tracing layer * linting * filesize * log gossipsub, dont filter by log level * turn on debug logs by default, remove deprecation warning * truncate file, add timestamp, add unit test * suppress output (#5) * use tracing appender * cleanup * Add a task to remove old log files and upgrade to warn level * Add the time feature for tokio * Udeps and fmt --------- Co-authored-by: Diva M <divma@protonmail.com> Co-authored-by: Divma <26765164+divagant-martian@users.noreply.github.com> Co-authored-by: Age Manning <Age@AgeManning.com>
- Loading branch information
1 parent
a68b701
commit f22e5b0
Showing
7 changed files
with
238 additions
and
35 deletions.
There are no files selected for viewing
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,115 @@ | ||
use chrono::{naive::Days, prelude::*}; | ||
use slog::{debug, warn}; | ||
use std::io::Write; | ||
use tracing::Subscriber; | ||
use tracing_appender::non_blocking::{NonBlocking, WorkerGuard}; | ||
use tracing_subscriber::layer::Context; | ||
use tracing_subscriber::Layer; | ||
|
||
pub struct LoggingLayer { | ||
pub libp2p_non_blocking_writer: NonBlocking, | ||
pub libp2p_guard: WorkerGuard, | ||
pub discv5_non_blocking_writer: NonBlocking, | ||
pub discv5_guard: WorkerGuard, | ||
} | ||
|
||
impl<S> Layer<S> for LoggingLayer | ||
where | ||
S: Subscriber, | ||
{ | ||
fn on_event(&self, event: &tracing::Event<'_>, _ctx: Context<S>) { | ||
let meta = event.metadata(); | ||
let log_level = meta.level(); | ||
let timestamp = Local::now().format("%Y-%m-%d %H:%M:%S").to_string(); | ||
|
||
let target = match meta.target().split_once("::") { | ||
Some((crate_name, _)) => crate_name, | ||
None => "unknown", | ||
}; | ||
|
||
let mut writer = match target { | ||
"libp2p_gossipsub" => self.libp2p_non_blocking_writer.clone(), | ||
"discv5" => self.discv5_non_blocking_writer.clone(), | ||
_ => return, | ||
}; | ||
|
||
let mut visitor = LogMessageExtractor { | ||
message: String::default(), | ||
}; | ||
|
||
event.record(&mut visitor); | ||
let message = format!("{} {} {}\n", timestamp, log_level, visitor.message); | ||
|
||
if let Err(e) = writer.write_all(message.as_bytes()) { | ||
eprintln!("Failed to write log: {}", e); | ||
} | ||
} | ||
} | ||
|
||
struct LogMessageExtractor { | ||
message: String, | ||
} | ||
|
||
impl tracing_core::field::Visit for LogMessageExtractor { | ||
fn record_debug(&mut self, _: &tracing_core::Field, value: &dyn std::fmt::Debug) { | ||
self.message = format!("{} {:?}", self.message, value); | ||
} | ||
} | ||
|
||
/// Creates a long lived async task that routinely deletes old tracing log files | ||
pub async fn cleanup_logging_task(path: std::path::PathBuf, log: slog::Logger) { | ||
loop { | ||
// Delay for 1 day and then prune old logs | ||
tokio::time::sleep(std::time::Duration::from_secs(60 * 60 * 24)).await; | ||
|
||
let Some(yesterday_date) = chrono::prelude::Local::now() | ||
.naive_local() | ||
.checked_sub_days(Days::new(1)) | ||
else { | ||
warn!(log, "Could not calculate the current date"); | ||
return; | ||
}; | ||
|
||
// Search for old log files | ||
let dir = path.as_path(); | ||
|
||
if dir.is_dir() { | ||
let Ok(files) = std::fs::read_dir(dir) else { | ||
warn!(log, "Could not read log directory contents"; "path" => ?dir); | ||
break; | ||
}; | ||
|
||
for file in files { | ||
let Ok(dir_entry) = file else { | ||
warn!(log, "Could not read file"); | ||
continue; | ||
}; | ||
|
||
let Ok(file_name) = dir_entry.file_name().into_string() else { | ||
warn!(log, "Could not read file"; "file" => ?dir_entry); | ||
continue; | ||
}; | ||
|
||
if file_name.starts_with("libp2p.log") | file_name.starts_with("discv5.log") { | ||
let log_file_date = file_name.split('.').collect::<Vec<_>>(); | ||
if log_file_date.len() == 3 { | ||
let Ok(log_file_date_type) = | ||
NaiveDate::parse_from_str(log_file_date[2], "%Y-%m-%d") | ||
else { | ||
warn!(log, "Could not parse log file date"; "file" => file_name); | ||
continue; | ||
}; | ||
|
||
if log_file_date_type < yesterday_date.into() { | ||
// Delete the file, its too old | ||
debug!(log, "Removing old log file"; "file" => &file_name); | ||
if let Err(e) = std::fs::remove_file(dir_entry.path()) { | ||
warn!(log, "Failed to remove log file"; "file" => file_name, "error" => %e); | ||
} | ||
} | ||
} | ||
} | ||
} | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters