审查视图

src/main/java/com/tianbo/warehouse/controller/LogWebsockController.java 2.1 KB
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
package com.tianbo.warehouse.controller;

import com.tianbo.warehouse.handle.IO_Log_Handle;
import org.springframework.stereotype.Component;

import javax.websocket.OnClose;
import javax.websocket.OnError;
import javax.websocket.OnOpen;
import javax.websocket.Session;
import javax.websocket.server.ServerEndpoint;
import java.io.IOException;
import java.io.InputStream;
import java.util.concurrent.CopyOnWriteArraySet;


@ServerEndpoint(value = "/log")
@Component
18
public class LogWebsockController {
19 20 21 22 23 24 25 26
    private Process process;
    private InputStream inputStream;
    //与某个客户端的连接会话,需要通过它来给客户端发送数据
    private Session session;

    //静态变量,用来记录当前在线连接数。应该把它设计成线程安全的。
    private static int onlineCount = 0;
    //concurrent包的线程安全Set,用来存放每个客户端对应的MyWebSocket对象。
27
    private static CopyOnWriteArraySet<LogWebsockController> webSocketSet = new CopyOnWriteArraySet<LogWebsockController>();
28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69


    @OnOpen
    public void onOpen(Session session){
        this.session = session;
        webSocketSet.add(this);
        addOnlineCount();
        try {
            process = Runtime.getRuntime().exec("tail -f logs/imf.log");
            inputStream = process.getInputStream();
            IO_Log_Handle thread = new IO_Log_Handle(inputStream, session);
            thread.start();

        }catch (IOException e){
            e.printStackTrace();
        }

    }
    /**
     * WebSocket请求关闭
     */
    @OnClose
    public void onClose() {
        try {
            if(inputStream != null) {
                inputStream.close();
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        if(process != null){
            process.destroy();
        }

    }

    @OnError
    public void onError(Throwable thr) {
        thr.printStackTrace();
    }

    public static synchronized void addOnlineCount() {
70
        LogWebsockController.onlineCount++;
71 72 73 74 75 76 77
    }
    public static synchronized int getOnlineCount() {
        return onlineCount;
    }


}