Java多線程服務(wù)器如何應(yīng)對相關(guān)鏈接問題
Java多線程服務(wù)器是目前很多企業(yè)都在使用的一種服務(wù)器方式。相關(guān)的問題還是需要不斷的學(xué)習(xí),只有不斷的學(xué)習(xí)才能更好的掌握相關(guān)的問題解決方案。希望大家有所收獲。
前面的示例教給您基礎(chǔ)知識,但并不能令您更深入。如果您到此就停止了,那么您一次只能處理一臺客戶機(jī)。原因是 handleConnection() 是一個阻塞方法。只有當(dāng)它完成了對當(dāng)前連接的處理時,服務(wù)器才能接受另一個客戶機(jī)。在多數(shù)時候,您將需要(也有必要)一個Java多線程服務(wù)器。
要開始同時處理多臺客戶機(jī),并不需要對 RemoteFileServer 作太多改變。事實上,要是我們前面討論過待發(fā)(backlog),那我們就只需改變一個方法,雖然我們將需要創(chuàng)建一些新東西來處理進(jìn)入的連接。這里我們還將向您展示Java多線程服務(wù)器 ServerSocket 如何處理眾多等待(備份)使用服務(wù)器的客戶機(jī)。本示例對線程的低效使用,所以請耐心點。
接受(太多)連接
這里我們實現(xiàn)改動過的 acceptConnections() 方法,它將創(chuàng)建一個能夠處理待發(fā)請求的 ServerSocket ,并告訴 ServerSocket 接受連接:
Java代碼
- public void acceptConnections() {
 - try {
 - ServerSocket server = new ServerSocket(listenPort, 5);
 - Socket incomingConnection = null;
 - while (true) {
 - incomingConnection = server.accept();
 - handleConnection(incomingConnection);
 - }
 - } catch (BindException e) {
 - System.out.println("Unable to bind to port " + listenPort);
 - } catch (IOException e) {
 - System.out.println("Unable to instantiate a ServerSocket on port: " + listenPort);
 - }
 - }
 - public void acceptConnections() {
 - try {
 - ServerSocket server = new ServerSocket(listenPort, 5);
 - Socket incomingConnection = null;
 - while (true) {
 - incomingConnection = server.accept();
 - handleConnection(incomingConnection);
 - }
 - } catch (BindException e) {
 - System.out.println("Unable to bind to port " + listenPort);
 - } catch (IOException e) {
 - System.out.println("Unable to instantiate a ServerSocket on port: " + listenPort);
 - }
 - }
 
新的 server 仍然需要 acceptConnections() ,所以這些代碼實際上是一樣的。突出顯示的行表示一個重大的不同。對這個多線程版,我們現(xiàn)在可以指定客戶機(jī)請求的最大數(shù)目,這些請求都能在實例化 ServerSocket 期間處于待發(fā)狀態(tài)。如果我們沒有指定客戶機(jī)請求的最大數(shù)目,則我們假設(shè)使用缺省值 50。
這里是它的工作機(jī)制。假設(shè)我們指定待發(fā)數(shù)(backlog 值)是 5 并且有五臺客戶機(jī)請求連接到我們的服務(wù)器。我們的服務(wù)器將著手處理第一個連接,但處理該連接需要很長時間。由于我們的待發(fā)值是 5,所以我們一次可以放五個請求到隊列中。我們正在處理一個,所以這意味著還有其它五個正在等待。等待的和正在處理的一共有六個。當(dāng)我們的服務(wù)器仍忙于接受一號連接(記住隊列中還有 2―6 號)時,如果有第七個客戶機(jī)提出連接申請,那么,在Java多線程服務(wù)器中該第七個客戶機(jī)將遭到拒絕。我們將在帶有連接池服務(wù)器示例中說明如何限定能同時連接的客戶機(jī)數(shù)目。
【編輯推薦】















 
 
 

 
 
 
 