本篇內容介紹了“服務器異常問題怎么解決”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
服務背景:
流數據接收--> 解析過濾-->調用socket服務 寫入mina服務。
服務器異常日志:
java.io.IOException: Too many open files Failed to open a selectorFailed to create a new instance of org.apache.mina.transport.socket.nio.NioProcessor:null
定位到問題代碼:
public void init() {NioSocketConnector connector = new NioSocketConnector();connector.getFilterChain().addLast("codec",new ProtocolCodecFilter(new TextLineCodecFactory(Charset.defaultCharset())));connector.setConnectTimeoutMillis(10000);connector.setHandler(new SocketClientHandler());connector.getSessionConfig().setReceiveBufferSize(10240); // 設置接收緩沖區的大小connector.getSessionConfig().setSendBufferSize(10240);// 設置輸出緩沖區的大小ConnectFuture cf = connector.connect(new InetSocketAddress(socketConfig.getSocketServerIp(),socketConfig.getSocketServerPort()));// 等待連接創建完成cf.awaitUninterruptibly();session = cf.getSession();}
問題產生原因:
當mina服務端長時間連接不上 ,并發連接特別多的時候 都會導致上述問題。
解決方案:當連接不成功的時候 進行施放句柄。
修改之后:
public void init() {NioSocketConnector connector = new NioSocketConnector();connector.getFilterChain().addLast("codec",new ProtocolCodecFilter(new TextLineCodecFactory(Charset.defaultCharset())));connector.setConnectTimeoutMillis(10000);connector.setHandler(new SocketClientHandler());connector.getSessionConfig().setReceiveBufferSize(10240); // 設置接收緩沖區的大小connector.getSessionConfig().setSendBufferSize(10240);// 設置輸出緩沖區的大小ConnectFuture cf = connector.connect(new InetSocketAddress(socketConfig.getSocketServerIp(),socketConfig.getSocketServerPort()));// 等待連接創建完成cf.awaitUninterruptibly();if (cf.isDone()) {if (!cf.isConnected()) {log.error("fail connect {} {}", socketConfig.getSocketServerIp(),socketConfig.getSocketServerPort());connector.dispose();throw new RuntimeException("Not connect to Mina Server");} else {session = cf.getSession();}}}
“服務器異常問題怎么解決”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。