2024年5月2日 Go生态洞察:Go 1.22中的安全随机性

2024-06-03 12:20

本文主要是介绍2024年5月2日 Go生态洞察:Go 1.22中的安全随机性,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


🌷🍁 博主猫头虎(🐅🐾)带您 Go to New World✨🍁

🦄 博客首页——🐅🐾猫头虎的博客🎐

专栏链接

🔗 精选专栏

  • 《面试题大全》 — 面试准备的宝典!
  • 《IDEA开发秘籍》 — 提升你的IDEA技能!
  • 《100天精通鸿蒙》 — 从Web/安卓到鸿蒙大师!
  • 《100天精通Golang(基础入门篇)》 — 踏入Go语言世界的第一步!
  • 《100天精通Go语言(精品VIP版)》 — 踏入Go语言世界的第二步!

领域矩阵

🌐 猫头虎技术领域矩阵
深入探索各技术领域,发现知识的交汇点。了解更多,请访问:

  • 猫头虎技术矩阵
  • 新矩阵备用链接

学会Golang语言,畅玩云原生,走遍大小厂~💐


在这里插入图片描述

文章目录

  • 2024年5月2日 Go生态洞察:Go 1.22中的安全随机性
    • 摘要 🌟
    • 引言 🚀
    • 正文 🌐
      • 统计随机性 🧩
        • Unix中的随机数生成器 🔍
      • Go 1生成器 ⚙️
      • PCG生成器 🌟
      • 加密随机性 🔐
      • ChaCha8Rand生成器 🚀
      • 性能比较 📊
    • 总结 📚
    • 参考资料 🔗
    • 下一篇预告 📢
    • QA 环节 🙋
    • 🐅🐾猫头虎建议Go程序员必备技术栈一览表📖:
  • 原创声明

  • 原创作者: 猫头虎

  • 作者wx: Libin9iOak

  • 作者公众号: 猫头虎技术团队

在这里插入图片描述

2024年5月2日 Go生态洞察:Go 1.22中的安全随机性

摘要 🌟

作为一个技术自媒体博主,我是猫头虎,今天我们来探讨Go 1.22在math/rand和crypto/rand之间的改进,如何通过使用加密随机数源改进了Go的随机性,减少了开发者误用math/rand而导致的安全隐患。📚🔍

引言 🚀

计算机并不随机。硬件设计师们非常努力地确保计算机每次都能以相同的方式运行每个程序。然而,当程序需要随机数时,这就需要额外的努力。传统上,计算机科学家和编程语言将随机数分为两种:统计随机数和加密随机数。在Go中,这分别由math/rand和crypto/rand提供。本文将探讨Go 1.22如何通过在math/rand中使用加密随机数源,使这两者更紧密地结合在一起,带来更好的随机性,并在开发者误用math/rand时减少了损害。

正文 🌐

统计随机性 🧩

统计随机数通过基本的统计测试通常适用于仿真、采样、数值分析、非加密的随机算法、随机测试、输入洗牌和随机指数回退。非常基本、易于计算的数学公式在这些用例中表现良好。然而,这些方法非常简单,知道使用的算法的观察者通常可以在看到足够的值后预测序列的其余部分。

Unix中的随机数生成器 🔍

几乎所有编程环境都提供了生成统计随机数的机制,这可以追溯到C语言和Research Unix第三版(V3),该版本增加了一对函数:srand和rand。以下是用现代C语言翻译的生成器源代码:

uint16 ranx;void srand(uint16 seed) {ranx = seed;
}int16 rand(void) {ranx = 13077 * ranx + 6925;return ranx & ~0x8000;
}

调用srand函数用单个整数种子对生成器进行播种,rand函数返回生成器的下一个数值。这种生成器被称为线性同余生成器(LCGs),尽管有已知的问题,但它们仍被广泛使用。

Go 1生成器 ⚙️

Go 1中的math/rand使用了一种线性反馈移位寄存器生成器。其内部状态是607个uint64组成的切片。生成下一个随机数的算法如下:

func (r *rngSource) Uint64() uint64 {r.tap--if r.tap < 0 {r.tap += len(r.vec)}r.feed--if r.feed < 0 {r.feed += len(r.vec)}x := r.vec[r.feed] + r.vec[r.tap]r.vec[r.feed] = xreturn uint64(x)
}

