当前位置:
首页
文章
后端
详情

Java 中的一个糟糕的默认超时设置 Infinity

许多库包装了一些外部通信。无论是类 REST 的 API、消息队列、数据库、邮件服务器还是其他东西。因此,您必须有一些超时时间——用于连接、读取、写入或空闲。遗憾的是,许多库的默认超时设置为“0”或“-1”,这意味着无穷大

这是一个非常无用甚至有害的默认设置。没有一个实际用例让您希望永远等待资源。并且有很多情况会发生这种情况,例如另一端卡住了。在过去的 3 个月里,我有 2 个库的默认超时为“无穷大”,最终导致生产问题,因为我们忘记了正确配置它们。有时您甚至看不到问题,直到线程池耗尽。

永远不要将“Inifinty”作为默认超时。因为,您的库会导致许多生产问题。还要注意,有时底层的 HTTP 客户端(或 Socket)没有合理的默认值——在包装它时修复它仍然是你的工作。

您应该提供什么默认值?合理的。5秒可以吗?您可能说您不想对用户强加任意超时。在这种情况下,我有一个更好的建议:

明确要求构建“客户端”超时(因为这些库通常是某些外部系统的客户端)。例如​Client.create(url, credentials, timeout)​。如果没有提供超时,则失败。这使得客户端的用户积极考虑他们的用例什么是好的超时 - 不强加任何东西,最重要的是 - 不会冒生产中连接卡住的风险。此外,您仍然可以向他们提供“默认”选项,但仍让他们明确选择它。例如:

Client client = ClientBuilder.create(url)
                   .withCredentials(credentials)
                   .withTimeouts(Timeouts.connect(1000).read(1000))
                   .build();
// OR
Client client = ClientBuilder.create(url)
                   .withCredentials(credentials)
                   .withDefaultTimeouts()
                   .build();

上面的构建器应该要求设置“timeout”,如果两个方法都没有被调用,则应该失败。即使你不提供这些选项,至少有一个指定超时的好方法——一些库需要反射来设置其底层客户端的超时。

我相信这是那些看起来很小但在现实世界中会导致很多问题的问题之一。它可以(并且应该)由库/客户端设计者解决。

但由于情况并非总是如此,我们必须确保每次使用 3rd 方库时都配置超时。


免责申明:本站发布的内容(图片、视频和文字)以转载和分享为主,文章观点不代表本站立场,如涉及侵权请联系站长邮箱:xbc-online@qq.com进行反馈,一经查实,将立刻删除涉嫌侵权内容。

同类热门文章

深入了解C++中的new操作符:使用具体实例学习

C++中的new操作符是动态分配内存的主要手段之一。在程序运行时,我们可能需要动态地创建和销毁对象,而new就是为此提供了便利。但是,使用new也常常会引发一些问题,如内存泄漏、空指针等等。因此,本文将通过具体的示例,深入介绍C++中的new操作符,帮助读者更好地掌握其使用。


深入了解C++中的new操作符:使用具体实例学习

怎么用Java反射获取包下所有类? 详细代码实例操作

Java的反射机制就是在运行状态下,对于任何一个类,它能知道这个类的所有属性和方法;对于任何一个对象,都能调用这个对象的任意一个方法。本篇文章将通过具体的代码示例,展示如何通过Java反射来获取包下的所有类。


怎么用Java反射获取包下所有类? 详细代码实例操作

员工线上学习考试系统

有点播,直播,在线支付,三级分销等功能,可以对学员学习情况的监督监控,有源码,可二次开发。支持外网和局域网私有化部署,经过测试源码完整可用!1、视频点播:视频播放,图文资料,课件下载,章节试学,限时免

员工线上学习考试系统

了解Java中的volati关键字的作用 以及具体使用方法

本篇文章将和大家分享一下Java当中的volatile关键字,下面将为各位小伙伴讲述volatile关键字的作用以及它的具体使用方法。


了解Java中的volati关键字的作用 以及具体使用方法

Java Map 所有的值转为String类型

可以使用 Java 8 中的 Map.replaceAll() 方法将所有的值转为 String 类型: 上面的代码会将 map 中所有的值都转为 String 类型。 HashMap 是 Java

Java Map 所有的值转为String类型