網路如何運作
用戶與伺服器
連接到網路的電腦稱為用戶端(client)與伺服器端(server)。彼此的連結原理如圖所示:
- 用戶端是網路用戶的典型上網設備(像是連到 Wi-Fi 的電腦、或是連到手機網路的手機),這些設備通常有能夠上網的軟體(通常是 Firefox 或 Chrome 之類的瀏覽器)。
- 伺服器端是放著網頁、網站、或者 app 的電腦。當用戶端設備要訪問網頁時,網頁的副本會從伺服器下載到用戶端,以便顯示在用戶的瀏覽器。
百寶箱的其他魔法
剛剛描述的用戶/伺服器端還不是一切,我們還要講述其他部份,才能說完整個故事。
現在把網路想像成一條大道。大道的一端是用戶端,就像你家一樣;另一端則是伺服器,就像是你要去血拼的商店。
除了用戶與伺服器之外,我們還需要和這些朋友們打招呼:
- 網路連線:讓你可以在網路傳送與接收資料。基本上就像是家裡到商店一樣。
- TCP/IP:傳輸控制協定和網際網路協定(Transmission Control Protocol and Internet Protocol)是定義資料如何在網路通行的通訊協定。這就像是方便你去商店買東西的交通工具。在這裡本例中,這就像是車子、腳踏車、或其他你想得到的交通工具。
- DNS:網域名稱系統(Domain Name Servers)就像是網站的電話簿。當你在瀏覽器輸入網址時,瀏覽器會在取得網站前,先去看 DNS 以查到網站的真實地址。瀏覽器需要找到哪個伺服器在託管指定的網站、這樣才能把 HTTP 訊息傳送到對的地方(可以參考下文)。這就像你在去商店前會先翻開電話簿,才好去商店一般。
- HTTP超文本傳輸協定(Hypertext Transfer Protocol)是定義用戶端語言,和伺服器如何對話的應用協議。可以想成你買東西時會用來溝通的語言。
- Component files:網站由許多不同的文件組成,如同商店內許多不同的商品。這些檔案分為以下類型:
- 程式檔:網站主要是由 HTML、CSS、JavaScript 建立,雖然你知會看到其他工具或技術。
- Asset:這是構成網站其他內容的集體名稱,裡面可能包含圖像、音樂、影片、Word、PDF……之類的。
所以我說到底發生了啥?
當你在瀏覽器輸入網址時(你可以想像說自己要走去商店時):
- 瀏覽器會先去 DNS 伺服器尋找託管網站的伺服器,其真實位置所在(如同你去尋找商店的地址)
- 瀏覽器向伺服器傳送 HTTP 訊息,請求伺服器向用戶端傳送網站的複本(如同去商店下訂單)。在用戶端及伺服器的之間,請求訊息與其他資訊,會使用 TCP/IP 在網路連線之間傳送。
- 伺服器如果允許用戶端請求,伺服器就會傳送「200 OK」訊息,意味著「好,你可以閱覽這個網站,那我給你網站資料囉~」並開始對瀏覽器以一小串稱作「資料封包」的組合形式,傳送網站的檔案。這就像是商店給你商品,你接著把它們都帶回家一樣
- 瀏覽器把一小塊一小塊的東西,組合成完整的網站,並把它呈現起來--商品送到家門口後,閃亮亮的新貨在你眼前,超棒的啦!
講講 DNS
再講講封包
稍早我們用了「封包」來描述從伺服器傳到用戶端的資料格式。這裡的「封包」是什麼意思呢?通常資料在網路傳送時,會傳送上千個小資料,這樣在同一時間和同一網站,才能有很多用戶下載內容。如果網站只傳送一個大傢伙過去,那在同一時間就只能有一個用戶能下載,網路會變得很慢、很無聊...
參見
製作群
街頭的照片:Street composing、作者是Kevin D。