Java分布式學習資料:分布式系統(tǒng)復(fù)習_第1頁
Java分布式學習資料:分布式系統(tǒng)復(fù)習_第2頁
Java分布式學習資料:分布式系統(tǒng)復(fù)習_第3頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、Java的集合包括 Collection, Map。資源消耗過多是影響分布式系統(tǒng)包括CPU,文件IO,網(wǎng)絡(luò)IO,內(nèi)存方面。負載均衡是負載均衡機器采用隨機選擇,Hash選擇,按權(quán)重選擇,按負載選擇,按連接選擇策略把把用戶請求轉(zhuǎn)發(fā)到業(yè)務(wù)處理機。水平伸縮通過增加機器來支撐訪問量和數(shù)據(jù)量的方式;垂直伸縮通過升級或增加單臺機器的硬件來支撐訪問量和數(shù)據(jù)量增長的方式。 寫出用TCP/IP+BIO實現(xiàn)基于消息方式實現(xiàn)系統(tǒng)間通信的主要過程。 答:Java中可基于Socket和ServerSocket實現(xiàn)TCP/IP+BIO的分布式系統(tǒng)間通信。其中,Socket用于連接和網(wǎng)絡(luò)I/O的操作,ServerSocket

2、用于實現(xiàn)服務(wù)器端端口的監(jiān)聽及Socket對象的獲取。TCP/IP+BIO實現(xiàn)基于消息方式實現(xiàn)系統(tǒng)間通信的主要過程是:客戶端:創(chuàng)建連接Socket socket = new Socket(目標IP,目標端口); (2) 創(chuàng)建讀取服務(wù)器端返回流的BufferReader BufferReader in = new BufferReader(new InputStreamReader(socket.getInputStream(); (3) 創(chuàng)建向服務(wù)器寫入流的PrinterWriter PrinterWriter out = new PrinterWriter(socket.getOututStr

3、eam(), true); (4)像服務(wù)器端發(fā)送字符串Out.println(“消息內(nèi)容”); (5) 阻塞讀取服務(wù)器的返回信息。該阻塞過程會持續(xù)到服務(wù)器返回信息或網(wǎng)絡(luò)異常為止。 In.readline( );服務(wù)器端核心代碼:創(chuàng)建本地指定端口的監(jiān)聽ServerSocket ss = new ServerSocket(監(jiān)聽端口)接受客戶端建連接請求Socket socket = ss.accept( );6、WebService調(diào)用的主要過程。答:WebService是一種跨語言的系統(tǒng)間交互標準,服務(wù)端以HTTP方式提供服務(wù),該服務(wù)采用WSDL(Web Service Description

4、Language)描述。WSDL文件描述服務(wù)使用的協(xié)議、期望的參數(shù)、返回的參數(shù)格式等。調(diào)用端通過SOAP(Simple Object Access Protocol)方式進行交互。WebService調(diào)用的具體過程是:首先把服務(wù)器端的服務(wù)描述成WSDL文件,并把該WSDL文件放入HTTP服務(wù)器,用Java輔助工具根據(jù)WSDL文件生成客戶端stub代碼。Stub代碼的作用是把產(chǎn)生的對象請求信息封裝為標準的SOAP格式數(shù)據(jù),并發(fā)送到服務(wù)器端。服務(wù)器端在收到SOAP格式數(shù)據(jù)時進行轉(zhuǎn)化,反射調(diào)用的Java類。 7Map類的迭代器可采用哪兩類方式訪問。答:Map是重要數(shù)據(jù)集,提供了數(shù)據(jù)的插入、刪除、索引

5、、查找、遍歷等數(shù)據(jù)訪問功能。Map類通常采用兩類迭代器訪問Map類,一種是keySet,一種是entrySet,示例代碼如下: String tmpkey = String.format(%d, index); if(hashmapTest.containsKey(tmpkey) System.out.println(found the key); else System.out.println(Not found the key); Iterator ite; ite = hashmapTest.keySet().iterator(); while(ite.hasNext() String

6、tempkey = (String)ite.next(); System.out.println(Key + tempkey + value : + hashmapTest.get(tempkey); ite = hashmapTest.entrySet().iterator(); while(ite.hasNext() Map.Entry entry = (Map.Entry) ite.next(); String key = entry.getKey(); Double value = entry.getValue(); System.out.println(Key + key + val

7、ue : + value); 8ArrayList和CopyOnWriteArrayList應(yīng)用的主要不同是什么?。 ArrayList和CopyOnWriteArrayList都是數(shù)據(jù)集類型,ArrayList是通常的數(shù)據(jù)集合,而CopyOnWriteArrayList是并發(fā)的數(shù)據(jù)集合。 二者的不同體現(xiàn)在,(1)二者的基類不同,ArrayList的基類是java.util.ArrayList;CopyOnWriteArrayList的基類是java.util.concurrent.CopyOnWriteArrayList;二者支持的數(shù)據(jù)操作類型不同,ArrayList是單線程操作,而Copy

8、OnWriteArrayList支持多線程操作。二者的性能在小規(guī)模數(shù)據(jù),二者的性能接近,隨著數(shù)據(jù)規(guī)模的增大,CopyOnWriteArrayList的性能逐漸優(yōu)于ArrayList。9.什么是序列化、反序列化?序列化的主要步驟是什么?反序列化的主要步驟是什么?答:分布式系統(tǒng)傳送的數(shù)據(jù)類型很多,包括音頻、視頻、文字、圖像等,這些不同類型的數(shù)據(jù)在網(wǎng)絡(luò)中傳輸時都要進行序列化和飯序列化操作。序列化操作把要在網(wǎng)絡(luò)系統(tǒng)傳送的數(shù)據(jù)序列化為二進制流,反序列化則把二進制數(shù)據(jù)反序列化為原數(shù)據(jù)。 序列化的常用方法:創(chuàng)建一個字節(jié)數(shù)組輸出流 ByteArrayOutputStream output = new Byte

9、ArrayOutputStream();把字節(jié)數(shù)組包裝為ObjectOutputStream ObjectOutputStream objectOut = new ObjectOutputStream(output);把對象寫入ObjectOutputStreamobjectOut.writeObject(序列化數(shù)據(jù))關(guān)閉數(shù)據(jù)objectOut.close();output.close(); 反序列化的常用方法: 創(chuàng)建一個字節(jié)數(shù)組輸入流 ByteArrayInutStream input = new ByteArrayInutStream ();把字節(jié)數(shù)組包裝為ObjectInputStream ObjectInputStream objecIn = new ObjectInputStream(input);從ObjectOutputStream

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論