【IT168 技術文章】
一、什麼是C/S和B/S
要想對「C/S」和「B/S」技術發展變化有所了解,首先必須搞清楚三個問題。
第一、什麼是C/S結構。
C/S (Client/Server)結構,即大家熟知的客戶機和伺服器結構。它是軟體系統體系結構,通過它可以充分利用兩端硬體環境的優勢,將任務合理分配到Client端和Server端來實現,降低了系統的通訊開銷。目前大多數應用軟體系統都是Client/Server形式的兩層結構,由於現在的軟體應用系統正在向分布式的Web應用發展,Web和Client/Server 應用都可以進行同樣的業務處理,應用不同的模塊共享邏輯組件;因此,內部的和外部的用戶都可以訪問新的和現有的應用系統,通過現有應用系統中的邏輯可以擴展出新的應用系統。這也就是目前應用系統的發展方向。
傳統的C/S體系結構雖然採用的是開放模式,但這只是系統開發一級的開放性,在特定的應用中無論是Client端還是Server端都還需要特定的軟體支持。由於沒能提供用戶真正期望的開放環境,C/S結構的軟體需要針對不同的作業系統系統開發不同版本的軟體, 加之產品的更新換代十分快,已經很難適應百臺電腦以上區域網用戶同時使用。而且代價高, 效率低。
第二、什麼是B/S結構。
B/S(Browser/Server)結構即瀏覽器和伺服器結構。它是隨著Internet技術的興起,對C/S結構的一種變化或者改進的結構。在這種結構下,用戶工作界面是通過WWW瀏覽器來實現,極少部分事務邏輯在前端(Browser)實現,但是主要事務邏輯在伺服器端(Server)實現,形成所謂三層3-tier結構。這樣就大大簡化了客戶端電腦載荷,減輕了系統維護與升級的成本和工作量,降低了用戶的總體成本(TCO)。
以目前的技術看,區域網建立B/S結構的網絡應用,並通過Internet/Intranet模式下資料庫應用,相對易於把握、成本也是較低的。它是一次性到位的開發,能實現不同的人員,從不同的地點,以不同的接入方式(比如LAN, WAN, Internet/Intranet等)訪問和操作共同的資料庫;它能有效地保護數據平臺和管理訪問權限,伺服器資料庫也很安全 。特別是在JAVA這樣的跨平臺語言出現之後,B/S架構管理軟體更是方便、快捷、高效。
第三、管理軟體主流技術。
管理軟體技術的主流技術與管理思想一樣,也經歷了三個發展時期。首先,界面技術從上世紀DOS字符界面到Windows圖形界面(或圖形用戶界面GUI),直至Browser瀏覽器界面三個不同的發展時期。其次,今天所有電腦的瀏覽器界面,不僅直觀和易於使用,更主要的是基於瀏覽器平臺的任何應用軟體其風格都是一樣的,使用人對操作培訓的要求不高,而且軟體可操作性強,易於識別;再者,平臺體系結構也從過去單用戶發展到今天的文件/伺服器(F/S)體系、客戶機/伺服器(C/S)體系和瀏覽器/伺服器(B/S)體系。
二、C/S和B/S 之比較
C/S和B/S是當今世界開發模式技術架構的兩大主流技術。C/S是美國 Borland公司最早研發,B/S是美國微軟公司研發。目前,這兩項技術以被世界各國所掌握,國內公司以C/S和B/S技術開發出產品也很多。這兩種技術都有自己一定的市場份額和客戶群,各家企業都說自己的管理軟體架構技術功能強大、先進、方便,都能舉出各自的客戶群體,都有一大群文人墨客為自己搖旗吶喊,廣告滿天飛,可謂仁者見仁,智者見智。
1、C/S架構軟體的優勢與劣勢
(1)、應用伺服器運行數據負荷較輕。
最簡單的C/S體系結構的資料庫應用由兩部分組成,即客戶應用程式和資料庫伺服器程序。二者可分別稱為前臺程序與後臺程序。運行資料庫伺服器程序的機器,也稱為應用伺服器。一旦伺服器程序被啟動,就隨時等待響應客戶程序發來的請求;客戶應用程式運行在用戶自己的電腦上,對應於資料庫伺服器,可稱為客戶電腦,當需要對資料庫中的數據進行任何操作時,客戶程序就自動地尋找伺服器程序,並向其發出請求,伺服器程序根據預定的規則作出應答,送回結果,應用伺服器運行數據負荷較輕。
(2)、數據的儲存管理功能較為透明。
在資料庫應用中,數據的儲存管理功能,是由伺服器程序和客戶應用程式分別獨立進行的,前臺應用可以違反的規則,並且通常把那些不同的(不管是已知還是未知的)運行數據,在伺服器程序中不集中實現,例如訪問者的權限,編號可以重複、必須有客戶才能建立定單這樣的規則。所有這些,對於工作在前臺程序上的最終用戶,是「透明」的,他們無須過問(通常也無法幹涉)背後的過程,就可以完成自己的一切工作。在客戶伺服器架構的應用中,前臺程序不是非常「瘦小」,麻煩的事情都交給了伺服器和網絡。在C/S體系的下,資料庫不能真正成為公共、專業化的倉庫,它受到獨立的專門管理。
(3)、C/S架構的劣勢是高昂的維護成本且投資大。
首先,採用C/S架構,要選擇適當的資料庫平臺來實現資料庫數據的真正「統一」,使分布於兩地的數據同步完全交由資料庫系統去管理,但邏輯上兩地的操作者要直接訪問同一個資料庫才能有效實現,有這樣一些問題,如果需要建立「實時」的數據同步,就必須在兩地間建立實時的通訊連接,保持兩地的資料庫伺服器在線運行,網絡管理工作人員既要對伺服器維護管理,又要對客戶端維護和管理,這需要高昂的投資和複雜的技術支持,維護成本很高,維護任務量大。
其次,傳統的C/S結構的軟體需要針對不同的作業系統系統開發不同版本的軟體,由於產品的更新換代十分快,代價高和低效率已經不適應工作需要。在JAVA這樣的跨平臺語言出現之後,B/S架構更是猛烈衝擊C/S,並對其形成威脅和挑戰。