首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

使用redis生成唯一编号

在项目开发中,我们需要保证数据的唯一性,就目前开发中常用的方式有使用自增序列、GUID、时间戳以及时间戳加上随机数。生成ID的方法有很多,每种适用场景、需求以及性能要求不同。...下面我们列出以下较为常用的生成ID的方式,并且来讨论以下他们的优缺点。 利用数据库自带的自增功能设置唯一id: 优点:可控并且显而易见。...自定义ID: 目前推特使用的是自己开发的全局唯一ID生成服务Snowflake。它是由精确到毫秒的41位时间序列和10位机器标识以及12位的计数顺序号组成的,它的最高位是符号位并且始终为0。...Redis生成id: 对于大型系统来说,我们可以使用Redis来生成ID,主要是依赖于redis是单线程的,因此可以用来生成全局唯一ID。...下面我们就来看一下如何使用redis生成唯一ID,主要思想是利用redis单线程特性以保证操作的原子性,这样读写同一key时不会出现不同的数据。

2.1K20
您找到你想要的搜索结果了吗?
是的
没有找到

SQL 生成连续的编号

给大家一分钟,请思考:在你熟悉的数据库里使用 SQL 快速生成 001~999 的编号有哪些方法。 以下是我想到的在 MySQL 中可以实现的方法。...我把这个实现过程分成两部分: 生成 1~999 的序号; 对不足三位数的序号在前面补‘0’。 MySQL 提供了 LPAD() 左填充函数,因此第二部分已经解决。...生成 1~999 的序号的方法有: 找到任意一张记录数大于 1000 的表 t,执行 SELECT ROW_NUMBER() OVER() AS num FROM t LIMIT 999 就能够生成 1...使用递归,关于用递归生成连续序号的文章请看——生成数字序列; 手动生成 0-9 的数字,将这批数字放到临时表中,对临时表重复求笛卡尔积,具体实现后面有讲。...* 10 + c.num AS num FROM t10 a, t10 b, t10 c) t WHERE num > 0 ORDER BY 1 1~999 的编号

3.7K30

pHP生成唯一单号

而交易的依据就是订单号,当然我们要随机生成的订单号也不能相同的,下面提供了四种利用PHP生成订单号的方法。...第一种PHP生成唯一单号的方法 PHP代码 $str = date('Ymd') . str_pad(mt_rand(1, 99999), 5, '0', STR_PAD_LEFT); /**飞鸟慕鱼博客...*/ echo $str; 注:这种方式是利用当前的时间,加随机机补全的方法生成,当然我们可以把时间精确到秒级 第二种PHP生成唯一单号的方法 代码 $str = date('Ymd').substr...代码 //生成24位唯一订单号码,格式:YYYY-MMDD-HHII-SS-NNNN,NNNN-CC, //其中:YYYY=年份,MM=月份,DD=日期,HH=24格式小时,II=分,SS=秒,NNNNNNNN...以上就有利用PHP生成唯一单号的方法,如果是不是很大型的电商网站,个人推荐使用第二种方法,快速高效。 如果你有,别的好的方法,可以在下方留言给我哦!

1.6K20

游戏后台生成唯一ID

