SnowflakeId.AutoRegister.Db 1.0.2

dotnet add package SnowflakeId.AutoRegister.Db --version 1.0.2                
NuGet\Install-Package SnowflakeId.AutoRegister.Db -Version 1.0.2                
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="SnowflakeId.AutoRegister.Db" Version="1.0.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add SnowflakeId.AutoRegister.Db --version 1.0.2                
#r "nuget: SnowflakeId.AutoRegister.Db, 1.0.2"                
#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 SnowflakeId.AutoRegister.Db as a Cake Addin
#addin nuget:?package=SnowflakeId.AutoRegister.Db&version=1.0.2

// Install SnowflakeId.AutoRegister.Db as a Cake Tool
#tool nuget:?package=SnowflakeId.AutoRegister.Db&version=1.0.2                

Snowflake Id(雪花Id) 自动注册

Latest version License LGPLv3 Coverity Scan

SnowflakeId.AutoRegister 是一个 C# 库,帮助你为 Snowflake ID 自动注册 WorkerId。 它不生成 Snowflake ID,仅为 WorkerId 的分配和注册提供支持。 支持多种存储机制(SQL Server、Redis 等),可轻松集成到任何使用 Snowflake ID 的库中。


入门指南

SnowflakeId AutoRegister 是一个库,提供了一种简单的方法在 SnowflakeId 中自动注册 WorkerId。
它本身不生成 Snowflake Id,只帮助你自动注册 WorkerId。

核心特点

  • 多存储机制支持:Redis、SQL Server、MySQL 等
  • 轻量级设计:无依赖,运行时动态加载驱动
  • 灵活配置:通过链式 API 自定义注册逻辑
  • 高兼容性:支持 .NET Standard 2.0,可在多种平台运行
  • 简化开发流程:减少手动维护 WorkerId 的复杂性
  • 高可靠性:支持 WorkerId 的自动续期,避免重复分配

注意

  • 为了兼容多种驱动以及多种版本,不包含任何驱动,避免过多依赖,运行时动态加载驱动

安装

安装核心包

使用 NuGet 包管理工具快速安装:

Install-Package SnowflakeId.AutoRegister

可选存储支持

  • Redis 存储支持:
    Install-Package SnowflakeId.AutoRegister.Redis
    
  • SQL Server 存储支持:
    Install-Package SnowflakeId.AutoRegister.SqlServer
    

    注意:需自行安装 SQL Server 驱动:Microsoft.Data.SqlClientSystem.Data.SqlClient
    一般情况业务上都有安装对应驱动,如果没有安装,请自行安装

    Install-Package Microsoft.Data.SqlClient
    

    Install-Package System.Data.SqlClient
    
  • MySQL 存储支持:
    Install-Package SnowflakeId.AutoRegister.MySql
    

    注意:需自行安装 MySQL 驱动MySql.DataMySqlConnector
    一般情况业务上都有安装对应驱动,如果没有安装,请自行安装

    Install-Package MySql.Data
    

  • Install-Package MySqlConnector
    

快速开始

以下是使用 SnowflakeId.AutoRegister 的基本示例

初始化 AutoRegister 实例

使用 AutoRegisterBuilder 构建一个单例实例:

static readonly IAutoRegister AutoRegister = new AutoRegisterBuilder()
    // 注册选项
    // 使用以下行设置标识符。
    // 推荐设置以区分单台机器上的多个应用程序
    .SetExtraIdentifier(Environment.CurrentDirectory)
    
    // 区分同路径exe,多个进程
    // .SetExtraIdentifier(Environment.CurrentDirectory + Process.GetCurrentProcess().Id)S
    
    // 日志配置
    .SetLogMinimumLevel(SnowflakeId.AutoRegister.Logging.LogLevel.Debug)
    .SetLogger((level, message, ex) => Console.WriteLine($"[{DateTime.Now}] [{level}] {message} {ex}"))
    
    // 使用以下行设置 WorkerId 范围。
    .SetWorkerIdScope(1, 31)
    // 使用以下行设置注册选项。
    // .SetRegisterOption(option => {})

    // 使用以下行使用默认存储。
    // 仅适用于开发使用、本地测试等。
    //.UseDefaultStore()
        
    // 使用以下行使用 Redis 存储。
    .UseRedisStore("localhost:6379,allowAdmin=true")
       
    // 使用以下行使用 SQL Server 存储。
    //.UseSqlServerStore("Server=localhost;Database=SnowflakeTest;User Id=sa;Password=123456;")
                
    // 使用以下行使用 MySQL 存储。
    .UseMySqlStore("Server=localhost;Port=3306;Database=snowflaketest;Uid=test;Pwd=123456;SslMode=None;")
    
    .Build();

注册 WorkerId

通过 AutoRegister 实例获取 WorkerId 配置:

// 注册 WorkerId。
SnowflakeIdConfig config = AutoRegister.Register();
Console.WriteLine($"WorkerId: {config.WorkerId}");

程序退出时注销 WorkerId

