深入理解計算機系統:2.計算機系統漫游(下)
1. 高速快取至關重要
系統花費了大量的時間把資訊從一個地方傳到另一個地方,hello程式的機器指令最初是存放在磁盤上,當程式加載時,它們被復制到主存;當處理器運行程式時,指令又從主存復制到處理器,從程式員的角度來看,這些復制就是開銷,減慢了程式“真正”的作業,因此,系統設計者的一個主要目標就是使這些復制操作盡可能快地完成,
根據機械原理, 較大的存盤設備要比較小的存盤設備運行得慢,而快速設備的造價遠高于同類的低速設備,一個典型的暫存器檔案只存盤幾百位元組的資訊,而主存里可存放幾十億字方, 然而處理器從暫存器檔案中讀資料比從主存中讀取幾乎要快100倍,
隨著這些年半導體技術的進步,這種處理器與主存之間的差距還在持續增大,加快處理器的運行速度比加快主存的運行速度委容易和便宜得多,針對這種處理器與主存之間的差異,系統設計者采用了更小更快的存盤設備:高速快取存盤器(簡稱為cache或高速快取),作為暫時的集結區域,存放處理器近期可能會需要的資訊,
2. 存盤設備形成層次結構
在這個層次結構中,從上至下,設備的訪問速度越來越慢、容量越來越大,并且每位元組的造價也越來越便宜,暫存器檔案在層次的構中位于最頂部,也就是第0級或記為L0, 這里我們展示的是三層高速級存L1到|占據存盤器層次結構的第1層到第3層,主存在第4層,以此類推,
存盤器層次結構的主要思想是上一層的存盤器作為低-一層存盤器的高速快取,因此暫存器檔案就是LI的高速快取,LI是L2的高速快取,L2是L3的高速快取,L.3是主存的高速快取,而主存又是磁盤的高速快取,在某些具有分布式檔案系統的網路系統中,本地磁盤就是存盤在其他系統中磁盤上的資料的高速快取,
3.作業系統管理硬體
我們可以把作業系統看成是應用程式和硬體之間插人的一層軟體,所有應用程式對硬體的操作嘗試都必須通過作業系統, 作業系統有兩個基本功能:
防 止硬體被失控的應用程式濫用; 向應用程式提供簡單一致的機制來控制復雜而又通常大不相同的低級硬體設備,
作業系統通過幾個基本的抽象概念(行程、虛擬記憶體和檔案)來實作這兩個功能,
檔案是對I/O設備的抽象表示,虛擬記憶體是對主存和磁盤I/O設備的抽象表示,行程則是對處理器、主存和I/O設備的抽象表示,
行程 :像hello這樣的程式在現代系統上運行時,作業系統會提供種假象,就好像系統上只有這個程式在運行,程式看上去是獨占地使用處理器、主存和1/O設備 ,處理器看上去就像在不間斷地一條接一 條地執行程式中的指令, 即該程式的代碼和資料是系統記憶體中唯一的物件,這些假象是通過行程的概念來實作的,行程是計算機科學中最重要和最成功的概念之一,是作業系統對一個正在運行的程式的一種抽象, 在一個系統上可以同時運行多個行程,而每個行程都好像在獨占地使用硬體,而并發運行,則是說一個行程的指令和另一個行程的指令是交錯執行的,在大多數系統中,需要運行的行程數是多于可以運行它們的CPU個數的,無論是在單核還是多核系統中,一個CPU看上去都像是在并發地執行多個行程,這是通過處理器在行程間切換來實作的,作業系統實作這種交錯執行的機制稱為背景關系切換,執行緒 :一個行程實際上可以由多個稱為執行緒的執行單元組成,每個執行緒都運行在行程的背景關系中,并共享同樣的代碼和全域資料 ,由于網路服務器中對并行處理的需求,執行緒成為越來越重要的編程模型,因為多執行緒之間比多行程之間更容易共享資料,也因為執行緒一般來說都比行程更高效,當有多處理器可用的時候,多執行緒也是一種使得程式可以運行得更快的方法,虛擬記憶體 :虛擬記憶體是一個抽象概念,它為每個行程提供了一個假象,即每個行程都在獨占地使用主存 ,每個行程看到的記憶體都是一致的, 稱為虛擬地址空間, 程式代碼和資料 :對所有的行程來說,代碼都是從同一固定地址開始的,即 0x08048000,緊接著是C全域變數的資料區, 代碼和資料區是直接按照可執行目標檔案的內容初始化的 堆 :運行時堆,在運行時動態地擴展收縮 共享庫 :大約在地址空間的中間部分,存放標準庫、數學庫等共享庫的代碼和資料 堆疊 :位于用戶虛擬地址空間頂部的是用戶堆疊,編譯器用它來實作函式呼叫,在程式執行期間可以動態的擴展和收縮, 內核虛擬存盤器 :地址空間頂部的區域是為內核保留的,不允許應用程式讀寫這個區域的內容或直接呼叫內核代碼定義的函式,必須呼叫內核執行這些操作檔案 :檔案就是位元組序列,每個I/O設備,包括磁盤、鍵盤、顯示幕,甚至網路,都可以看成是檔案,系統中的所有輸入輸出都是通過使用一小組稱為Unix I/O的系統函式呼叫讀寫檔案來實作的,檔案向應用程式提供了一個統一的視圖,來看待系統中可能含有的所有各式各樣的I/O設備,
4.系統之間利用網路通信
隨在Inenet這樣的全球網路的出現,從一臺主機復制資訊到另外一臺主機已經成為計算機系統最重要的用途之一, 假設用本地主機上的telne客戶端連接遠程主機上的ene服務器,在我們登錄到遠程主機并運行shell后,遠端的shell就在等待接收輸人命令
<style>#mermaid-svg-ygisPfIwlu0EmPvq .label{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);fill:#333;color:#333}#mermaid-svg-ygisPfIwlu0EmPvq .label text{fill:#333}#mermaid-svg-ygisPfIwlu0EmPvq .node rect,#mermaid-svg-ygisPfIwlu0EmPvq .node circle,#mermaid-svg-ygisPfIwlu0EmPvq .node ellipse,#mermaid-svg-ygisPfIwlu0EmPvq .node polygon,#mermaid-svg-ygisPfIwlu0EmPvq .node path{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-ygisPfIwlu0EmPvq .node .label{text-align:center;fill:#333}#mermaid-svg-ygisPfIwlu0EmPvq .node.clickable{cursor:pointer}#mermaid-svg-ygisPfIwlu0EmPvq .arrowheadPath{fill:#333}#mermaid-svg-ygisPfIwlu0EmPvq .edgePath .path{stroke:#333;stroke-width:1.5px}#mermaid-svg-ygisPfIwlu0EmPvq .flowchart-link{stroke:#333;fill:none}#mermaid-svg-ygisPfIwlu0EmPvq .edgeLabel{background-color:#e8e8e8;text-align:center}#mermaid-svg-ygisPfIwlu0EmPvq .edgeLabel rect{opacity:0.9}#mermaid-svg-ygisPfIwlu0EmPvq .edgeLabel span{color:#333}#mermaid-svg-ygisPfIwlu0EmPvq .cluster rect{fill:#ffffde;stroke:#aa3;stroke-width:1px}#mermaid-svg-ygisPfIwlu0EmPvq .cluster text{fill:#333}#mermaid-svg-ygisPfIwlu0EmPvq div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:12px;background:#ffffde;border:1px solid #aa3;border-radius:2px;pointer-events:none;z-index:100}#mermaid-svg-ygisPfIwlu0EmPvq .actor{stroke:#ccf;fill:#ECECFF}#mermaid-svg-ygisPfIwlu0EmPvq text.actor>tspan{fill:#000;stroke:none}#mermaid-svg-ygisPfIwlu0EmPvq .actor-line{stroke:grey}#mermaid-svg-ygisPfIwlu0EmPvq .messageLine0{stroke-width:1.5;stroke-dasharray:none;stroke:#333}#mermaid-svg-ygisPfIwlu0EmPvq .messageLine1{stroke-width:1.5;stroke-dasharray:2, 2;stroke:#333}#mermaid-svg-ygisPfIwlu0EmPvq #arrowhead path{fill:#333;stroke:#333}#mermaid-svg-ygisPfIwlu0EmPvq .sequenceNumber{fill:#fff}#mermaid-svg-ygisPfIwlu0EmPvq #sequencenumber{fill:#333}#mermaid-svg-ygisPfIwlu0EmPvq #crosshead path{fill:#333;stroke:#333}#mermaid-svg-ygisPfIwlu0EmPvq .messageText{fill:#333;stroke:#333}#mermaid-svg-ygisPfIwlu0EmPvq .labelBox{stroke:#ccf;fill:#ECECFF}#mermaid-svg-ygisPfIwlu0EmPvq .labelText,#mermaid-svg-ygisPfIwlu0EmPvq .labelText>tspan{fill:#000;stroke:none}#mermaid-svg-ygisPfIwlu0EmPvq .loopText,#mermaid-svg-ygisPfIwlu0EmPvq .loopText>tspan{fill:#000;stroke:none}#mermaid-svg-ygisPfIwlu0EmPvq .loopLine{stroke-width:2px;stroke-dasharray:2, 2;stroke:#ccf;fill:#ccf}#mermaid-svg-ygisPfIwlu0EmPvq .note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-ygisPfIwlu0EmPvq .noteText,#mermaid-svg-ygisPfIwlu0EmPvq .noteText>tspan{fill:#000;stroke:none}#mermaid-svg-ygisPfIwlu0EmPvq .activation0{fill:#f4f4f4;stroke:#666}#mermaid-svg-ygisPfIwlu0EmPvq .activation1{fill:#f4f4f4;stroke:#666}#mermaid-svg-ygisPfIwlu0EmPvq .activation2{fill:#f4f4f4;stroke:#666}#mermaid-svg-ygisPfIwlu0EmPvq .mermaid-main-font{font-family:"trebuchet ms", verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-ygisPfIwlu0EmPvq .section{stroke:none;opacity:0.2}#mermaid-svg-ygisPfIwlu0EmPvq .section0{fill:rgba(102,102,255,0.49)}#mermaid-svg-ygisPfIwlu0EmPvq .section2{fill:#fff400}#mermaid-svg-ygisPfIwlu0EmPvq .section1,#mermaid-svg-ygisPfIwlu0EmPvq .section3{fill:#fff;opacity:0.2}#mermaid-svg-ygisPfIwlu0EmPvq .sectionTitle0{fill:#333}#mermaid-svg-ygisPfIwlu0EmPvq .sectionTitle1{fill:#333}#mermaid-svg-ygisPfIwlu0EmPvq .sectionTitle2{fill:#333}#mermaid-svg-ygisPfIwlu0EmPvq .sectionTitle3{fill:#333}#mermaid-svg-ygisPfIwlu0EmPvq .sectionTitle{text-anchor:start;font-size:11px;text-height:14px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-ygisPfIwlu0EmPvq .grid .tick{stroke:#d3d3d3;opacity:0.8;shape-rendering:crispEdges}#mermaid-svg-ygisPfIwlu0EmPvq .grid .tick text{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-ygisPfIwlu0EmPvq .grid path{stroke-width:0}#mermaid-svg-ygisPfIwlu0EmPvq .today{fill:none;stroke:red;stroke-width:2px}#mermaid-svg-ygisPfIwlu0EmPvq .task{stroke-width:2}#mermaid-svg-ygisPfIwlu0EmPvq .taskText{text-anchor:middle;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-ygisPfIwlu0EmPvq .taskText:not([font-size]){font-size:11px}#mermaid-svg-ygisPfIwlu0EmPvq .taskTextOutsideRight{fill:#000;text-anchor:start;font-size:11px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-ygisPfIwlu0EmPvq .taskTextOutsideLeft{fill:#000;text-anchor:end;font-size:11px}#mermaid-svg-ygisPfIwlu0EmPvq .task.clickable{cursor:pointer}#mermaid-svg-ygisPfIwlu0EmPvq .taskText.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-ygisPfIwlu0EmPvq .taskTextOutsideLeft.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-ygisPfIwlu0EmPvq .taskTextOutsideRight.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-ygisPfIwlu0EmPvq .taskText0,#mermaid-svg-ygisPfIwlu0EmPvq .taskText1,#mermaid-svg-ygisPfIwlu0EmPvq .taskText2,#mermaid-svg-ygisPfIwlu0EmPvq .taskText3{fill:#fff}#mermaid-svg-ygisPfIwlu0EmPvq .task0,#mermaid-svg-ygisPfIwlu0EmPvq .task1,#mermaid-svg-ygisPfIwlu0EmPvq .task2,#mermaid-svg-ygisPfIwlu0EmPvq .task3{fill:#8a90dd;stroke:#534fbc}#mermaid-svg-ygisPfIwlu0EmPvq .taskTextOutside0,#mermaid-svg-ygisPfIwlu0EmPvq .taskTextOutside2{fill:#000}#mermaid-svg-ygisPfIwlu0EmPvq .taskTextOutside1,#mermaid-svg-ygisPfIwlu0EmPvq .taskTextOutside3{fill:#000}#mermaid-svg-ygisPfIwlu0EmPvq .active0,#mermaid-svg-ygisPfIwlu0EmPvq .active1,#mermaid-svg-ygisPfIwlu0EmPvq .active2,#mermaid-svg-ygisPfIwlu0EmPvq .active3{fill:#bfc7ff;stroke:#534fbc}#mermaid-svg-ygisPfIwlu0EmPvq .activeText0,#mermaid-svg-ygisPfIwlu0EmPvq .activeText1,#mermaid-svg-ygisPfIwlu0EmPvq .activeText2,#mermaid-svg-ygisPfIwlu0EmPvq .activeText3{fill:#000 !important}#mermaid-svg-ygisPfIwlu0EmPvq .done0,#mermaid-svg-ygisPfIwlu0EmPvq .done1,#mermaid-svg-ygisPfIwlu0EmPvq .done2,#mermaid-svg-ygisPfIwlu0EmPvq .done3{stroke:grey;fill:#d3d3d3;stroke-width:2}#mermaid-svg-ygisPfIwlu0EmPvq .doneText0,#mermaid-svg-ygisPfIwlu0EmPvq .doneText1,#mermaid-svg-ygisPfIwlu0EmPvq .doneText2,#mermaid-svg-ygisPfIwlu0EmPvq .doneText3{fill:#000 !important}#mermaid-svg-ygisPfIwlu0EmPvq .crit0,#mermaid-svg-ygisPfIwlu0EmPvq .crit1,#mermaid-svg-ygisPfIwlu0EmPvq .crit2,#mermaid-svg-ygisPfIwlu0EmPvq .crit3{stroke:#f88;fill:red;stroke-width:2}#mermaid-svg-ygisPfIwlu0EmPvq .activeCrit0,#mermaid-svg-ygisPfIwlu0EmPvq .activeCrit1,#mermaid-svg-ygisPfIwlu0EmPvq .activeCrit2,#mermaid-svg-ygisPfIwlu0EmPvq .activeCrit3{stroke:#f88;fill:#bfc7ff;stroke-width:2}#mermaid-svg-ygisPfIwlu0EmPvq .doneCrit0,#mermaid-svg-ygisPfIwlu0EmPvq .doneCrit1,#mermaid-svg-ygisPfIwlu0EmPvq .doneCrit2,#mermaid-svg-ygisPfIwlu0EmPvq .doneCrit3{stroke:#f88;fill:#d3d3d3;stroke-width:2;cursor:pointer;shape-rendering:crispEdges}#mermaid-svg-ygisPfIwlu0EmPvq .milestone{transform:rotate(45deg) scale(0.8, 0.8)}#mermaid-svg-ygisPfIwlu0EmPvq .milestoneText{font-style:italic}#mermaid-svg-ygisPfIwlu0EmPvq .doneCritText0,#mermaid-svg-ygisPfIwlu0EmPvq .doneCritText1,#mermaid-svg-ygisPfIwlu0EmPvq .doneCritText2,#mermaid-svg-ygisPfIwlu0EmPvq .doneCritText3{fill:#000 !important}#mermaid-svg-ygisPfIwlu0EmPvq .activeCritText0,#mermaid-svg-ygisPfIwlu0EmPvq .activeCritText1,#mermaid-svg-ygisPfIwlu0EmPvq .activeCritText2,#mermaid-svg-ygisPfIwlu0EmPvq .activeCritText3{fill:#000 !important}#mermaid-svg-ygisPfIwlu0EmPvq .titleText{text-anchor:middle;font-size:18px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-ygisPfIwlu0EmPvq g.classGroup text{fill:#9370db;stroke:none;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:10px}#mermaid-svg-ygisPfIwlu0EmPvq g.classGroup text .title{font-weight:bolder}#mermaid-svg-ygisPfIwlu0EmPvq g.clickable{cursor:pointer}#mermaid-svg-ygisPfIwlu0EmPvq g.classGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-ygisPfIwlu0EmPvq g.classGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-ygisPfIwlu0EmPvq .classLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.5}#mermaid-svg-ygisPfIwlu0EmPvq .classLabel .label{fill:#9370db;font-size:10px}#mermaid-svg-ygisPfIwlu0EmPvq .relation{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-ygisPfIwlu0EmPvq .dashed-line{stroke-dasharray:3}#mermaid-svg-ygisPfIwlu0EmPvq #compositionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-ygisPfIwlu0EmPvq #compositionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-ygisPfIwlu0EmPvq #aggregationStart{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-ygisPfIwlu0EmPvq #aggregationEnd{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-ygisPfIwlu0EmPvq #dependencyStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-ygisPfIwlu0EmPvq #dependencyEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-ygisPfIwlu0EmPvq #extensionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-ygisPfIwlu0EmPvq #extensionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-ygisPfIwlu0EmPvq .commit-id,#mermaid-svg-ygisPfIwlu0EmPvq .commit-msg,#mermaid-svg-ygisPfIwlu0EmPvq .branch-label{fill:lightgrey;color:lightgrey;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-ygisPfIwlu0EmPvq .pieTitleText{text-anchor:middle;font-size:25px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-ygisPfIwlu0EmPvq .slice{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-ygisPfIwlu0EmPvq g.stateGroup text{fill:#9370db;stroke:none;font-size:10px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-ygisPfIwlu0EmPvq g.stateGroup text{fill:#9370db;fill:#333;stroke:none;font-size:10px}#mermaid-svg-ygisPfIwlu0EmPvq g.statediagram-cluster .cluster-label text{fill:#333}#mermaid-svg-ygisPfIwlu0EmPvq g.stateGroup .state-title{font-weight:bolder;fill:#000}#mermaid-svg-ygisPfIwlu0EmPvq g.stateGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-ygisPfIwlu0EmPvq g.stateGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-ygisPfIwlu0EmPvq .transition{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-ygisPfIwlu0EmPvq .stateGroup .composit{fill:white;border-bottom:1px}#mermaid-svg-ygisPfIwlu0EmPvq .stateGroup .alt-composit{fill:#e0e0e0;border-bottom:1px}#mermaid-svg-ygisPfIwlu0EmPvq .state-note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-ygisPfIwlu0EmPvq .state-note text{fill:black;stroke:none;font-size:10px}#mermaid-svg-ygisPfIwlu0EmPvq .stateLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.7}#mermaid-svg-ygisPfIwlu0EmPvq .edgeLabel text{fill:#333}#mermaid-svg-ygisPfIwlu0EmPvq .stateLabel text{fill:#000;font-size:10px;font-weight:bold;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-ygisPfIwlu0EmPvq .node circle.state-start{fill:black;stroke:black}#mermaid-svg-ygisPfIwlu0EmPvq .node circle.state-end{fill:black;stroke:white;stroke-width:1.5}#mermaid-svg-ygisPfIwlu0EmPvq #statediagram-barbEnd{fill:#9370db}#mermaid-svg-ygisPfIwlu0EmPvq .statediagram-cluster rect{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-ygisPfIwlu0EmPvq .statediagram-cluster rect.outer{rx:5px;ry:5px}#mermaid-svg-ygisPfIwlu0EmPvq .statediagram-state .divider{stroke:#9370db}#mermaid-svg-ygisPfIwlu0EmPvq .statediagram-state .title-state{rx:5px;ry:5px}#mermaid-svg-ygisPfIwlu0EmPvq .statediagram-cluster.statediagram-cluster .inner{fill:white}#mermaid-svg-ygisPfIwlu0EmPvq .statediagram-cluster.statediagram-cluster-alt .inner{fill:#e0e0e0}#mermaid-svg-ygisPfIwlu0EmPvq .statediagram-cluster .inner{rx:0;ry:0}#mermaid-svg-ygisPfIwlu0EmPvq .statediagram-state rect.basic{rx:5px;ry:5px}#mermaid-svg-ygisPfIwlu0EmPvq .statediagram-state rect.divider{stroke-dasharray:10,10;fill:#efefef}#mermaid-svg-ygisPfIwlu0EmPvq .note-edge{stroke-dasharray:5}#mermaid-svg-ygisPfIwlu0EmPvq .statediagram-note rect{fill:#fff5ad;stroke:#aa3;stroke-width:1px;rx:0;ry:0}:root{--mermaid-font-family: '"trebuchet ms", verdana, arial';--mermaid-font-family: "Comic Sans MS", "Comic Sans", cursive}#mermaid-svg-ygisPfIwlu0EmPvq .error-icon{fill:#522}#mermaid-svg-ygisPfIwlu0EmPvq .error-text{fill:#522;stroke:#522}#mermaid-svg-ygisPfIwlu0EmPvq .edge-thickness-normal{stroke-width:2px}#mermaid-svg-ygisPfIwlu0EmPvq .edge-thickness-thick{stroke-width:3.5px}#mermaid-svg-ygisPfIwlu0EmPvq .edge-pattern-solid{stroke-dasharray:0}#mermaid-svg-ygisPfIwlu0EmPvq .edge-pattern-dashed{stroke-dasharray:3}#mermaid-svg-ygisPfIwlu0EmPvq .edge-pattern-dotted{stroke-dasharray:2}#mermaid-svg-ygisPfIwlu0EmPvq .marker{fill:#333}#mermaid-svg-ygisPfIwlu0EmPvq .marker.cross{stroke:#333}
:root { --mermaid-font-family: "trebuchet ms", verdana, arial;}</style>
<style>#mermaid-svg-ygisPfIwlu0EmPvq {
color: rgba(0, 0, 0, 0.75);
font: ;
}</style>
本地telnet客戶端
遠程telnet 服務器
1.用戶在telnet客戶端鍵入"hello" 字串并敲下回車鍵 2.客戶端軟體向telnet的服務器發送字串 3.telnet服務器從網路上接收到這個字串后,向遠端shell程式發送字串,遠端shell運行hello程式,并將輸出行回傳給telnet服務器 4.telnet服務器通過網路把輸出串轉發給telnet 客戶端 5.客戶端將輸出串輸出到本地終端上
這種客戶端和服務器之間互動的型別在所有的網路應用中是非常典型的
5.重要主題
Amdahl定律:要想顯著加速整個系統,必須提升全系統中相當大的部分的速度
執行緒級并發 :設計同時有多個程式執行的系統甚至在一個行程中執行多個控制流指令級并行 :較低抽象層次,可以同時執行多條指令,流水線將執行一條指令所需要的活動劃分成不同步驟,將處理器的硬體組織成一系列的階段,每個階段執行一個步驟,這些階段可以并行操作,用來處理不同指令的不同部分單指令、多資料并行 :最低層次,許多現代處理器擁有特殊硬體,允許一條指令產生多個可以并行執行的操作