生成下一个数值的过程非常便宜:两个减法、两个条件加法、两个加载、一个加法和一个存储。然而,由于生成器直接返回其内部状态向量中的一个切片元素,读取607个值即可完全暴露其状态,从而可以预测所有未来的值。

PCG生成器 🌟

在math/rand/v2中,我们使用了Melissa O’Neill在2014年发布的PCG算法。以下是PCG生成器的代码示例:

const (pcgM = 0x2360ed051fc65da44385df649fccf645pcgA = 0x5851f42d4c957f2d14057b7ef767814f
)type PCG struct {x uint128
}func (p *PCG) Uint64() uint64 {p.x = p.x * pcgM + pcgAreturn scramble(p.x)
}func scramble(x uint128) uint64 {hi, lo := uint64(x >> 64), uint64(x)hi ^= hi >> 32hi *= 0xda942042e4dd58b5hi ^= hi >> 48hi *= lo | 1
}

PCG生成器使用更少的状态,且对初始值的敏感性较低,能通过许多统计测试,是一种理想的统计生成器。

加密随机性 🔐

加密随机数需要在实际中完全不可预测,即使观察者知道它们的生成方式并且已经观察到生成的任意数量的值。提供加密随机性的最终任务是操作系统,它可以从物理设备中收集真正的随机性,如鼠标、键盘、磁盘和网络的时序,以及CPU本身测量的电噪声。

ChaCha8Rand生成器 🚀

我们的新生成器ChaCha8Rand基于Daniel J. Bernstein的ChaCha流密码,是math/rand/v2中的rand.ChaCha8的实现。其关键特性如下:

  1. ChaCha8Rand使用32字节种子,作为ChaCha8的密钥。
  2. ChaCha8生成64字节的块,并将块作为16个uint32进行处理。
  3. 每生成16个块,ChaCha8Rand将最后32字节作为下一个16个块的密钥,实现了前向安全性。

以下是ChaCha8Rand的实现示例:

func scramble(x uint128) uint64 {hi, lo := uint64(x>>64), uint64(x)hi ^= hi >> 32hi *= 0xda942042e4dd58b5hi ^= hi >> 48hi *= lo | 1
}

性能比较 📊

ChaCha8Rand在性能上稍逊于Go 1生成器,但在现代服务器上差异不超过3ns,大多数程序不会因此成为瓶颈,而许多程序将受益于改进的安全性。

生成器Uint64速度(ns)N(1000)速度(ns)
Go 1生成器1.83.2
PCG生成器2.12.4
ChaCha8Rand2.42.7

总结 📚

Go 1.22通过加强math/rand,使程序更安全而无需更改代码。这是Go持续确保程序默认安全的一小步。

参考资料 🔗

  • Russ Cox, Filippo Valsorda. Secure Randomness in Go 1.22. May 2, 2024.

下一篇预告 📢

下一篇文章将探讨如何在Go 1.22中确保随机数生成器的安全性,敬请期待!


知识点说明
统计随机性Unix和Go 1生成器的分析
PCG生成器新算法及其优点
加密随机性操作系统的角色及实现
ChaCha8Rand新生成器的详细实现
性能比较三种生成器的性能对比

QA 环节 🙋

Q1: 为什么需要ChaCha8Rand生成器?

A1: ChaCha8Rand生成器结合了统计和加密随机性的优点,提高了安全性,并减少了误用带来的安全隐患。

Q2: PCG生成器有哪些优点?

A2: PCG生成器使用更少的状态,对初始值不敏感,通过了许多统计测试,是理想的统计生成器。

Q3: 如何在程序中使用ChaCha8Rand生成器?

A3: 可以直接创建rand.ChaCha8实例,或使用math/rand/v2中的顶层函数。

通过这篇博客,希望大家能够更好地理解和应用Go 1.22中的安全随机性。感谢阅读!👋

在这里插入图片描述

🐅🐾猫头虎建议Go程序员必备技术栈一览表📖:

☁️🐳 Go语言开发者必备技术栈☸️:
🐹 GoLang | 🌿 Git | 🐳 Docker | ☸️ Kubernetes | 🔧 CI/CD | ✅ Testing | 💾 SQL/NoSQL | 📡 gRPC | ☁️ Cloud | 📊 Prometheus | 📚 ELK Stack


🪁🍁 希望本文能够给您带来一定的帮助🌸文章粗浅,敬请批评指正!🐅🐾🍁🐥

