Amo Chen

用 Python 學網路程式設計重要概念 — 從單執行緒到 I/O 多工(I/O multiplexing)

在學習網路程式設計時,每個人都遇過怎麼讓 sever 可以盡可能地處理更多連線的課題,要達到這個目的,多數人直覺應該會想到運用多執行緒、多 processes 的架構,為每個連線建立 1 個新的執行緒或 process 處理,但是這種方法在處理大量連線時,就顯得捉襟見肘,單就多執行緒的解決方案來說,隨著連線數上升,首先就會遇到 CPU context switch 所造成的效能問題,更遑論多 processes 架構會需要使用比多執行緒架構更多資源的問題。

但現代有很多應用僅用單執行緒就能夠處理龐大的連線數,包含 Nginx, Redis 等知名開源軟體,這些軟體是怎麼做到的呢?這就需要談到 1 種稱為 I/O multiplexing 的技術!

本文將教導 1 種稱為 I/O multiplexing 的技術,該技術能夠讓單執行緒處理多個連線,將效能壓榨出來!

p.s. 這個技術還可以與多執行緒、多 processes 架構混用

Posted on  May 12, 2024  in  Python 程式設計 - 中階  by  Amo Chen  ‐ 15 min read

好文分享 — Select vs. Poll vs. Epoll

Nginx 的 worker_processes 其實每 1 個都是 single-threaded process 。 Nginx 之所以採用 single-threaded processes 還能這麼高效能,這其中用了不少技術,其中 1 個稱為 multiplexing 。 相信很多人看到這個單字就不想深究了,但其實它只

Posted on  May 10, 2024  by  Amo Chen  ‐ 1 min read

你知道 Port 0 嗎?

開發 TCP/IP 應用服務的人應該都知道通訊埠(port),譬如 HTTP server 通常都使用 80 port, HTTPS 則通常使用 443 port, SMTP 協定則使用 25 port 等等。 通訊埠的範圍為 0 - 65535, 其中通訊埠 0

Posted on  May 8, 2024  by  Amo Chen  ‐ 1 min read

趣文分享 — 睡覺也能做好排序?

“Sleepsort: Sorting while sleeping” 是 1 篇很有趣的文章,內容是講 1 個稱為 Sleep Sort 的排序方法,沒看錯,就是 Sleep 。 Sleep Sort 據聞最早是 2011 年有人在 4Chan 提

Posted on  May 6, 2024  by  Amo Chen  ‐ 1 min read

Python 豆知識 — str.partition(sep)

假設有以下字串: s = 'data1: {"title": "abc", "content": "123"}' 當我們想把字串切成 data1 與 {"title": "abc", "content": "123"} 2 個部分的話,多數人應該直覺會想到 s.split(': ')[0] 與 ': '.join(s.split(': ')[1:]) 這個簡單的方法。 但是上述解法有個問

Posted on  May 5, 2024  by  Amo Chen  ‐ 1 min read

帶你搞懂 Python 的 Iterable, Iterator 與 Generator

Python 的 Iterable, Iterator 與 Generator 是經常會讓人產生混淆的事物,因為這 3 個都可以用 for 迴圈走訪,因此有些熟悉 Python 的面試官很喜歡問這 3 者之間的差異,追根究底是因為對這 3 者不熟悉的話,很容易寫出類似以下的低效率程式碼:

set([x for x in iterator])

本文將透過實際範例帶大家認識 Iterable, Iterator 與 Generator! 再也不搞混!

Posted on  May 3, 2024  in  Python 程式設計 - 中階  by  Amo Chen  ‐ 4 min read