26、【Ubuntu】【远程开发】内网穿透:密钥算法介绍(二)

【声明】本博客所有内容均为个人业余时间创作,所述技术案例均来自公开开源项目(如Github,Apache基金会),不涉及任何企业机密或未公开技术,如有侵权请联系删除

背景

上篇 blog
【Ubuntu】【远程开发】内网穿透:密钥算法介绍(一)

分析了 SSH 中支持的一些密钥算法类型,下面继续

内网穿透

上篇 blog 提到 RSA-3072 作为传统算法,是对标现代安全标准的底线 ,在 ssh-keygen 命令中关于设置密钥长度的选项 -b 的描述如下

可以看到,这里 -b 选项指定要生成的密钥长度(以 bit 为单位),但要注意,这个参数对不同算法的作用完全不同

  • rsa:最小长度 1024 位(不安全,别用 ),默认长度 3072 位(安全底线 ),比如如果要指定 rsa 算法的话,可以
bash 复制代码
ssh-keygen -t rsa -b 4096   # 显式指定 4096 位 RSA
ssh-keygen -t rsa           # 默认生成 3072 位
  • dsa必须正好是 1024 ,这是美国联邦政府发布的密码学老标准 FIPS Federal Information Processing Standards Publication 186-2 中强制规定的,该标准由 NIST 制定,是 FIPS 186 的第二次修订版本 ,即使写 -b 2048,OpenSSH 也会忽略或报错,因为传统 dsa 不支持更长,这里再次强调,dsa 已过时且不安全,不要使用
  • ecdsa:只能选 256默认 ),384(更安全),521(注意是 521,不是 512,最安全,但性能略低 )三个数字之一,如果写别的数字,比如是 -b 512 或者 -b 300命令会直接失败 ,还有,ecdsa-256 指的是椭圆曲线的域大小,不是传统意义上的密钥比特数 ,效果等效于 ASE-128 对称加密强度
  • ecdsa-sked25519ed25519-sk密钥长度固定 ,一般是 256 位,即使写别的数字,比如 -b 4096会被完全忽略

这里再额外说下 FIPS 186 的历史版本演进

  • FIPS 186:1994 年首次引入 dsa
  • FIPS 186-1:1998 年小修小补
  • FIPS 186-2:2000 年固定 dsa1024/160 位(大素数 p1024 位,小素数 q160 位),成为广泛引用的版本,可以说是 dsa 算法的黄金时代
  • FIPS 186-3:2009 年新增 rsaecdsa 支持,允许更长密钥,比如 dsa-2048/224dsa-3072/256
  • FIPS 186-4:2013 年进一步细化安全要求,推荐弃用 dsa-1024/160
  • FIPS 186-5:2023 年移除 dsa 完全不再推荐 ,因为 dsa 极度依赖一次性随机数,如果随机数被被重复使用,哪怕只一次,攻击者也可以通过两个签名直接解出私钥 ,此外,相比更好的现代方案 ed25519dsa 算法性能差,实现复杂,容易出错 ,实际生态也逐渐抛弃 dsa

可以看到, dsa 已经成为历史产物,在特定时期,完成了其历史使命

下面再提下 -t 选项的另一个作用

除了生成密钥,-t 选项还可以用在 RSA 证书颁发机构(CA)签署 SSH 证书时 ,指定签名算法类型,对于 RSA CA,有三种签名方式:

  • ssh-rsa:使用 SHA-1 哈希(已被认为不安全,不推荐
  • rsa-sha2-256:使用 SHA-256(安全)
  • rsa-sha2-512:使用 SHA-512(更安全,默认值

这种用法只在搭建 SSH 证书认证体系 (比如企业内部用 CA 统一签发 SSH 证书)时才需要指定 RSA 签名哈希算法 ,比如 -t rsa-sha2-512,普通用户一般用不到,普通用户一般就是拿来生成密钥-t 选项指定密钥算法 ,比如 -t ed25519-t rsa用途一个是签名,一个是生成密钥


OK,本篇先到这里,如有疑问,欢迎评论区留言讨论,祝各位功力大涨,技术更上一层楼!!!更多内容见下篇 blog
【Ubuntu】【远程开发】内网穿透:CA 签名

相关推荐
珠海西格电力18 小时前
西格电力零碳园区管理系统的技术架构是怎样的?
大数据·运维·人工智能·物联网·架构·能源
MAHATMA玛哈特科技18 小时前
矫平机的液压系统是干什么的?压下精度背后的控制逻辑
运维·服务器·校平机·矫平机·整平机
打码人的日常分享19 小时前
信息化数据安全管理制度办法(Word)
大数据·运维·网络·云计算·制造
Kingairy19 小时前
vi(vim)常用命令汇总
linux·编辑器·vim
li357419 小时前
深入理解 Linux eBPF 技术——从内核观测到可编程网络
linux·网络
电商API_1800790524719 小时前
技术分享:如何实现批量自动化获取淘宝商品视频主图API
运维·爬虫·数据挖掘·自动化
TG_yunshuguoji19 小时前
亚马逊云代理商:如何用 CloudWatch+Lambda 打造自动化告警系统
大数据·运维·自动化·云计算·aws
maosheng114619 小时前
网络综合项目(做个博客)
linux·服务器·网络
田里的水稻19 小时前
FA_IPC_协议网络(VRPN)数据交互三
linux·网络·网络协议·tcp/ip·机器人
Irissgwe19 小时前
6、传输层协议
linux·服务器·网络·传输层·udp协议