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

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 =...) print(id_used) 图2 运行结果 Part 3:方法2 uuid包实现,是根据当前时间和设备MAC地址生成的,这样两台不同的电脑生成的id肯定是不同的 import uuidid_1

2K10

PHP生成唯一ID

即使使用了第二个参数,也会重复,最好的方案是结合 md5 函数来生成唯一 ID。...使用函数 string uniqid ([ string $prefix = "" [, bool $more_entropy = false ]] ) 获取一个带前缀、基于当前时间微秒数的唯一 ID。...prefix 有用的参数。例如:如果在多台主机上可能在同一微秒生成唯一 ID。prefix 为空,则返回的字符串长度为 13。moreentropy 为 TRUE,则返回的字符串长度为 23。...使得唯一 ID 更具唯一性。 PHP uniqid() 生成不重复唯一标识方法一 这种方法会产生大量的重复数据,运行如下 PHP 代码会数组索引是产生的唯一标识,对应的元素值是该唯一标识重复的次数。...php sessioncreateid()是 php 7.1 新增的函数,用来生成 session id,低版本无法使用

4.1K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    全局唯一 ID 服务的分布式ID生成系统

    背景 在复杂分布式系统中,往往需要对大量的数据和消息进行唯一标识。...如在美团点评的金融、支付、餐饮、酒店、猫眼电影等产品的系统中,数据日渐增长,对数据分库分表后需要有一个唯一ID来标识一条数据或消息,数据库的自增ID显然不能满足需求;特别一点的如订单、骑手、优惠券也都需要有唯一...此时一个能够生成全局唯一ID的系统是非常必要的。概括下来,那业务系统对ID号的要求有哪些呢? 全局唯一性:不能出现重复的ID号,既然是唯一标识,这是最基本的要求。...可以自定义max_id的大小,非常方便业务从原有的ID方式上迁移过来。 缺点: ID号码不够随机,能够泄露发号数量的信息,不太安全。...后台, 基础研发平台, 分布式, 唯一ID, 高可用, 高性能, 技术工程, 基础架构

    3.6K41

    游戏后台生成唯一ID

    游戏中的角色,装备,物品等需要生成一个全局唯一ID标识,便于辨别不同玩家,不同装备,也方便定位外网问题。...常见的分布式全局唯一ID生成方式包括使用数据库自增,使用Redis的原子操作INCR和INCRBY,使用UUID,SnowFlake算法等等。...前面两种方式均需要产生一次异步调用,在MMO中,海量玩家会集中在一个场景中进行PK,做任务,打怪等,场景内业务逻辑复杂,为了降低编码复杂度,减少BUG几率,通常会选择使用本地算法来生成全局唯一ID。...下面讲述一种MMO中的分布式ID生成方式,它会生成一个64位的整数ID,核心思想与SnowFlake类似。同时会根据游戏的特性对64位ID中的位段进行相应的调整。...在游戏部署上,我们会根据进程所在不同大区,不同功能,不同机器给线上部署的进程分配一个唯一的进程业务ID,这个进程业务ID的格式如下:WorldID.ZoneID.FuncID.InstID。

    2.8K00

    Mysql按条件计数的几种方法

    最近在给某网站的后台添加一系列的统计功能,遇到很多需要按条件计数的情况。尝试了几种方法,下面简要记录,供大家参考。 问题描述 为使讨论简单易懂,我将问题稍作简化,去掉诸多的背景。...数据库的结构如下: 字段 解释 id 皇子的唯一编号 mother 皇子母亲的唯一编号 皇帝把妃子分成了两个等级,天宫娘娘(编号小于25)和地宫娘娘(编号大于等于25),他想知道天宫娘娘们和地宫娘娘们的生育能力孰强孰弱...方法2:使用嵌套的SELECT 使用嵌套的SELECT也可以达到目的,在每个SELECT子句中统计一个条件下的数据,然后用一个主SELECT把这些统计数据整合起来。...,做到了分类计数。...缺点就是语句比较长,对语句长度有洁癖的同学可能会比较不舒服。 总结 对于确定分类的按条件计数,可以尽量不用GROUP BY,从而避免排序动作,加速Query的执行。

    4.6K20

    移动设备(手机)的唯一ID详解

    iOS - 4.5+ (支持): 根据包名随机生成的设备标识号。注意:在设备重置后会重新生成。 ? 移动设备(手机)的唯一ID有哪些 在移动广告领域,设备的ID 是用来追踪一个人的最重要的标识。...对于与外部数据打通而言,移动设备ID 是能与公司外的数据进行打通、交换、补充的唯一性ID,也是市场上大家都认可的ID。...既然移动设备ID 如此的重要,那我们就来聊一聊,有哪些ID我们是可以使用的: 一、IMEI IMEI是国际移动设备识别码,一串15位的号码,每部通过正规渠道销售的GSM手机均有唯一的IMEI码。...原苹果设备的唯一识别ID,它是40个字符组成。 1、IOS体系下:无法获取 在IOS旧版本可以使用,但在IOS7.0以后版本苹果停用了此ID,新版都无法获取。...六、其它 IDFV、openUDID、UUID IDFV是苹果设备给单个APP自身用于追踪用户的唯一ID,这个IDFV在一个APP内是唯一的,跨APP就不唯一了,因此只能用于单个APP自身用于追踪用户行为

    5.1K20

    雪花算法SnowFlake生成唯一ID

    这个算法的好处很简单可以在每秒产生约400W个不同的16位数字ID(10进制) 一、雪花算法原理解析 1. 分布式ID常见生成策略: 分布式ID生成策略常见的有如下几种: 数据库自增ID。...本文主要介绍SnowFlake 算法,是 Twitter 开源的分布式 id 生成算法。 其核心思想就是:使用一个 64 bit 的 long 型的数字作为全局唯一 id。...也就是同一毫秒内同一台机器所生成的最大ID数量为4096  简单来说,你的某个服务假设要生成一个全局唯一 id,那么就可以发送一个请求给部署了 SnowFlake 算法的系统,由这个 SnowFlake...算法系统来生成唯一 id。...(pow(2,9) - 1 + $machineId); //毫秒类的计数 $random = mt_rand(1, pow(2,11)-1); $random

    1.8K10

    唯一ID生成算法剖析

    引 在业务开发中,大量场景需要唯一ID来进行标识:用户需要唯一身份标识;商品需要唯一标识;消息需要唯一标识;事件需要唯一标识…等等,都需要全局唯一ID,尤其是分布式场景下。...按照我的分析有以下特性: 唯一性:生成的ID全局唯一,在特定范围内冲突概率极小 有序性:生成的ID按某种规则有序,便于数据库插入及排序 可用性:可保证高并发下的可用性 自主性:分布式环境下不依赖中心认证即可自行生成...UUID算法的目的是为了生成某种形式的全局唯一ID来标识系统中的任一元素,尤其在分布式环境下,该ID需要不依赖中心认证即可自动生成全局唯一ID。...中,时间值是一个60位的整型值,对应UTC的100ns时间间隔计数,因此其支持支持一台机器每秒生成10M次。...各种方案都有其优缺点,技术的使用没有绝对的好坏之分,主要在于是否适合使用场景: 要求生成全局唯一且不会重复ID,不关心顺序 —— 使用基于时间的UUID(如游戏聊天室中不同用户的身份ID) 要求生成唯一

    3.6K51

    Go全局唯一ID选型集合

    相对于UUID来说,雪花算法不会暴露MAC地址更安全、生成的ID也不会过于冗余。雪花的一部分ID序列是基于时间戳的,那么时钟回拨的问题就来了。 上面提到的xid,一定程度上避免的时钟回拨的影响。...在流量较大的场景下,网络耗时也可能成为瓶颈。 ZooKeeper唯一ID ZooKeeper是使用了Znode结构中的Zxid实现顺序增ID。...Zookeeper类似一个文件系统,每个节点都有唯一路径名(Znode),Zxid是个全局事务计数器,每个节点发生变化是都会记录响应的版本(Zxid),这个版本号是全局唯一且顺序递增的。...这种架构还是出现了ZooKeeper的单点问题。 号段模式 Leaf-segment 把数据库自增主键换成了计数法。...实现方案 使用Zookeeper顺序增、全局唯一的节点版本号,替换了原有的机器地址。解决了时钟回拨的问题。 前面介绍ZooKeeper的缺点,强依赖ZooKeeper、大流量下的网络瓶颈。

    65620

    UniqGenerator - 生成唯一ID技术方案

    令牌和租约 参与分配唯一ID的机器都需要取得一个令牌,这是它能分配唯一ID的先决条件。令牌是一种有限的资源,获取令牌的方式是租约。...唯一性 怎么做到ID的唯一性?协议将根本下图所示的这样一个思路进行设计。 3.3. ...结构 通过下图所示的结构,即可保证产生的ID在系统内部具有绝对的唯一性(本设计方案不能保证不同系统间的ID也能绝对唯一): 针对不同需要,将结构划分成3种类型(但可以根据需求继续扩充):...有状态数字型 当需要为第一条留言或评论分配一个唯一的ID时,则可以使用有状态的数字型ID,一个8字节的无符号整数,程序处理起来也非常便利。...Agent 唯一ID由Agent产生,并提供多种形式的获取接口(如HTTP取唯一ID、RPC取唯一ID等)。

    98310

    移动设备(手机)的唯一ID有哪些

    在移动广告领域,设备的ID 是用来追踪一个人的最重要的标识。 对于APP自身产品而言,使用设备唯一ID可以追踪到用户从下载到激活、注册、使用、流失、回归的全流程数据,对产品运营工作非常有帮助。...对于与外部数据打通而言,移动设备ID 是能与公司外的数据进行打通、交换、补充的唯一性ID,也是市场上大家都认可的ID。...既然移动设备ID 如此的重要,那我们就来聊一聊,有哪些ID我们是可以使用的: 一、IMEI IMEI是国际移动设备识别码,一串15位的号码,每部通过正规渠道销售的GSM手机均有唯一的IMEI码。...三、UDID 原苹果设备的唯一识别ID,它是40个字符组成。 1、IOS体系下:无法获取 在IOS旧版本可以使用,但在IOS7.0以后版本苹果停用了此ID,新版都无法获取。...六、其它 IDFV、openUDID、UUID IDFV 是苹果设备给单个APP自身用于追踪用户的唯一ID,这个IDFV在一个APP内是唯一的,跨APP就不唯一了,因此只能用于单个APP自身用于追踪用户行为

    1.9K20

    python使用UUID库生成唯一ID

    (UUID) URN Namespace》 概述: UUID 是128位的全局唯一标识符,通常由32字节的字符串表示。...IDentifier C# 中叫 GUID 它通过MAC地址、时间戳、命名空间、随机数、伪随机数来保证生成ID的唯一性。...可以保证全球范围内的唯一性,但MAC的使用同时带来安全性问题,局域网中可以使用IP来代替MAC。...3、uuid3()——基于名字的MD5散列值 通过计算名字和命名空间的MD5散列值得到,保证了同一命名空间中不同名字的唯一性,和不同命名空间的唯一性,但同一命名空间的同一名字生成相同的uuid。...可以忽略; 其次,uuid4存在概率性重复,由无映射性,最好不用; 再次,若在Global的分布式计算环境下,最好用uuid1; 最后,若有名字的唯一性要求,最好用uuid3或uuid5。

    1.1K10

    Redis实战9-全局唯一ID

    id的唯一性。...全局ID生成器全局ID生成器,是一种在分布式系统下用来生成全局唯一的ID工具,一般需要瞒住下列特性:唯一性、高可用、递增性、安全性、高性能全局唯一ID生成策略:UUID、Redis自增长、雪花算法、数据库自增...Redis自增ID策略:1:每天一个key,方便统计订单量;2:ID都在是时间戳+计数器实战:基于Redis拼接其他信息来实现全局唯一ID全局唯一ID使用long类型的,其中时间戳是基于某一个时间点开始的...注意:我们再来看看全局唯一ID的格式。如上图,我们可以看出,共64位,其中符号位是1个,时间戳是31位。序列号是32位,发现什么了吗?如果我们把时间戳向左移动32位(因为序列号是32位。...2:我们还需要知道,在计算机中 | 或计算:按位或运算“|”根据上面,我们可以知道位运算序号后,就是序列号的值。序列号是多少,就是多少。

    1.3K40

    分布式系统中唯一 ID 的生成

    几乎我见过的所有大型系统中,都需要一个唯一 ID 的生成逻辑。...别看小小的 ID,需求和场景还挺多: 这个 ID 多数为数字,但有时候是数字字母的组合; 可能随机,也可能要求随时间严格递增; 有时 ID 的长度和组成并不重要,有时候却要求它严格遵循规则,或者考虑可读性而要求长度越短越好...有多台 application 的 host,但是只有一个数据库。本质上这是耍了个小赖皮,把某分布式系统唯一 ID 的生成逻辑寄托到一个特定的数据库上,于是分布式系统存在中心节点了。...比如我见过这样的逻辑,用 host 的唯一编号来作前缀(保证环境中节点编号的唯一性即可),毫秒数来生成 ID 的主体部分。看似简单,一样可以解决唯一 ID 的问题。...在分布式系统中,它比前面说的方案有更多优势,比如长度一致,比如没有一个毫秒内最多只能生成一个的要求。但是,尽管可以认为它是唯一的,基于随机数产生的 UUID 冲突却是理论上可能存在的。

    67010

    分布式唯一ID的生成方案

    分布式ID的特性 全局唯一 不能出现重复的ID,这是最基本的要求。 递增 有利于关系数据库索引性能。 高可用 既然是服务于分布式系统,为多个服务提供ID服务,访问压力一定很大,所以需要保证高可用。...信息安全 如果ID是有规律的,就容易被恶意操作,在一些场景下需要ID无规则。 生成方案 UUID 核心思想是结合机器的网卡、当地时间、一个随机数来生成。 优点: 性能非常高,本地生成,没有网络消耗。...Redis Redis 提供了自增的原子命令,可以保证唯一、有序。 优点: 简单,自有能力。 高并发环境下性能好,优于数据库。 维护成本低于数据库。 缺点: 主从切换时也可能会重复发号。...雪花算法 给每台机器分配一个唯一标识,然后通过下面的结构实现全局唯一ID: 时间戳 + 机器标识 + 自增序列号 毫秒在高位,自增序列在低位,一定是递增的。 优点: 生成性能高。...例如在美团早期,ID方案就是多种形式的: 有的业务通过 DB 自增的方式生成 有的业务通过 Redis 缓存来生成 有的业务直接用 UUID 生成 后来推出了一个类雪花算法的分布式ID服务:Leaf,QPS

    71810
    领券