JSDC 2017
Simon Sun
標題殺人法XD
發現台灣讀者又愛看又愛罵XD
網路新媒體轉型後端架構實作經驗分享
JSDC 2017
Simon Sun
好拉...看起來題目也沒有很酷炫也沒有屌炸天XD
自我介紹
Simon Sun
寫 code 是工作也是興趣
喜歡 JS 高彈性就如我的個性
JSDC 成員
email: blackghost0118@gmail.com
1. 了解舊架構與規劃新架構
2. 雲端服務選擇
3. 實作 Backend 的經驗分享
4. 雲端上遇到實作問題與解決方案
5. 結論
6. Q&A
+
ADMIN
DB converter
+
WEB
其實這個架構認真來說沒什麼問題
但是就是常常出問題
所以我真心覺得
應該是人的問題......
1. MySQL 移轉資料到 Mongo 有夠暴力
3. 交接者不了解系統架構就硬幹
2. 系統並沒有持續更新
4. 無法重現開發環境
了解完整個架構之後
新媒體的元素??
1. 地區化
2. 個人化
3. 影音圖片
4. 直播
5. AR, VR 應用
最後有空再來吐槽....
思考新架構方向
1. 後台上稿
2. 前台顯示
3. RSS
4. Mobile
5. APP
6. 公司其他網站
7. 合作公司資料授權
做一套,可以給任何平台串接
All Services Around API
1. 我們只需要專心處理 api 效能問題
2. 擴展容易
3. 輸出格式統一,文件統一
4. 抽換功能與模組容易
WHY?
API 主要架構
CHANGELOG.md
CHANGELOG.md
1. 確認功能發布時間
2. 秋後算賬
3. 了解夥伴改了什麼
ADMIN/
ADMIN/
app.js - 主要啟動程式
controllers/ - routers
middlewares/ - 中介處理
errorHandlers/ - 錯誤處理
validators/ - 驗證資料
WEB/
WEB/
app.js - 主要啟動程式
controllers/ - api routers
middlewares/ - 中介處理
errorHandlers/ - 錯誤處理
event/ - 活動使用的 api
Config/
CRON/
CRON/
rss.js - 匯入外部RSS新聞
hot.js - 更新熱門新聞
keywords.js - 更新熱門關鍵字
CRON/
Documents/
Libs/
Libs/
download.js - 下載檔案
hash.js - 密碼加密處理
htmlToString.js - 將所有 html 轉換成純文字
Database 的選擇
1. Read >> Write
2. JSON Format
Mongo/
Redis/
好處
1. 共用 Mongo 與 Redis 的 schema 與 method
2. 共用 libs
3. 易於統一管理
壞處
1. node_modules 太肥大
2. 架構會很肥大,巢狀層數太多
1. 了解舊架構與規劃新架構
2. 雲端服務選擇
3. 實作 Backend 的經驗分享
4. 雲端上遇到實作問題與解決方案
5. 結論
6. Q&A
大家還記得 8/15 那天嗎 ?
事件回憶錄
為何要上雲端?
1. 開設機器的時間
2. 自動擴展能力
3. 維運人員隱形成本
UI (個人認為)
功能
費用 (各代理商報價)
Other
1. 機房
2. 社群支援度 (GCPUG)
3. 未來公司需要整合的功能
4. 300 鎂的試用
就決定是你了..... GCP
1. 了解舊架構與規劃新架構
2. 雲端服務選擇
3. 實作 Backend 經驗分享
4. 雲端上遇到實作問題與解決方案
5. 結論
6. Q&A
async / await
async / await (優點)
1. 遠離 callback, Promise 地獄
2. 增加程式碼易讀性
3. 非同步操作更為簡便
async / await (缺點)
1. babel 好大包 QAQ
2. 其他缺點暫時沒想到 XD
模組化
一個檔案就是一個模組,都盡量處理單一功能
一個大的功能,都是由小模組組成
模組化 (優點)
1. 每個小模組都有獨立功能,程式碼單純
2. 看大功能就像看一篇文章
3. 抽換功能容易
模組化 (缺點)
1. 有些不常使用的程式碼也會被包成小模組
2. 架構上會非常龐大,檔案也非常多
3. 如果要做些許改變,就要獨立做另外一個模組
大量使用 middlewares
大量使用 middlewares (優點)
1. 資料驗證與邏輯區分離
2. code 會更簡潔,controllers 更單純
大量使用 middlewares (缺點)
1. 多了一層驗證的架構
2. 檔案變更多了 Orz
Redis Cache (優點)
1. 新聞平台讀比寫多,所以很適合使用 Cache
2. 搭配 mongo 的 JSON 格式更容易處理
3. 效能好速度快
4. 搭配 cronjob 可以處理較慢的資料
Redis Cache (缺點)
1. 更新時間有落差
2. 資料變更會比較麻煩
Mongodb
1. 盡量少於兩層的巢狀結構
2. 定義 schema 避免前端處理過多的事情
3. index, index, index
4. db.system.profile.find({ millis : {$gt : 300} })
5. db.xxx.find({}).explain()
Api Response Time
Api 系統效能
Mongodb 系統效能
Redis 系統效能
1. 了解舊架構與規劃新架構
2. 雲端服務選擇
3. 實作 Backend 的經驗分享
4. 雲端上遇到實作問題與解決方案
5. 結論
6. Q&A
Load Balancing
無法自己分配比重
所以自己開一台 VM + nginx
QAQ
mail server
自己做一台 api server 做介接
QAQ
CDN
自己做一個 image thumbnail server
QAQ
流量費好貴,又不想在上傳的時候縮圖
1. 了解舊架構與規劃新架構
2. 雲端服務選擇
3. 實作 Backend 的實做經驗
4. 雲端上遇到實作問題與解決方案
5. 結論
6. Q&A
1. 在評估成本後,上雲端方便很多
2. 需要 SEO 還是乖乖做 SSR
3. 系統再快還是抵不過過多的廣告
4. 如果可以我會選用一個完整的 CMS 當後台
5. 神一般的夥伴很重要
Q & A