游戏中的角色,装备,物品等需要生成一个全局唯一ID标识,便于辨别不同玩家,不同装备,也方便定位外网问题。...常见的分布式全局唯一ID生成方式包括使用数据库自增,使用Redis的原子操作INCR和INCRBY,使用UUID,SnowFlake算法等等。...前面两种方式均需要产生一次异步调用,在MMO中,海量玩家会集中在一个场景中进行PK,做任务,打怪等,场景内业务逻辑复杂,为了降低编码复杂度,减少BUG几率,通常会选择使用本地算法来生成全局唯一ID。...根据游戏进程部署的特点,产生了下面这种64位ID的通用结构: mmo uid.png 具体字段含义如下: 大区号:游戏中的分区 虚拟机器号:一个小区内的机器虚拟编号 功能号:不同类型的进程的功能编号,比如排行榜进程和组队进程功能号不一样...实例ID:同一类型的进程的不同实例编号 校验序号:这个序号在每次进程重启时就自增1,数据会写入本地文件中 序列号:同一时间内生成ID会自增序列号 自适应时间:进程启动时初始化为当前时间的时间戳(秒级别的

2.6K00

Python-唯一ID-01-生成唯一ID

系统:Windows 10 编辑器:JetBrains PyCharm Community Edition 2018.2.2 x64 这个系列讲讲和唯一ID相关的一些操作 今天讲讲如何生成 Part 1...:场景描述 对于数据的每一条记录一般都有一个唯一的ID,用来标识这一记录 在Django项目中,若使用MySQL作为数据库,使用Models创建数据库,会自动创建一个ID字段,且该字段为自增,不重复 自增的...ID在不同表之间是重复的,那如果有一个个性的需求,需要手动生成一个不重复的ID,如何实现 Part 2:方法1 通过时间序列生成ID,已用户的操作时刻生成一串数字,理论上同一毫秒进行操作的概率不大,当然也不是严格没有可能...import datetime def get_unique_id(): """ 根据时间生成唯一ID :return: """ current_time =...,这样两台不同的电脑生成的id肯定是不同的 import uuidid_1 = uuid.uuid1() print(id_1) 图3 运行结果 本机mac地址获取 windows系统下cmd中输入getmac

1.9K10

如何生成全局唯一标识

引出 大家都用过QQ或者微信吧, 当我们注册的时候, 会被自动分配一个QQ号, 这个号码是全局唯一且固定的, 那么, 如果是你来写的话, 如何为新注册的用户分配一个号码呢?...要想生成随机ID, 首先, 要有一个不是随机的而又是当前唯一持有的. 在这个前提下, 再各种添油加醋, 生成最终的ID. 就算你要调用随机函数, 也得设置一个随机种子不是?...很好, 那么现在问题就归结为, 如何给每个用户都配一个唯一标识 1.数数 直接想到的方案, 从1开始, 慢慢往后数, 而这个过程可以借助MySQL的主键自增, 也可以借助redis的单线程优势....等等吧, 2.用户特征 可以根据不同用户的特征, 如用户的地域、性别、生辰等等, 来生成每个人的唯一标识, 此举可以参考身份证号码的生成, 每个人都是不一样的 3.当前机器特征 找到执行代码时的特定特征..., 如: mac地址、时间戳、机器编号、线程ID等等 4.代码运行次数 线程共享变量, 每次执行则+1.

1.6K20

雪花算法SnowFlake生成唯一ID

分布式ID常见生成策略: 分布式ID生成策略常见的有如下几种: 数据库自增ID。 UUID生成。 Redis的原子自增方式。 数据库水平拆分,设置初始值和相同的自增步长。 批量申请自增ID。...本文主要介绍SnowFlake 算法,是 Twitter 开源的分布式 id 生成算法。 其核心思想就是:使用一个 64 bit 的 long 型的数字作为全局唯一 id。...是 12 个 bit:表示的序号,就是某个机房某台机器上这一毫秒内同时生成的 id 的序号,0000 0000 0000。...也就是同一毫秒内同一台机器所生成的最大ID数量为4096  简单来说,你的某个服务假设要生成一个全局唯一 id,那么就可以发送一个请求给部署了 SnowFlake 算法的系统,由这个 SnowFlake...算法系统来生成唯一 id。

1.6K10

唯一ID生成算法剖析

按照我的分析有以下特性: 唯一性:生成的ID全局唯一,在特定范围内冲突概率极小 有序性:生成的ID按某种规则有序,便于数据库插入及排序 可用性:可保证高并发下的可用性 自主性:分布式环境下不依赖中心认证即可自行生成...ID 安全性:不暴露系统和业务的信息 一般来说,常用的唯一ID生成方法有这些: UUID: 基于时间戳&时钟序列生成 基于名字空间/名字的散列值 (MD5/SHA1) 生成 基于随机数生成 数据库自增ID...UUID算法的目的是为了生成某种形式的全局唯一ID来标识系统中的任一元素,尤其在分布式环境下,该ID需要不依赖中心认证即可自动生成全局唯一ID。...缺点:SHA1计算相对耗时 总得来说: 版本 1/2 适用于需要高度唯一性且无需重复的场景; 版本 3/5 适用于一定范围内唯一且需要或可能会重复生成UUID的环境下; 版本 4 适用于对唯一性要求不太严格且追求简单的场景...各种方案都有其优缺点,技术的使用没有绝对的好坏之分,主要在于是否适合使用场景: 要求生成全局唯一且不会重复ID,不关心顺序 —— 使用基于时间的UUID(如游戏聊天室中不同用户的身份ID) 要求生成唯一

2.8K50

python使用UUID库生成唯一ID

它可以保证时间和空间的唯一性,也称为GUID,全称为: UUID —— Universally Unique IDentifier Python 中叫 UUID GUID —— Globally Unique...IDentifier C# 中叫 GUID 它通过MAC地址、时间戳、命名空间、随机数、伪随机数来保证生成ID的唯一性。...UUID主要有五个算法,也就是五种方法来实现: 1、uuid1()——基于时间戳 由MAC地址、当前时间戳、随机数生成。...可以保证全球范围内的唯一性,但MAC的使用同时带来安全性问题,局域网中可以使用IP来代替MAC。...3、uuid3()——基于名字的MD5散列值 通过计算名字和命名空间的MD5散列值得到,保证了同一命名空间中不同名字的唯一性,和不同命名空间的唯一性,但同一命名空间的同一名字生成相同的uuid。

1K10

php生成唯一uid的解决思路

一、生成唯一uuid 看到某些人会用uuid去代替用户的uid 从代码中可以看出,通过unique生成一个以毫秒级时间戳为前缀的字符后md5加密 再通过分隔符进行分割后得到uuid 这种方式虽然极大程度的避免了...uid的重复 但是生成的uid太长,足足36个字符,而且是混杂英文和数字符号的,可读性很差 而一般的uid中都是纯数值组成的 <?...$hyphen . substr($charid, 20, 12); return $uuid; } //结果:37f14a07-cb18-2e54-4e40-da1e2fa0456d 二、生成唯一...uid 由于一般正常的uid都是纯数值型的 而要保证唯一性,必然要跟时间戳有关系,因此有了以下代码 为了尽可能的在同一秒中注册人数的uid不同,将时间戳进行打乱随机排序,也不失为一个好办法 但是这种缺点就是...php function generateUid() { return call_user_func('str_shuffle', time()); } //结果:4067524162 三、 生成唯一

1.2K30

唯一ID生成原理与PHP实现

snowflake算法 虽然PHP提供了一个生成唯一ID的函数uniqid(),但这个函数真的可以生成唯一ID吗?...RETURN_STRING(uniqid, 0); } 从代码可以看出,uniqid()是通过微妙级时间戳来实现的,在分布式高并发的情况下,ID的重复率是很高的,所以我们不能使用uniqid()来生成唯一...对于不同的机器来说,可以为每一台机器分配一个唯一的机器ID,这样就可以保证每台机器锁生成的ID不会重复。 对于同一台机器,如果同一时刻多个客户端并发请求,那么可以通过增加序列号来保证ID唯一性。...当然这两种锁都可以解决资源竞争问题,但是相对于生成唯一ID这种场景,使用自旋锁会有更好的性能,这是因为生成ID这个过程非常短,而自旋锁锁不需要切换上下文。...总结 snowflake算法可以有效的生成唯一ID,而且通过配置机器ID可以很好地支持分布式环境。

1.4K30
领券