我发现了一个纯Java移植版的zeromq库,想要使用它。尽管它声称在某些方面表现不错,但我进行的测试结果很差,即使是在本地(客户端和服务器在同一台机器上)。我确定是我做错了什么。执行这个10,000条信息循环需要大约5秒钟。
我只是拿了Hello World示例并删除了暂停和sysouts。以下是代码: 服务器端:
这段代码能否修复并获得一些合理的数字?
我只是拿了Hello World示例并删除了暂停和sysouts。以下是代码: 服务器端:
package guide;
import org.jeromq.ZMQ;
public class hwserver{
public static void main(String[] args) throws Exception{
// Prepare our context and socket
ZMQ.Context context = ZMQ.context(1);
ZMQ.Socket socket = context.socket(ZMQ.REP);
System.out.println("Binding hello world server");
socket.bind ("tcp://*:5555");
while (true) {
byte[] reply = socket.recv(0);
String requestString = "Hello" ;
byte[] request = requestString.getBytes();
socket.send(request, 0);
}
}
}
客户端:
package guide;
import org.jeromq.ZMQ;
public class hwclient{
public static void main(String[] args){
ZMQ.Context context = ZMQ.context(1);
ZMQ.Socket socket = context.socket(ZMQ.REQ);
socket.connect ("tcp://localhost:5555");
System.out.println("Connecting to hello world server");
long start = System.currentTimeMillis();
for(int request_nbr = 0; request_nbr != 10_000; request_nbr++) {
String requestString = "Hello" ;
byte[] request = requestString.getBytes();
socket.send(request, 0);
byte[] reply = socket.recv(0);
}
long end = System.currentTimeMillis();
System.out.println(end-start);
socket.close();
context.term();
}
}
这段代码能否修复并获得一些合理的数字?