原创声明


  • 原创作者: 猫头虎

  • 作者wx: Libin9iOak
    在这里插入图片描述

  • 作者公众号: 猫头虎技术团队

在这里插入图片描述

学习复习Go生态

本文为原创文章,版权归作者所有。未经许可,禁止转载、复制或引用。

作者保证信息真实可靠,但不对准确性和完整性承担责任

未经许可,禁止商业用途。

如有疑问或建议,请联系作者。

感谢您的支持与尊重。

点击下方名片,加入猫头虎领域矩阵。一起探索科技的未来,洞察Go生态,共同成长。

🔗 猫头虎社群 | 🔗 Go语言VIP专栏| 🔗 GitHub 代码仓库 | 🔗 Go生态洞察专栏

这篇关于2024年5月2日 Go生态洞察:Go 1.22中的安全随机性的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1026977

相关文章

Golang基于内存的键值存储缓存库go-cache

《Golang基于内存的键值存储缓存库go-cache》go-cache是一个内存中的key:valuestore/cache库,适用于单机应用程序,本文主要介绍了Golang基于内存的键值存储缓存库... 目录文档安装方法示例1示例2使用注意点优点缺点go-cache 和 Redis 缓存对比1)功能特性

Go 1.23中Timer无buffer的实现方式详解

《Go1.23中Timer无buffer的实现方式详解》在Go1.23中,Timer的实现通常是通过time包提供的time.Timer类型来实现的,本文主要介绍了Go1.23中Timer无buff... 目录Timer 的基本实现无缓冲区的实现自定义无缓冲 Timer 实现更复杂的 Timer 实现总结在

Go使用pprof进行CPU,内存和阻塞情况分析

《Go使用pprof进行CPU,内存和阻塞情况分析》Go语言提供了强大的pprof工具,用于分析CPU、内存、Goroutine阻塞等性能问题,帮助开发者优化程序,提高运行效率,下面我们就来深入了解下... 目录1. pprof 介绍2. 快速上手:启用 pprof3. CPU Profiling:分析 C

使用Go语言开发一个命令行文件管理工具

《使用Go语言开发一个命令行文件管理工具》这篇文章主要为大家详细介绍了如何使用Go语言开发一款命令行文件管理工具,支持批量重命名,删除,创建,移动文件,需要的小伙伴可以了解下... 目录一、工具功能一览二、核心代码解析1. 主程序结构2. 批量重命名3. 批量删除4. 创建文件/目录5. 批量移动三、如何安

Go路由注册方法详解

《Go路由注册方法详解》Go语言中,http.NewServeMux()和http.HandleFunc()是两种不同的路由注册方式,前者创建独立的ServeMux实例,适合模块化和分层路由,灵活性高... 目录Go路由注册方法1. 路由注册的方式2. 路由器的独立性3. 灵活性4. 启动服务器的方式5.

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

Go Mongox轻松实现MongoDB的时间字段自动填充

《GoMongox轻松实现MongoDB的时间字段自动填充》这篇文章主要为大家详细介绍了Go语言如何使用mongox库,在插入和更新数据时自动填充时间字段,从而提升开发效率并减少重复代码,需要的可以... 目录前言时间字段填充规则Mongox 的安装使用 Mongox 进行插入操作使用 Mongox 进行更

Go语言利用泛型封装常见的Map操作

《Go语言利用泛型封装常见的Map操作》Go语言在1.18版本中引入了泛型,这是Go语言发展的一个重要里程碑,它极大地增强了语言的表达能力和灵活性,本文将通过泛型实现封装常见的Map操作,感... 目录什么是泛型泛型解决了什么问题Go泛型基于泛型的常见Map操作代码合集总结什么是泛型泛型是一种编程范式,允

基于Go语言实现一个压测工具

《基于Go语言实现一个压测工具》这篇文章主要为大家详细介绍了基于Go语言实现一个简单的压测工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理客户端模块Http客户端处理Grpc客户端处理Websocket客户端

浅析Rust多线程中如何安全的使用变量

《浅析Rust多线程中如何安全的使用变量》这篇文章主要为大家详细介绍了Rust如何在线程的闭包中安全的使用变量,包括共享变量和修改变量,文中的示例代码讲解详细,有需要的小伙伴可以参考下... 目录1. 向线程传递变量2. 多线程共享变量引用3. 多线程中修改变量4. 总结在Rust语言中,一个既引人入胜又可