(java)Socket短連接雙端通信

一、TCP連接簡介
當網絡通信時採用TCP協議時,在真正的讀寫操作之前,server與client之間必須建立一個連接,
當讀寫操作完成後,雙方不再需要這個連接時它們可以釋放這個連接,
連接的建立是需要三次握手的,而釋放則需要4次握手,
所以說每個連接的建立都是需要資源消耗和時間消耗的
經典的三次握手示意圖:



經典的四次握手關閉圖:
 
二、socket短連接
通常的短連接操作步驟是: 
  連接→數據傳輸→關閉連接;
二、發送接收方式
1、異步 
報文發送和接收是分開的,相互獨立的,互不影響。這種方式又分兩種情況: 
(1)異步雙工:接收和發送在同一個程序中,由兩個不同的子進程分別負責發送和接收 
(2)異步單工:接收和發送是用兩個不同的程序來完成。 

2、同步 
報文發送和接收是同步進行,既報文發送後等待接收返回報文。 
同步方式一般需要考慮超時問題,即報文發出去後不能無限等待,需要設定超時時間,
超過該時間發送方不再等待讀返回報文,直接通知超時返回。
 三. 單工、半雙工和全雙工
根據通信雙方的分工和信號傳輸方向可將通信分爲三種方式:
單工、
半雙工、
全雙工。

在計算機網絡中主要採用雙工方式,其中:
局域網採用半雙工方式,
城域網和廣域網採用全雙年方式。   

1. 單工(Simplex)方式:
通信雙方設備中發送器與接收器分工明確,只能在由發送器向接收器的單一固定方向上傳送數據。
採用單工通信的典型發送設備如早期計算機的讀卡器,典型的接收設備如打印機。   

2. 半雙工(Half Duplex)方式:
通信雙方設備既是發送器,也是接收器,兩臺設備可以相互傳送數據,但某一時刻則只能向一個方向傳送數據。
例如,步話機是半雙工設備,因爲在一個時刻只能有一方說話。   

3. 全雙工(Full Duplex)方式:
通信雙方設備既是發送器,也是接收器,兩臺設備可以同時在兩個方向上傳送數據。
例如,電話是全雙工設備,因爲雙方可同時說話。

而像WEB網站的http服務一般都用短鏈接,因爲長連接對於服務端來說會耗費一定的資源,
而像WEB網站這麼頻繁的成千上萬甚至上億客戶端的連接用短連接會更省一些資源,
如果用長連接,而且同時有成千上萬的用戶,如果每個用戶都佔用一個連接的話,那可想而知吧。
所以併發量大,但每個用戶無需頻繁操作情況下需用短連好。
三、代碼如下:
服務器端:
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.Scanner;

public class Server {

	public static void main(String[] args){
		// TODO Auto-generated method stub
		ServerSocket serversocket=null;
		Socket socket=null;
		BufferedReader br=null;
		PrintWriter pw=null;
		Scanner sc=null;
		try{
			serversocket=new ServerSocket(8000);
			socket=serversocket.accept();
			System.out.println("client connected!");
			br=new BufferedReader(new InputStreamReader(socket.getInputStream()));
			pw=new PrintWriter(new BufferedWriter(new OutputStreamWriter(socket.getOutputStream())));
			sc=new Scanner(System.in);
			while(true){
				String str=br.readLine();
				if("END".equals(str)){
					pw.println("END");
					pw.flush();
					break;
				}else{
					System.out.println("client:"+str);
					str=sc.nextLine();
					pw.println(str);
					pw.flush();
				}
			}
		}catch(Exception e){
			e.printStackTrace();
		}finally {
			try{
				System.out.println("closed......");
				br.close();
				pw.close();
				socket.close();
				serversocket.close();
			}catch(Exception e){
				e.printStackTrace();
			}
		}
	}

}
客戶端:
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.net.Socket;
import java.util.Scanner;

public class Client {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Socket socket=null;
		BufferedReader br=null;
		PrintWriter pw=null;
		Scanner sc=null;
		try{
			socket=new Socket("127.0.0.1",8000);
			br=new BufferedReader(new InputStreamReader(socket.getInputStream()));
			pw=new PrintWriter(new BufferedWriter(new OutputStreamWriter(socket.getOutputStream())));
			sc=new Scanner(System.in);
			for(int i=0;i<10;i++){
				String str=sc.nextLine();
				pw.println(str);
				pw.flush();
				str=br.readLine();
				System.out.println("server:"+str);
			}
			pw.print("END");
			pw.flush();
		}catch(Exception e){
			e.printStackTrace();
		}finally {
			System.out.println("closed......");
			try{
			br.close();
			pw.close();
			socket.close();
			}catch(Exception e){
				e.printStackTrace();
			}
		}
	}

}




發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章