虚机运行pgjdbc-ng 客户端驱动创建数据库连接报超时错误

news/2025/2/6 15:57:16/文章来源:https://www.cnblogs.com/xpp-123/p/18701212

 

// debug 调试代码发现 CryptoUtil.nonce卡住,继续跟踪发现是random.nextInt方法阻塞。
public ScramSession start(String user) {String nonce = CryptoUtil.nonce(nonceLength, secureRandom); // return new ScramSession(scramMechanism,channelBindMethod, serverSupportsChannelBinding,stringPreparation,checkNotNull(user, "user"), nonce);}

public static String nonce(int size, SecureRandom random) {if (size <= 0) {throw new IllegalArgumentException("Size must be positive");}char[] chars = new char[size];int r;for (int i = 0; i < size; ) {r = random.nextInt(MAX_ASCII_PRINTABLE_RANGE - MIN_ASCII_PRINTABLE_RANGE + 1) + MIN_ASCII_PRINTABLE_RANGE;if (r != EXCLUDED_CHAR) {chars[i++] = (char) r;}}return new String(chars);}

// random是调用SecureRandom.getInstanceStrong()方法生成:
private Builder() throws NoSuchAlgorithmException {this.serverAdvertisedMechanisms = Collections.emptyList();this.channelBindMethod = null;this.preferChannelBindingOverAlgorithmStrength = false;this.stringPreparation = StringPreparations.NO_PREPARATION;this.nonceLength = DEFAULT_NONCE_LENGTH;this.secureRandom = SecureRandom.getInstanceStrong();}

在Java中,SecureRandom.getInstanceStrong()是用于获取安全的随机数生成器(SecureRandom)的方法。它使用强安全性提供者(Strong Security Provider)来获取一个实例,这通常是操作系统提供的本地安全实现。虽然这种方法提供了高质量的随机数生成器,但它有时可能导致系统响应变慢的问题。

SecureRandom.getInstanceStrong()可能需要在获取强安全性提供者的过程中进行耗时的操作,例如系统调用或硬件生成的随机数。这可能导致在某些情况下,特别是在具有低熵(entropy)的系统环境中,调用此方法时会出现较长的延迟。

Linux内核采用熵来描述数据的随机性,熵(entropy)是描述系统混乱无序程度的物理量,一个系统的熵越大则说明该系统的有序性越差,即不确定性越大。内核维护了一个熵池用来收集来自设备驱动程序和其它来源的环境噪音。

Linux系统中,随机数是通过/dev/random/dev/urandom这两个特殊的设备文件提供的。这些设备文件允许用户和应用程序获取系统的随机数据。这些设备文件利用系统的熵源(entropy source)来生成随机数,其中熵源是系统中的不可预测事件,如硬件中断、鼠标移动、键盘输入等。

以下是/dev/random/dev/urandom的主要区别以及关于它们的一些信息:

  • /dev/random/dev/random是一个阻塞设备,它会等待足够的熵积累后再提供输出。如果熵不够,读取/dev/random的操作可能会被阻塞,直到有足够的熵可用。这是为了确保生成的随机数具有更高的质量,因为/dev/random提供的是真正的随机数。
  • /dev/urandom/dev/urandom是一个非阻塞设备,它会立即提供随机数输出,即使熵源不足。当系统的熵源不足时,/dev/urandom仍然会生成伪随机数。这样,即使熵源不够,应用程序仍然能够获得随机数,但可能会牺牲一些质量。
  • 参考: SecureRandom.getInstanceStrong()导致的系统崩溃 - https://zhuanlan.zhihu.com/p/681631220

官方bug: https://github.com/impossibl/pgjdbc-ng/issues/567

SecureRandom.getInstanceStrong()导致的系统崩溃

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/879691.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

政采云业务网关实践:使用 Higress 统一替代 APISIX/Kong/Istio Ingress

技术栈统一是逐步达成的目标,不过从目前需要解决的问题紧急度上看,容器网关、业务网关需要合并,以一个技术栈解决网关配置治理、扩展能力的问题。经过社区活跃度、能力对比等多个维度的比较,最终筛选出 APISIX、Higress、Istio(IngressGateway)这三个网关服务。作者:政采…

03 配置测试、兼容测试

8.配置测试 8.1配置测试综述 1)个人计算机 2)部件 3)外设 4)接口 5)可选项和内存 6)设备驱动程序 8.1.1分离配置缺陷 软件缺陷和配置缺陷有可能造成软件出现问题。 8.2执行配置测试 1)确定所需配置类型 2)确定有哪些厂商的硬件、型号、和驱动程序可用 3)确定可能的硬件…

