#sentry #crash #minidump #process #capture #native #applications

sentry-rust-minidump

Captures native crashes as minidumps and sends to Sentry

20 unstable releases (8 breaking)

0.9.0 Nov 29, 2024
0.8.0 Jun 29, 2024
0.7.0 Feb 25, 2024
0.6.4 Jul 12, 2023
0.1.3 Jul 22, 2022

#153 in Debugging

Download history 337/week @ 2024-08-23 233/week @ 2024-08-30 286/week @ 2024-09-06 253/week @ 2024-09-13 696/week @ 2024-09-20 837/week @ 2024-09-27 785/week @ 2024-10-04 717/week @ 2024-10-11 1038/week @ 2024-10-18 862/week @ 2024-10-25 1045/week @ 2024-11-01 848/week @ 2024-11-08 1074/week @ 2024-11-15 969/week @ 2024-11-22 1071/week @ 2024-11-29 953/week @ 2024-12-06

4,249 downloads per month
Used in 2 crates

MIT/Apache

18KB
91 lines

sentry-rust-minidump

Master branch integration test status

Uses the minidumper-child crate to capture minidumps from a separate process and sends them to Sentry as attachments via the Sentry Rust SDK.

sentry_rust_minidump::init starts the current executable again with an argument that causes it to start in crash reporter mode. In this mode it waits for minidump notification from the main app process and handles writing and sending of the minidump file as an attachment to Sentry.

Everything before sentry_rust_minidump::init is called in both the main and crash reporter processes and should configure and start Sentry. Everything after sentry_rust_minidump::init is only called in the main process to run your application code.

[dependencies]
sentry = "0.35"
sentry-rust-minidump = "0.9"
fn main() {
    let client = sentry::init("__YOUR_DSN__");

    // Everything before here runs in both app and crash reporter processes
    let _guard = sentry_rust_minidump::init(&client);
    // Everything after here runs in only the app process

    App::run();

    // This will cause a minidump to be sent to Sentry 
    #[allow(deref_nullptr)]
    unsafe {
        *std::ptr::null_mut() = true;
    }
}

ipc feature

By default there is no scope synchronisation from the app process to the crash reporter process. This means that native crash event will be missing breadcrumbs, user, tags or extra added to the scope in the app.

When the ipc feature is enabled, you can send scope updates to the crash reporter process:

fn main() {
    let client = sentry::init("__YOUR_DSN__");

    // Everything before here runs in both app and crash reporter processes
    let crash_reporter = sentry_rust_minidump::init(&client).expect("crash reported didn't start");
    // Everything after here runs in only the app process

    crash_reporter.add_breadcrumb(...);
    crash_reporter.set_user(...);
    crash_reporter.set_extra(...);
    crash_reporter.set_tag(...);

    // Don't drop crash_reporter or the reporter process will close!
}

Dependencies

~9–19MB
~283K SLoC