linux操作系統中bsd套接口開發的基礎介紹 |
發布時間: 2012/8/13 14:13:34 |
這是關于如何用各種可以得到的接口為Linux開發網絡程序的系列文章的第一篇。就像大多數Unix-based的操作系統一樣,Linux支持將TCP/IP作為本地的網絡傳輸協議。在這個系列中,我們假定你已經比較熟悉Linux上的C編程和Linux的一些系統知識諸如signals,forking等等。
這篇文章是關于如何用BSD套接口創建網絡程序的基礎介紹 。在下一篇中,我們會解決涉及到建立(網絡)deamon進程的問題。而且今后的文章我們還會涉及到使用遠程過程調用(RPC),以及用CORBA/distributed objects進行開發。 一、TCP/IP的基礎介紹 TCP/IP協議族允許兩個運行在同一臺電腦或者由網絡連接在一起的兩臺電腦上的程序進行通訊。這個協議族是專門為了在不可靠的網絡上進行通訊設計的。TCP/IP允許兩個基本的操作模式——面向連接的可靠的傳輸(指TCP)和無連接的(connectionless)不可靠的傳輸(UDP)。 TCP提供帶有對上層協議透明的中繼功能的,順序的,可靠的,雙向的(bi-directional),以連接為基礎的字節傳輸流。TCP將你的信息分割成數據報(不大于64kb)并保證所有的數據報無誤的按照順序都到達目的地。由于以連接為基礎,所以一個虛擬連接必須在一個網絡實體(network entity)和另一個之間進行通信前建立。UDP相反則提供一個(非常快的)無連接的不可靠消息傳輸(消息的大小是一個確定的最大長度)。 為了使程序間可以相互通信,不論他們是在同一個機器(通過loopback接口)還是不同主機,每一個程序都必須有獨立的地址。 TCP/IP地址由兩部分組成——用來辨別機器的IP地址和用來辨別在那臺機器上的特定程序的端口地址。 地址可以是點分(dotted-quad)符號形式的(如,127.0.0.1)或者是主機名形式的(如,www.csdn.net)。系統可以使用/etc/hosts或DNS域名服務(如果可以獲得的話)進行主機名到點分符號地址(也就是IP地址)的轉換。 端口從1號開始編號。1和IPP0RT_RESERVED(在/usr/include/netinet/in.h中定義,通常為1024)之間的段口號保留給系統使用(也就是說,你必須以root的身份建立一個網絡服務來綁定這部分的端口)。 最簡單的網絡程序大都用的客戶-服務器模型。一個服務進程等待一個客戶進程連接他。當連接建立時,服務器代表客戶執行特定的任務,通常這這以后連接就中斷了。 二、使用BSD套接口界面 最通行的TCP/IP編程方法就是使用BSD套接口界面編程。通過它,網絡端點(network endpoints)(IP地址和端口地址)以套接口(sockets)的形式出現。 這套套接口IPC(interprocess communication,進程間通訊)設施(從4.2BSD開始引入)的設計是為了能讓網絡程序的設計能夠獨立于不同的底層通信設施。 1、建立一個服務器程序 要使用BSD界面建立一個服務器程序,你必須通過以下步驟: (1)通過函數socket()建立一個套接口 (2)通過函數bind()綁定一個地址(IP地址和端口地址)。這一步確定了服務器的位置,使客戶端知道如何訪問。 (3)通過函數listem()監聽(listen)端口的新的連接請求。 (4)通過函數accept()接受新的連接。 通常,維護代表了客戶的請求可能需要花費相當長的一段時間。在處理一個請求時,接收和處理新的請求也應該是高效的。達到這種目的的最通常的做法是讓服務器通過fork()函數拷貝一份自己的進程來接受新的連接。 以下的例子顯示了服務器是如何用C實現的: 以下為引用的內容: /* /* Hellwolf Misty translated */ #include /* */
/*
if (2 != argc) 本文出自:億恩科技【www.laynepeng.cn】 |