3

カスタム セキュリティ ポリシーを備えた Java アプリがあり、100 個の udp ソケットを開こうとしたときに例外が発生しました。

java.net.SocketException: maximum number of DatagramSockets reached

テストアプリ:

import java.net.DatagramSocket;
import java.net.Inet4Address;
import java.util.ArrayList;
import java.util.List;   

public class Test {
    static int basePortNum = 40000; 
    public static void main(String[] args) {
        List<DatagramSocket> socks = new ArrayList<DatagramSocket>();
        try{
            for(int i = 0; i<100; i++){
                socks.add(new DatagramSocket(basePortNum+i, Inet4Address.getByName("127.0.0.1")) );
                System.out.println(i);
            }
        }catch(Exception e){
            e.printStackTrace();
        }finally{
            for(java.net.DatagramSocket soc: socks){
                soc.close();
            }
        }    
    }    
}

セキュリティ マネージャなしで起動すると、100 ソケットすべてが作成されます。

0
1
...
98
99

しかし、この行を VM 引数に追加すると

-Djava.security.manager

デフォルトのセキュリティ ポリシーでも失敗します。

0
1
...
23
24
java.net.SocketException: maximum number of DatagramSockets reached
    at sun.net.ResourceManager.beforeUdpCreate(ResourceManager.java:53)
    at java.net.PlainDatagramSocketImpl.create(PlainDatagramSocketImpl.java:74)
    at java.net.DatagramSocket.createImpl(DatagramSocket.java:318)
    at java.net.DatagramSocket.<init>(DatagramSocket.java:209)
    at java.net.DatagramSocket.<init>(DatagramSocket.java:262)
    at Test.main(Test.java:16)

セキュリティマネージャの使用中にソケット制限を変更するにはどうすればよいですか?

UPD: Windows 8.1 x64、Windows 7 x64、および Windows XP SP3 x32、Windows 7 x32 で再現されました。すべてのシステムで、JDK 1.6.45 x32 が使用されました。

UPD2: Windows XP SP3 x32 では JDK7 でも再現されますが、JDK 1.6.27 ではこれを再現できません。

UPD3: JDK クラスのデバッグでこれが見つかりました:

// Compiled from ResourceManager.java (version 1.5 : 49.0, super bit)
public class sun.net.ResourceManager {

  // Field descriptor #14 I
  private static final int DEFAULT_MAX_SOCKETS = 25;

オープン JDK 実装では、デフォルトのソケット制限は 1024 です http://www.docjar.com/html/api/sun/net/ResourceManager.java.html

4

1 に答える 1

5

その VM 引数は次のように役に立ちました。

-Dsun.net.maxDatagramSockets=101

于 2013-11-08T09:36:46.353 に答える