RuntimeUpgradeNotifier 1.0.0-beta1

This is a prerelease version of RuntimeUpgradeNotifier.
dotnet add package RuntimeUpgradeNotifier --version 1.0.0-beta1                
NuGet\Install-Package RuntimeUpgradeNotifier -Version 1.0.0-beta1                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="RuntimeUpgradeNotifier" Version="1.0.0-beta1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add RuntimeUpgradeNotifier --version 1.0.0-beta1                
#r "nuget: RuntimeUpgradeNotifier, 1.0.0-beta1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install RuntimeUpgradeNotifier as a Cake Addin
#addin nuget:?package=RuntimeUpgradeNotifier&version=1.0.0-beta1&prerelease

// Install RuntimeUpgradeNotifier as a Cake Tool
#tool nuget:?package=RuntimeUpgradeNotifier&version=1.0.0-beta1&prerelease                

RuntimeUpgradeNotifier

Receive notifications when the .NET Runtime running your process gets upgraded to a new version, so you can restart your process and avoid crashing later.

Requirements

  • .NET Runtime 8 or later

Installation

dotnet add package RuntimeUpgradeNotifier

Usage

By default, this library will only notify you when the .NET Runtime is upgraded instead of starting or stopping any processes, but you can choose to have it automatically start or stop your process as well.

Automatically restart process

When the .NET Runtime for your process is upgraded, this will start a new instance of your program with the same command-line arguments, environment variables, and working directory as the current process. It will then exit the old process with status code 1.

using RuntimeUpgrade.Notifier;
using RuntimeUpgrade.Notifier.Data;

RuntimeUpgradeNotifier.RestartBehavior = RestartBehavior.AutoRestartProcess;

RuntimeUpgradeNotifier.RuntimeUpgraded += (_, evt) => {
    Console.WriteLine($"Restarting process with PID {evt.NewProcessId}");
    return ValueTask.CompletedTask;
};
Custom exit code

By default, the current process will exit with status code 0 as soon as the RuntimeUpgraded event handler returns. You can change this value with CurrentProcessExitCode.

RuntimeUpgradeNotifier.RuntimeUpgraded += (_, evt) => {
    evt.CurrentProcessExitCode = 1;
    return ValueTask.CompletedTask;
};

Automatically start new process and manually exit old process

This allows you to shut down your application more gracefully than Environment.Exit() can.

RuntimeUpgradeNotifier.RestartBehavior = RestartBehavior.AutoStartNewProcess;
RuntimeUpgradeNotifier.RuntimeUpgraded += (_, evt) => {
    /*       WPF: */ Application.Current.Shutdown();
    /*     Forms: */ Application.Exit();
    /* .NET Host: */ hostApplicationLifetime.StopApplication();

    return ValueTask.CompletedTask;
};

Manually restart process (notify only)

This grants you full customization of the shutdown and restart of your program. For example, you can help your process resume its execution by transferring state using extra command-line arguments, environment variables, IPC messages, or any other signaling technique.

RuntimeUpgradeNotifier.RestartBehavior = RestartBehavior.Manual; //default
RuntimeUpgradeNotifier.RuntimeUpgraded += (_, evt) => {
    Process.Start(Environment.ProcessPath, Environment.GetCommandLineArgs().Skip(1).Concat(["--restarted-after-runtime-upgrade"]));
    
    Application.Current.Shutdown();
};
Service restart

If you have a background service or daemon, you can configure Windows or systemd to automatically restart your program when it exits with a non-zero status code.

  • Windows:
    • GUI: services.msc → service properties → Recovery → Choose Restart the service for "First failure", "Second failure", and "Subsequent failures"
    • CLI: sc failure MyService actions= restart/0/restart/0/restart/0 reset= 86400
  • systemd:
    [Service]
    Restart=on-failure
    
Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net8.0

    • No dependencies.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.0-beta1 68 5/30/2024