在程序退出时,主动注销 WorkerId,确保资源释放:

//主动注销WorkId,程序退出时调用
//如果程序异常退出,下次启动时会自动尝试获取上次的WorkerId,如果获取失败会重新注册
AutoRegister.UnRegister();

//可以使用AppDomain.CurrentDomain.ProcessExit事件
AppDomain.CurrentDomain.ProcessExit += (_, _) =>
{
    builder.UnRegister();
    Console.WriteLine("Unregistered.");
};

//.Net Core及以上版本可以使用ApplicationStopping事件
applicationLifetime.ApplicationStopping.Register(() =>
{
    builder.UnRegister();
    Console.WriteLine("Unregistered.");
});


集成 Snowflake ID 库

Yitter.IdGenerator

以下是集成 Yitter.IdGenerator 的示例:

var config = AutoRegister.Register();
var options = new IdGeneratorOptions
{
    WorkerId = (ushort)config.WorkerId,
};
IIdGenerator idGenInstance = new DefaultIdGenerator(options);
long id = idGenInstance.NewLong();
Console.WriteLine($"Id: {id}");

高级用法

托管雪花Id工具库生命周期

将雪花Id工具库的生命周期托管到AutoRegister实例中,以避免假死问题
原理:进程A注册了WorkerId 1,但是进程A因为各种原因(如生命周期太短、网络问题等) 导致无法及时续期,在其他进程看来此WorkerId已无效,进程B注册就会获得相同的WorkerId 1,在进程A恢复正常后,重新续期时会检测当前WorkId 1已被使用,会取消注册下次获取时会重新注册,

用法只需要调整Build

一下是Yitter.IdGenerator 的用法示例:

//IAutoRegister => IAutoRegister<xxx>
static readonly IAutoRegister<IIdGenerator> AutoRegister = new AutoRegisterBuilder()
    
    //与其他配置一样
    ...
    
    //重点在于这里
    .Build<IIdGenerator>(config => new DefaultIdGenerator(new IdGeneratorOptions()
            {
                WorkerId = (ushort)config.WorkerId
            }));

    //获取Id
    //确保每次都要使用`GetIdGenerator()`来获取`IdGenerator`实例,不要缓存,因为可能会重新注册
    long id =autoRegister.GetIdGenerator().NewLong();
    Console.WriteLine($"Id: {id}");

对于其他 Snowflake ID 生成库,可以参考上述示例进行集成。


常见问题 (FAQ)

  • Q: 为什么需要自动注册 WorkerId?

  • A: Snowflake ID 需要 WorkerId 来生成唯一的 ID。自动注册 WorkerId 可以减少手动维护的复杂性。

  • Q: 如果程序崩溃了,WorkerId 会被释放吗?

  • A: 不会。WorkerId存在生命周期,程序异常退出时,下次启动会尝试注册上一次的 WorkerId。如果失败,则重新注册新的 WorkerId。

  • Q: "假死问题"是什么?

  • A: 例如:进程A注册了WorkerId,但是进程A因为各种原因(如生命周期太短、网络问题等) 导致无法及时续期,在其他进程看来此WorkerId已无效,进程B注册就会获得相同的WorkerId,如果进程A恢复正常,此时进程A和进程B都会使用相同的WorkerId,导致ID重复 解决方案看高级用法

  • Q: 如何避免同文件多进程重复分配 WorkerId?

  • A: 在 SetExtraIdentifier 中添加进程相关的标识符,例如当前进程 ID。

  • Q: 默认存储机制适合生产环境吗?

  • A: 默认存储机制仅适合开发和本地测试(为了保持一致性)。在生产环境中,建议使用 Redis、SQL Server、MySql等等。


贡献指南

欢迎提交拉取请求!在贡献代码前,请遵循以下步骤:

  1. Fork 本仓库并创建新分支。
  2. 确保代码通过所有测试,并保持与主分支同步。
  3. 如果有重大更改,请先打开一个 Issue 讨论你想要更改的内容。 请确保适当更新测试。
  4. 提交 PR 并描述所做的更改。

构建源码

克隆仓库:

git clone https://github.com/LemonNoCry/SnowflakeId.AutoRegister.git

导航到项目目录:

cd SnowflakeId.AutoRegister 

恢复包:

dotnet restore 

构建项目:

dotnet build

许可证

This project is licensed under the MIT License.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  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. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (2)

Showing the top 2 NuGet packages that depend on SnowflakeId.AutoRegister.Db:

Package Downloads
SnowflakeId.AutoRegister.SqlServer

SnowflakeId AutoRegister StackExchangeRedis: An extension of the SnowflakeId AutoRegister library, enabling automatic WorkerId registration in SnowflakeId systems using SqlServer

SnowflakeId.AutoRegister.MySql

SnowflakeId AutoRegister MySql: An extension of the SnowflakeId AutoRegister library, enabling automatic WorkerId registration in SnowflakeId systems using MySql

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.2 670 12/9/2024
1.0.1 177 12/5/2024
1.0.0 215 12/3/2024