socket收到报文慢,存在时间差

socket发送报文的时间是16:42,但是服务端接受到是16:43(代码中的socketTime),中间差了一分钟是什么原因?怎么改下服务端代码?

package net.huadong.citos.service;

import com.alibaba.fastjson.JSONObject;

import java.io.*;
import java.net.ServerSocket;
import java.net.Socket;
import java.sql.SQLException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Timer;
import java.util.TimerTask;

public class Main {
    public static final int port = 9001;
  
    public static void main(String[] args) throws IOException {

        new HandlerThread();
    }

    private static class HandlerThread implements Runnable {
        ServerSocket serverSocket ;
        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

        public HandlerThread() {
            try {
                serverSocket = new ServerSocket(port);
                serverSocket.setSoTimeout(5000);
            } catch (IOException e) {
                e.printStackTrace();
            }
            new Thread(this).start();
        }

        @Override
        public void run() {
            while(true) {
                try (Socket socket=serverSocket.accept();
                     InputStream inputStream = socket.getInputStream()){
//                try{
//                    socket = serverSocket.accept();
//                    inputStream = socket.getInputStream();

                    byte[] bytes = new byte[1024];
                    int len = 0;
                    //int bytesWritten = 0;
                    StringBuilder sb = new StringBuilder();
                    System.out.println("socketTime:"+simpleDateFormat.format(new Date()));
                    while ((len = inputStream.read(bytes)) != -1) {
                        //注意指定编码格式,发送方和接收方一定要统一,建议使用UTF-8
                        sb.append(new String(bytes, 0, len, "GB2312"));
                        //bytesWritten += len;
                    }
                    System.out.println("readtime:" + simpleDateFormat.format(new Date()));
                    String str = sb.toString();
                    if(str!=null&&!str.equals("")) {
                        String result = str.substring(38, str.length() - 3);
                        System.out.println("xml begintime:" + simpleDateFormat.format(new Date()));
                        dealMessage t = new dealMessage();
                        t.JdbcDemo(result);
                    }
                } catch (Exception e) {
                    System.out.println("*****************异常***************");
                }
            }
        }
    }

}


试试用同一个局域网,公网可能是网络慢吧

可能其他应用抢占线程导致HandlerThread线程阻塞导致延时。

不知道你这个问题是否已经解决, 如果还没有解决的话:

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^