ThreeJs-13效果合成与后期处理

一.合成效果原理与设置 什么是效果合成,就是可以把一些效果经过后期处理再放出来 原来的物体是直接通过render渲染出来,而现在则是经过一条render通道,可以处理也可以叠加处理后再放出来首先正常加载模型首先导入效果合成器以及一些自带的效果创建合成效果渲染器,跟之前渲染…

解决Windows11可能出现的自动获取到错误的DNS地址问题

现象 当一个wifi再射中中配置了手动的DNS地址,如114.114.114.114/114.114.115.115,连接其他新wifi的时候,虽然默认自动获取DNS,但是获取的却不是路由配发的DNS,而是之前设置的114.114.114.114/114.114.115.115 解决方案 1、首先打开旧ui的网卡的设置,确定处于自动dns。2、…

docker在mac-m1芯片部署并启用tomcat

手把手教你使用docker在mac-m1芯片部署并启用tomcat 1,下载docker并安装 登陆官网下载dockr,选择mi芯片的docker下载 下载地址:https://www.docker.com/get-started 2,配置docker的阿里云加速器(也可以配置其他加速器) 在设置---docker engine 中添加阿里云的加速器 {&quo…

JS-51 事件代理(事件委托)

由于事件会在冒泡阶段向上传播到父节点,因此可以把子节点的监听函数定义在父结点上,由父节点的监听函数统一处理多个子元素的事件。这种方法叫做事件的代理(delegation)var ul =document.querySelector(ul);ul.addEventListenr(click,function(event){if(event.target.tagN…

docker搭建jenkins导入python包

title: docker搭建jenkins导入python包 tags: - docker - centos - jenkins categories: - docker1. 项目概述 2. 环境准备 3. 创建 Dockerfile 4. 创建 Docker Compose YAML 文件 services volumes5. 同级目录放requirements.txt 6. 启动 Jenkins 服务 7. 访问 Jenkins 8. 验…

普通人做短剧需要哪些证书?

短剧行业爆火,但在制作短剧需持有相关资质,否则就属于违规经营。不管是想在各大平台宣传推广,还是想上架小程序等途径都是要求三证齐全的。 那应该先取得什么样的资质才可以开展这项业务? 第一个就是增值电信业务经营许可证—ICP许可证这是从事互联网行业的基本要求,它的申…

DeepSeek如何在资源优化时做到了性能领先?

问题:DeepSeek如何在资源优化时做到了性能领先? DeepSeek V3的Benchmark如图3所示,该图显示DeepSeek V3在主要数据集测试时超越了业界LLM同类标杆的水平,这给了业界一个初步的惊喜,尤其是训练阶段花费了少于业界LLM同类标杆十分之一的代价:图3:DeepSeek V3如何以更少资源…

【ABAP】使用vscode+cline+deepseek进行abap的开发

声明:本文主要进行的是演示,实际项目中的应用还需要大家的探索 前置条件: 1. vscode 安装abap的插件 2. 注册deepseek的api key 或者 硅基流动的 apikey (最近deepseek遭受攻击不太稳定,推荐使用硅基流动的deepseek模型)deepseek api平台硅基流动注册 3. vscode安装clin…

vxe-table 如何实现全部单元格都能拖拽调整列宽,表头和表体都支持拖拽

vxe-table 如何实现全部单元格都能拖拽调整列宽,表头和表体都支持拖拽 官网:https://vxetable.cn 效果代码 通过 resizable-config.isAllColumnDrag 启用所有单元格允许拖拽调整列宽 <template><div><vxe-grid v-bind="gridOptions"></vxe-gr…

初探集群联邦

本文分享自天翼云开发者社区《初探集群联邦》,作者:echooo 一.什么是集群联邦?集群联邦(Federation)是将多个kubenetes集群注册到统一的控制平面,为用户提供统一API入口的多集群解决方案。集群联邦设计的核心是提供在全局层面对应用的描述能力,并将联邦对象实例化为kub…