Java程序连接KingbaseES 异常
错误信息:
--KStudio客户端工具错误信息
The conncetion attempt failed.Reason:connect time out
--Java应用程序控制台日志
Caused by :java.net.SocketTimeoutException: connect time out
at java.net.DualStackPlainSocketImpl.waitForConnect(Native Method)
at java.net.DualStackPlainSocketImpl.socketConnect(Unknown Source)
问题现象:
Navicat客户端工具可以正常连接KingbaseES数据库,Navicat客户端工具连接数据库未使用jdbc驱动。而使用jdbc驱动的Java应用程序及KStudio客户端工具不能正常连接KingbaseES数据库。
排查过程:
同样是远程跨主机访问数据库,Navicat客户端工具连接数据库未使用jdbc驱动程序,可以正常连接KingbaseES数据库,说明问题原因跟网络和防火墙没有关系。
通过Java应用程序控制台日志发现客户端/应用程序在尝试使用IPv6,但是网络环境不支持IPv6,所以无法建立连接。
Caused by :java.net.SocketTimeoutException: connect time out
at java.net.DualStackPlainSocketImpl.waitForConnect(Native Method)
at java.net.DualStackPlainSocketImpl.socketConnect(Unknown Source)
通过以下网址得知,在使用VPN连接的环境部分VPN软件会导致Java应用jdbc驱动默认使用IPv6,不使用IPv4。
https://docs.oracle.com/javase/7/docs/webnotes/tsg/TSG-Desktop/html/plugin.html
Network Configuration
In general, Java Web Start applications use the system network configuration by default, and applets use the browser network settings. You can set network proxies explicitly using Java Control Panel.
In particular, the Java technology networking layer automatically detects what networking stack to use. However, sometimes autodetection does not work and you may observe "Permission Denied" exceptions trying to open a socket to download your application or applet, even while the same URL is accessible using the same proxy settings with other tools. This problem was observed on some Windows 7 systems when VPN software is used. This can be resolved by explicitly passing a parameter to the JVM:
-Djava.net.preferIPv4Stack=true
See the section on how to pass parameters to JVM for details.
通过询问同事得知,连接有问题的环境确实有在使用VPN(Easy connect )软件。
在Java代码添加System.setProperty("java.net.preferIPv4Stack","true"); 添加后可以正常运行Java应用。
到此基本可以确定,问题出现原因主要就是由于使用VPN软件导致不能正常建立IPv6连接,Java程序又尝试使用IPv6导致。
可以通过显式设置jvm参数 -Djava.net.preferIPv4Stack=true,使Java应用程序优先使用IPv4来解决此问题。
解决方法:
在KStudio客户端工具配置文件kstudio.ini 加入 -Djava.net.preferIPv4Stack=true 问题解决。
Java应用程序解决方法:
禁用系统IPv6.
设置Java系统属性
在Java应用程序代码里面添加 System.setProperty("java.net.preferIPv4Stack","true");
使用java -jar 启动Java应用时,增加参数 -Djava.net.preferIPv4Stack=true
设置环境变量_JPI_VM_OPTIONS和_JAVA_OPTIONS -Djava.net.preferIPv4Stack=true
设置开发工具IDEA 的vm options -Djava.net.preferIPv4Stack=true
添加环境变量
windows系统 set "JAVA_OPTS=%JAVA_OPTS% -Djava.net.preferIPv4Stack=true"
Linux系统 export _JAVA_OPTIONS="-Djava.net.preferIPv4Stack=true"
关于参数 java.net.preferIPv4Stack
官方文档解释:
If IPv6 is available on the operating system, the underlying native socket will be an IPv6 socket. This allows Java applications to connect to, and accept connections from, both IPv4 and IPv6 hosts.
java.net.preferIPv4Stack=false
在支持IPv6的双栈系统上,使用Java的Socket会默认通过底层native方法创建一个IPv6 Socket,这个IPv6 Socket可以同时支持和IPv4或IPv6主机通信。
java.net.preferIPv4Stack=true
如果设置为true,Java程序将无法使用IPv6进行网络通信,也就是仅支持IPv4。通过IPv6访问就会访问不通。
通过以下代码获取默认优先使用IPv4还是IPv6
System.out.println(InetAddress.getByName("[www.aliyun.com](http://www.aliyun.com)"));
Java程序连接KingbaseES 异常的更多相关文章
- Core Java 总结(异常类问题)
所有代码均在本地编译运行测试,环境为 Windows7 32位机器 + eclipse Mars.2 Release (4.5.2) 2016-10-17 整理 下面的代码输出结果是多少?为什么?并由 ...
- 【Java心得总结二】浅谈Java中的异常
作为一个面向对象编程的程序员对于 下面的一句一定非常熟悉: try { // 代码块 } catch(Exception e) { // 异常处理 } finally { // 清理工作 } 就是面向 ...
- Atitit 跨平台异常处理(2)--------异常转换 -----java c# js异常对象结构比较and转换
Atitit 跨平台异常处理(2)--------异常转换 -----java c# js异常对象结构比较and转换 { "@type":"java.lang.Runti ...
- 关于java中的异常问题 1
1.首先参考一下关于java异常处理方面的知识 查看博客http://lavasoft.blog.51cto.com/62575/18920/ 这里介绍的很好,下面从中学习到一些东西,摘抄如下: 1. ...
- Java中的异常-Throwable-Error-Exception-RuntimeExcetpion-throw-throws-try catch
今天在做一个将String转换为Integer的功能时,发现Integer.parseInte()会抛出异常NumberFormatException. 函数Integer.parseInt(Stri ...
- Java throw:异常的抛出怎么回事
到目前为止,你只是获取了被Java运行时系统抛出的异常.然而,程序可以用throw语句抛出明确的异常.Throw语句的通常形式如下: throw ThrowableInstance;这里,Thr ...
- [改善Java代码] 提倡异常的封装
JavaAPI提供的异常都是比较低级别的,低级别是指只有开发人员才能看懂的异常.而对于终端用户来说基本上就是天书,与业务无关,是纯计算机语言的描述. 异常封装的三方面的好处: 1)提高系统的友好性 ...
- java学习一目了然——异常必知
java学习一目了然--异常必知 我们只要学java,异常肯定非常熟悉,该抛的时候抛一下就行.但是这其中还有点小细节需要注意.就用这个小短篇来说一下异常处理中的小细节吧. 异常处理 RuntimeEx ...
- Java基础笔记-异常
Java中的异常机制: Throwable类是 Java 语言中所有错误或异常的超类.主要包括两个子类: Error和Exception. 一般中要处理的异常是Exception. Java中最常见的 ...
- getActionBar().setTitle(); Java.lang.NullPoint异常解决方案
getActionBar().setTitle(); Java.lang.NullPoint异常解决方案,是由于低版本不支持直接获取的缘故,修改方案: try changing your theme ...
随机推荐
- Js中数组空位问题
Js中数组空位问题 JavaScript中数组空位指的是数组中的empty,其表示的是在该位置没有任何值,而且empty是区别于undefined的,同样empty也不属于Js的任何数据类型,并且在J ...
- 关于dpi awareness 的清单文件设置
要设置dpi 意识,一般是使用SetProcessDpiAwareness(PROCESS_PER_MONITOR_DPI_AWARE)来设置 具体可参考:Setting the default DP ...
- [Revit二次开发] 使用过滤器时,可能存在的坑:FilteredElementCollector.MoveNext()报错
1.问题描述 在使用FilteredElementCollector时,如果涉及到需要对collector进行多次过滤处理,可能会出现MoveNext的报错. 问题代码如下: 1 var collec ...
- 硬件开发笔记(三):硬件开发基本流程,制作一个USB转RS232的模块(二):设计原理图库
前言 上一篇了解了基本的过程,选型了相关的芯片,本篇描述原理图的设计过程,在原理图设计之前或者过程中需要不断新增原理图元器件. Allegro.OrCad Cadence公司针对PCB方面 ...
- Python函数每日一讲 - 一文让你彻底掌握Python中的frozenset函数
引言 在 Python 中,frozenset() 函数是一个重要的工具,用于创建不可变的集合对象.本文将介绍 frozenset() 函数的语法.用法示例以及实际应用场景,帮助大家更好地理解和应用这 ...
- 【Azure 环境】标准版 Logic App 如何查看 Workflow的执行成功数和失败数的指标呢?
问题描述 在Azure中创建逻辑应用(Logic App),有两种计划类型.一是消费型,另一种是标准型. 在消费型的Logic App Metrics页面中,我们可以看见Workflow的执行成功数指 ...
- 分布式事务框架seata入门
一.简介 在近几年流行的微服务架构中,由于对服务和数据库进行了拆分,原来的一个单进程本地事务变成多个进程的本地事务,这时要保证数据的一致性,就需要用到分布式事务了.分布式事务的解决方案有很多,其中国内 ...
- [JS] 获取超星视频题答案
// 解除鼠标限制 var btnn = $(document.getElementById("iframe").contentWindow.document.getElement ...
- 想做大模型开发前,先来了解一下MoE
为了实现大模型的高效训练和推理,混合专家模型MoE便横空出世. 大模型发展即将进入下一阶段但目前仍面临众多难题.为满足与日俱增的实际需求,大模型参数会越来越大,数据集类型越来越多,从而导致训练难度大增 ...
- DuiLib 一个window的皮肤库 C++ 项目,打包小,比较纯正主流的大制作
https://github.com/duilib/duilib 从 火柴 那个软件 发现的这个库