legongju.com
我们一直在努力
2025-01-12 21:40 | 星期天

C#如何实现Snowflake算法

Snowflake 是 Twitter 开源的分布式 ID 生成算法,它可以在不依赖数据库的情况下生成全局唯一的 ID。下面是一个简单的 C# 实现:

using System;

public class Snowflake
{
    // 基准时间
    private static readonly DateTime Epoch = new DateTime(2021, 1, 1, 0, 0, 0, DateTimeKind.Utc);

    // 机器 ID 所占位数
    private const int WorkerIdBits = 5;

    // 数据中心 ID 所占位数
    private const int DatacenterIdBits = 5;

    // 序列号所占位数
    private const int SequenceBits = 12;

    // 机器 ID 左移位数
    private const int WorkerIdShift = SequenceBits;

    // 数据中心 ID 左移位数
    private const int DatacenterIdShift = SequenceBits + WorkerIdBits;

    // 时间戳左移位数
    private const int TimestampLeftShift = SequenceBits + WorkerIdBits + DatacenterIdBits;

    // 最大序列号
    private const long MaxSequence = (1L << SequenceBits) - 1;

    // 机器 ID 和数据中心 ID 的最大值
    private const long MaxWorkerId = (1L<< WorkerIdBits) - 1;
    private const long MaxDatacenterId = (1L<< DatacenterIdBits) - 1;

    // 机器 ID
    private readonly long _workerId;

    // 数据中心 ID
    private readonly long _datacenterId;

    // 序列号
    private long _sequence;

    // 上次生成 ID 的时间戳
    private long _lastTimestamp;

    public Snowflake(long workerId, long datacenterId, long sequence = 0L)
    {
        if (workerId < 0 || workerId > MaxWorkerId)
            throw new ArgumentException($"Worker Id must be between 0 and {MaxWorkerId}");

        if (datacenterId < 0 || datacenterId > MaxDatacenterId)
            throw new ArgumentException($"Datacenter Id must be between 0 and {MaxDatacenterId}");

        _workerId = workerId;
        _datacenterId = datacenterId;
        _sequence = sequence;
    }

    public long NextId()
    {
        lock (this)
        {
            var timestamp = GetCurrentTimestamp();

            if (timestamp < _lastTimestamp)
                throw new Exception("Invalid system clock");

            if (_lastTimestamp == timestamp)
            {
                _sequence = (_sequence + 1) & MaxSequence;
                if (_sequence == 0)
                    timestamp = WaitNextMillisecond(_lastTimestamp);
            }
            else
            {
                _sequence = 0;
            }

            _lastTimestamp = timestamp;
            return ((timestamp - Epoch.Ticks)<< TimestampLeftShift) |
                   (_datacenterId<< DatacenterIdShift) |
                   (_workerId<< WorkerIdShift) |
                   _sequence;
        }
    }

    private long GetCurrentTimestamp()
    {
        return (DateTime.UtcNow - Epoch).Ticks / 10000;
    }

    private long WaitNextMillisecond(long lastTimestamp)
    {
        var timestamp = GetCurrentTimestamp();
        while (timestamp <= lastTimestamp)
            timestamp = GetCurrentTimestamp();
        return timestamp;
    }
}

使用方法:

var snowflake = new Snowflake(1, 1);
var id = snowflake.NextId();
Console.WriteLine(id);

这个实现中,我们使用了一个基准时间(Epoch),机器 ID(workerId),数据中心 ID(datacenterId)和序列号(sequence)来生成全局唯一的 ID。你需要为每个工作节点分配一个唯一的机器 ID 和数据中心 ID。

未经允许不得转载 » 本文链接:https://www.legongju.com/article/104227.html

相关推荐

  • C#中token是什么及其作用

    C#中token是什么及其作用

    在C#中,token通常指的是一个代表特定字符串或数据的标识符 身份验证和授权:在许多Web应用程序和API中,使用令牌(如JWT,JSON Web Token)进行身份验证和授权。...

  • 在C#中如何对token进行加密

    在C#中如何对token进行加密

    在C#中,对token进行加密通常使用的是对称加密算法,如AES(Advanced Encryption Standard)。以下是一个使用AES加密和解密token的示例:
    首先,需要引入Sy...

  • C#中token传递方式有哪些

    C#中token传递方式有哪些

    在C#中,token传递方式主要有以下几种: 查询字符串(Query String):将token作为URL的一部分,通过查询字符串传递。这种方式简单易用,但不太安全,因为URL可能...

  • C#中token与session的对比

    C#中token与session的对比

    在C#中,Token和Session都是用于身份验证和授权的技术,但它们之间存在一些关键区别。 存储方式: Token:通常以JWT(JSON Web Token)形式存储在客户端,如Web浏...

  • Snowflake算法在C#中的错误处理

    Snowflake算法在C#中的错误处理

    Snowflake 算法是一种分布式 ID 生成策略,用于在不依赖数据库或其他存储设备的情况下生成全局唯一的 ID。在 C# 中实现 Snowflake 算法时,可能会遇到一些错误和...

  • C# Snowflake算法的源码解析

    C# Snowflake算法的源码解析

    Snowflake 算法是 Twitter 开源的一种分布式 ID 生成策略,它可以在不依赖数据库或其他存储设备的情况下生成全局唯一的 ID。Snowflake 算法的 ID 结构包括时间戳...

  • Snowflake与C#的集成步骤

    Snowflake与C#的集成步骤

    要将Snowflake与C#集成,你需要遵循以下步骤: 安装Snowflake C#驱动程序:首先,你需要在你的项目中安装Snowflake C#驱动程序。你可以通过NuGet包管理器或者使用...

  • C# Snowflake算法的适用范围

    C# Snowflake算法的适用范围

    Snowflake 算法是一种分布式 ID 生成策略,主要用于在分布式系统中生成唯一、有序、不重复的 ID。它可以广泛应用于各种需要全局唯一 ID 的场景,例如数据库记录、...