架構師訓練營 week11 總結
11.1 安全架构:Web攻击与防护
Cross-Site Scripting (XSS)
https://zhuanlan.zhihu.com/p/61773197
Sql injection
预编译和绑定变量
Cross-site request forger (CSRF)
https://blog.techbridge.cc/2017/02/25/csrf-introduction/
Others
文件上傳
路徑遍歷
將 Javascript, CSS 等資源文件獨立服務器,獨立域名
11.2 安全架构:加密与解密
單向散列加密
data:image/s3,"s3://crabby-images/44b6a/44b6a4dc159d35f1821e9a0746f579241dea7347" alt=""
data:image/s3,"s3://crabby-images/9beb2/9beb2426d8bbdca56b85276089ab59f5d8767e22" alt=""
對稱加密
data:image/s3,"s3://crabby-images/69cb1/69cb1a94509a0a0aadeba5bd316433a0d65061b8" alt=""
非對稱加密
data:image/s3,"s3://crabby-images/36890/36890ce9b60fe05a596277837b3ca8035c02e4c9" alt=""
密匙安全管理與加解密服務系統架構
data:image/s3,"s3://crabby-images/e5dfc/e5dfc99b65486cece73611cf5af297caa8fd681f" alt=""
11.3 安全架构:反垃圾与风控
data:image/s3,"s3://crabby-images/516d2/516d297848c115a675b783e20b47d831ce5f9512" alt=""
Bayes' theorem
Bloom Filter
https://medium.com/@Kadai/%E8%B3%87%E6%96%99%E7%B5%90%E6%A7%8B%E5%A4%A7%E4%BE%BF%E7%95%B6-bloom-filter-58b0320a346d
電商風控系統
data:image/s3,"s3://crabby-images/e82d5/e82d5baf3ccfff09cc78baa6b5a322ede74d9708" alt=""
11.4 高可用:可用性度量
可用性指標:幾個9
故障處理流程及考核
data:image/s3,"s3://crabby-images/122da/122da310f862f5a4145a39913356045c5a70367c" alt=""
故障的原因
硬體故障
軟體bug
系統發佈
併發壓力
網路攻擊
外部災害
11.5 高可用:提升系统可用性的架构方案
解耦
高內聚、低耦合的組件設計原則
面相對象基本設計原則
面相對象設計模式
領域驅動建模
隔離
業務與子系統隔離
維服務與中台架構
生產者消費者隔離
虛擬機與容器隔離
異步
multi-thread
async
event-driven
data:image/s3,"s3://crabby-images/d8e32/d8e32a20f4641bba4501387907b487c16d0ef2c5" alt=""
備份
集群
CAP (Consistency, Availability, Partition tolerance)
https://zhuanlan.zhihu.com/p/20399316
Failover
database
load balancer
how to detect, how to transfer
design no-state service
冪等
idempotent是HTTP方法的屬性,表示不管執行多少次操作請求,都將產生相同的結果。
https://www.cnblogs.com/bukudekong/p/3837696.html
事務補償
ACID
Atomicity, Consistency,
Isolation, Durability
分佈式 BASE
Basic Availability, Soft-state, Eventual Consistency
Retry
熔斷
data:image/s3,"s3://crabby-images/b87d2/b87d25750a4d070079d04a858e65238af1e71b0f" alt=""
限流
計數器算法
固定窗口、滑動窗口
令牌桶算法
漏桶算法
自適應限流
data:image/s3,"s3://crabby-images/3714f/3714fc45d4ad75cd3af705a7cc8825e4680d560f" alt=""
降級
異地多活
11.6 高可用:架构运维方案
Deployment
data:image/s3,"s3://crabby-images/4d5f6/4d5f6221052eb85ddb3ab9b839d3711f9018b5a2" alt=""
預發佈驗證
先發佈的預發佈機器上
data:image/s3,"s3://crabby-images/18f33/18f3396b6d68ccb4901f867a204a802c37794903" alt=""
發佈流程
data:image/s3,"s3://crabby-images/896d8/896d84a32a4131ea8c09fe8061d5c143b4dc506f" alt=""
灰度發佈
一次發佈部分
data:image/s3,"s3://crabby-images/1446b/1446b581766f9d9cab792c1e86a3b5a0ca0bd297" alt=""
網站運行監控
監控數據採集
用戶行為日誌收集
服務性能監控
業務運行數據報告
監控管理
data:image/s3,"s3://crabby-images/0b0b3/0b0b3130ed978456fb2d8e1ad055899ec58d5a9a" alt=""
高可用的價值觀
data:image/s3,"s3://crabby-images/092df/092df79867cf627ea5ec24f25221fae33beb9475" alt=""
11.7 高可用故障案例分析
經驗學習
data:image/s3,"s3://crabby-images/24d4f/24d4fdd40c02481f8465e997e3bad02ca7093c1a" alt=""
data:image/s3,"s3://crabby-images/71565/71565dc5aa30d5d504ef5e310cb772333737ddd0" alt=""
檢查 Log 配置文件,Log Level at least need to be "Warn"
3-party Lib log Level sometimes has too many Error log, need to turn off
separate our log and 3-party's log
data:image/s3,"s3://crabby-images/d5ce4/d5ce4715a5285f4940eba6d372f5808d7db16fcb" alt=""
data:image/s3,"s3://crabby-images/c7846/c7846e9819b1f580c4bfac1c6760ac3fb6a4188e" alt=""
首頁不應該訪問 DB,
首頁的資料應該使用 cache or search engine
首頁最好是靜態的
data:image/s3,"s3://crabby-images/daeba/daebad55bc1e8d697845b5be442bdd827b998a4e" alt=""
data:image/s3,"s3://crabby-images/609ef/609ef5167c1f27de8b2531b804b983f5d719c56b" alt=""
使用鎖時要很謹慎,特別是有長時間 IO 操作的時候
使用不同的鎖在不同的場景
data:image/s3,"s3://crabby-images/67d76/67d7662c74482cc663d18b33e296738d9129226d" alt=""
data:image/s3,"s3://crabby-images/09423/0942315702bf15769aec3e96056d54d0e8d6bdee" alt=""
cache management
data:image/s3,"s3://crabby-images/abcd1/abcd1e1cba1e209818e771d6c1d1bea7ebd55ee7" alt=""
data:image/s3,"s3://crabby-images/b242e/b242e50ccede01e878d4052d85b3eabf30ffc320" alt=""
deployment 各個元件操作的先後順序
data:image/s3,"s3://crabby-images/e3a6e/e3a6e6ad1cdf5c54868e1c058cdad396747cff4a" alt=""
data:image/s3,"s3://crabby-images/25356/2535634f4dc90b65a2756394075e38537d6296e5" alt=""
存儲文件的管理
根據不同的文件類型和用途分別管理
小文件不能和大文件共用儲存
批次處理用的大文件可以用其他的分佈式文件系統
data:image/s3,"s3://crabby-images/bd6dc/bd6dc0105e42697332caff217ff801d92073e0c0" alt=""
data:image/s3,"s3://crabby-images/f48e8/f48e8a8d72512f2ea0809031a6eb7475418b7146" alt=""
production 環境的管理規範,不能讓人隨便用 production 環境
data:image/s3,"s3://crabby-images/88677/886778bbfe19a0b46e43d46f4ec745993a1cd1b7" alt=""
data:image/s3,"s3://crabby-images/746e2/746e21b5fb786fd92ba99add10e1da34756a7f81" alt=""
code versioning control
data:image/s3,"s3://crabby-images/33dc3/33dc3d5da655559529c199a540d525baad027dd9" alt=""
data:image/s3,"s3://crabby-images/ee7cd/ee7cd7789e3b39c0cad1d0d4fcf461287c901711" alt=""
default 初始資料的處理
评论