AIX上运行Jetty碰到A system call received a parameter that is not valid

Jetty在window上、linux上运行都没有问题,在AIX上运行碰到如下异常:

 

java.net.SocketException: A system call received a parameter that is not valid.
        at sun.nio.ch.Net.localInetAddress(Native Method)
        at sun.nio.ch.Net.localAddress(Net.java:185)
        at sun.nio.ch.SocketChannelImpl.localAddress(SocketChannelImpl.java:421)
        at sun.nio.ch.SocketAdaptor.getLocalAddress(SocketAdaptor.java:179)
        at java.net.Socket.getLocalSocketAddress(Socket.java:719)
        at org.eclipse.jetty.io.nio.ChannelEndPoint.<init>(ChannelEndPoint.java:68)
        at org.eclipse.jetty.io.nio.SelectChannelEndPoint.<init>(SelectChannelEndPoint.java:59)
        at org.eclipse.jetty.server.nio.SelectChannelConnector.newEndPoint(SelectChannelConnector.java:306)
        at org.eclipse.jetty.server.nio.SelectChannelConnector$ConnectorSelectorManager.newEndPoint(SelectChannelConnector.java:399)
        at org.eclipse.jetty.io.nio.SelectorManager$SelectSet.createEndPoint(SelectorManager.java:812)
        at org.eclipse.jetty.io.nio.SelectorManager$SelectSet.doSelect(SelectorManager.java:425)
        at org.eclipse.jetty.io.nio.SelectorManager.doSelect(SelectorManager.java:225)
        at org.eclipse.jetty.server.nio.SelectChannelConnector$1.run(SelectChannelConnector.java:268)
        at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:529)
        at java.lang.Thread.run(Thread.java:803)

 

网上查找类似问题:

http://www-01.ibm.com/support/docview.wss?uid=swg1PK42970

应该是IBM JDK的一个bug,只能升级JDK版本了

下载地址:http://www.ibm.com/developerworks/java/jdk/aix/service.html

安装过程:http://fxyc.iteye.com/blog/751084

 

APAR status

    *
      Closed as program error.

Error description

    *

      Error Message: java.net.SocketException: A system call received
      a parameter that is not valid.
      Stack Trace: java.lang.Error: java.net.SocketException: A system
      call received a parameter that is not valid.
       at sun.nio.ch.Net.localAddress(Net.java(Inlined Compiled Code))
       at
      sun.nio.ch.SocketChannelImpl.localAddress(SocketChannelImpl.java
      (Compiled Code))
       at
      sun.nio.ch.SocketAdaptor.getLocalAddress(SocketAdaptor.java:178)
       at java.net.Socket.getLocalSocketAddress(Socket.java:660)
       at
      com.ibm.ws.tcp.channel.impl.NBAcceptChannelSelector.performReque
      st(NBAcceptChannelSelector.java:271)
       at
      com.ibm.ws.tcp.channel.impl.ChannelSelector.run(ChannelSelector.
      java:233)
       at java.lang.Thread.run(Thread.java:570)
      .

Local fix

    *

Problem summary

    *

      getLocalSocketAddress, getLocalPort returns invalid argument.

Problem conclusion

    *

      This defect will be fixed in:
      1.4.2 SR9
      .
      As per java API doc getLocalSocketAddress() and getLocalPort()
      should not throw any exception. If socket is not bound,
      getLocalPort returns -1 and null for getLocalSocketAddress.
      .
      To obtain the fix:
      Install build 20070613 or later
 

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值