TCP是建立可靠連接,并且通信雙方都可以以流的形式發送數據。相對TCP,UDP則是面向無連接的協議。
使用UDP協議時,不需要建立連接,只需要知道對方的IP地址和端口號,就可以直接發數據包。但是,能不能到達就不知道了。
雖然用UDP傳輸數據不可靠,但它的優點是和TCP比,速度快,對于不要求可靠到達的數據,就可以使用UDP協議。
我們來看看如何通過UDP協議傳輸數據。和TCP類似,使用UDP的通信雙方也分為客戶端和服務器。服務器首先需要綁定端口:
1
2
3
|
s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) # 綁定端口: s.bind(( '127.0.0.1' , 9999 )) |
創建Socket時,SOCK_DGRAM指定了這個Socket的類型是UDP。綁定端口和TCP一樣,但是不需要調用listen()方法,而是直接接收來自任何客戶端的數據:
1
2
3
4
5
6
|
print 'Bind UDP on 9999...' while True : # 接收數據: data, addr = s.recvfrom( 1024 ) print 'Received from %s:%s.' % addr s.sendto( 'Hello, %s!' % data, addr) |
recvfrom()方法返回數據和客戶端的地址與端口,這樣,服務器收到數據后,直接調用sendto()就可以把數據用UDP發給客戶端。
注意這里省掉了多線程,因為這個例子很簡單。
客戶端使用UDP時,首先仍然創建基于UDP的Socket,然后,不需要調用connect(),直接通過sendto()給服務器發數據:
1
2
3
4
5
6
7
|
s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) for data in [ 'Michael' , 'Tracy' , 'Sarah' ]: # 發送數據: s.sendto(data, ( '127.0.0.1' , 9999 )) # 接收數據: print s.recv( 1024 ) s.close() |
從服務器接收數據仍然調用recv()方法。
仍然用兩個命令行分別啟動服務器和客戶端測試,結果如下:
小結
UDP的使用與TCP類似,但是不需要建立連接。此外,服務器綁定UDP端口和TCP端口互不沖突,也就是說,UDP的9999端口與TCP的9999端口可以各自綁定。
源碼參考:https://github.com/michaelliao/learn-python/tree/master/socket