Re: [請益]高流量網站和資料結構

軟工

16160

: 先自承是非本科的新人
: 最近看了版上的討論串,覺得自己的確實是
: 沒有CS基礎的API工程師,以前在學校修過資料結構
: 但是只有一些很粗糙的觀念
: 像是hash function因為返回的是index,所以在查找資料上非常快
: 目前還在惡補基礎的DS,至於OS和計算機組織就真的完全沒概念了
: 每次看到thread,大概就止步於看到那種for loop 交叉印出不同函數的例子
: 自己稍微爬文下來,不太懂如果要往高流量網站的設計邁進
: 該怎麼去活用那些知識
: 我爬文的結果有點像是
: 如果一張資料庫數量超過百萬
: 那這樣就要想辦法把資料分成不同的表格
: 然後這時hashmap 就可以幫你找到不同的表格這樣?
: 爬文大概看到以下方法
: 1.建立多個File server , 寫hash function 將上傳的圖片及影音平均分散到File server
: 上的Folder
: 2.Query優化、索引優化及將負載重的table做反正規化以減少資料庫負荷
: 建立Master /Slave 資料庫,分散Master主機loading,將讀寫資料庫動作分離,
: Matster DB只負責被寫入及複製,Slave DB負責被讀取
: 3.可能還有一些cache之類的
: 比如說像是搶票網站好了
: https://imgur.com/TON1Nid

: 看到有人說可以這樣解決
: 那像這樣的知識,是不是要想辦法進去大公司才有辦法學到
: 比較難在網路上,像是一般的前後端CRUD一樣容易獲得?
: 另外想問說,如果有一個API,他是getallemployee好了,打了url就要返回所有的員工
: 資料,這是如果是高併發高流量的網站設計
: 該怎麼活用資料結構,才能讓網站不要LAG
這是常用場景,已知問題,所以有很多解決方案。
其中一種就是類似Twtiiter的Push架構,每次新增一個員工就把資料寫進cache&DB
然後API打進來先去問cache要資料,然後cache多設幾個組成一個cluster,
避免單點失效...這些知識都可以從下面推薦的網站中學到,不用做過也略知一二

: 還是說這可能跟資料結構比較無關,我要去補充其他知識才會知道
: 如果可以的話,希望前輩們可以分享哪些關鍵字或是網站有sample code可以查詢
System Design Primer
https://github.com/donnemartin/system-design-primer


InfoQ
https://www.infoq.cn/topic/architecture


Grokking the System Design Interview
https://www.educative.io/courses/grokking-the-system-design-interview


HiredInTech
https://www.hiredintech.com/classrooms/system-design/lesson/52


System Design Interview
https://github.com/checkcheckzz/system-design-interview


Awesome Scalability
https://github.com/binhnguyennus/awesome-scalability


SYSTEM DESIGN INTERVIEW- AN INSIDER'S GUIDE
https://systeminterview.com/



另外我推薦分散式系統聖經 Design Data-Intesive Application
就這些內容,全看完不可能 但掌握幾個大方向你的系統設計能力就不會差



--
學弟名言:

讀書是三小 我只知道毒玉

延畢是三小 我只知道炎玉


--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 61.57.146.63 (臺灣) ※ 文章網址: https://www.ptt.cc/bbs/Soft_Job/M.1629530059.A.B0A.html
kor5251樓分享 推個 08/21 15:20
kvjo2樓來看看 08/21 16:42
tttkkk3樓推! 08/21 17:01
WaterLengend4樓謝謝分享 08/21 17:21
BlacksPig5樓感謝分享這些資源,thx! 08/21 17:41
bjk6樓111 08/21 18:16
ntpuisbest7樓ty 08/21 19:22
bjk8樓11 08/21 19:28
as2090999樓推感謝 08/21 23:47
ufap10樓謝謝分享 08/22 01:21
umum2911樓推DDIA 每次重看都有不同收穫 聖經啊 08/22 02:34
k79897686912樓good 08/22 03:02
k90042113樓 08/22 06:18
popmentos14樓 08/22 08:43
garylai0000015樓感謝分享資源 08/22 16:49
Yunyung16樓 08/23 03:50
devilkool17樓 08/23 08:57