Weekly Reading (2019/May 20 ~ 26)
1. redis系列–redis4.0深入持久化
Redis 快,但資料終究是存在記憶體裡面,還是得要有「持久化」的機制來保存重要的資料。
這篇文章就是在介紹 Redis 本身提供的「持久化」機制:
- RDB persistent
- AOF Persistence
- Mixed RDB and AOP
以及觸發的時機點:
- save command
- bgsave command
- save <second> <changes> rule
- Master-Slave duplication
- flushall command
- shutdown command
雖說另外透過 DB 來達到持久化也是常見的作法,但若有成本考量、維運考量等情況沒有額外的 DB 下,也不失為一個不錯的辦法。
2. Don’t talk CRUD
作者透過開發中最常見的資料操作 C (Create) R (Read) U (Update) D (Delete),說明開發者與客戶之間溝通的隔閡。
例如,對程式的會以 create 或 update 命名,但實際的功能邏輯並不只是單純的 create 和 update。
因此,作者建議透過共通的溝通方式,讓雙方能夠互相了解,也因此提到了 DDD (Domain Driven Design)可作為這樣的溝通語言。
3.「我們失敗了」系列文
簡單一句話,完美的團隊也會失敗。 對於產品,要找出「被使用者需要」的東西,而不是「讓使用者需要」。而這過程,除了 Fail Early, Fail Often 還要搶快,而搶快,也就表示對軟體的品質是要有所妥協的。 待達到 Product/market fit 再來調整。
4. Web Architecture 101
作者以使用者發出一次 Google 搜尋的資料流為例,介紹這樣大型甚至巨型的網站架構,包含 DNS 、 Load Balance 、 Database 等服務,都做了基本的介紹。