Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
單體式服務邁向微服務 @ MOPCON 2019
Search
Hash Lin
October 19, 2019
Technology
2k
3
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
單體式服務邁向微服務 @ MOPCON 2019
微服務的興起,透過微服務可以改善現有系統架構上的問題,是什麼原因讓 KKBOX 開始使用微服務?又是如何透過容器達到快速部屬與管理的,讓我們一探究竟。
Hash Lin
October 19, 2019
More Decks by Hash Lin
See All by Hash Lin
如何在微服務系統架構上導入 CI/CD
hashman
1
180
MOPCON 2019 資訊組工作方法
hashman
0
420
看 KKBOX 怎麼走通知這條路 @ COSCUP 2018
hashman
2
670
Other Decks in Technology
See All in Technology
Android の公式 Skill / Android skills
yanzm
0
110
AWSシリコン最前線 〜AI時代のチップ選択を読み解く〜
htokoyo
2
380
ルールやカスタム機能、どう活かす?ハンズオンで体感するIBM Bobの出力コントロール
muehara
1
120
10倍の生産性を実現するAI駆動並列エージェントのすべて
kumaiu
4
1.3k
機械学習を「社会実装」するということ 2026年夏版 / Social Implementation of Machine Learning June 2026 Version
moepy_stats
4
1.2k
個人最適 から 全体最適 へ AI情報共有会・AIギルド・AI-DLC で進める カンリーの組織展開
rfdnxbro
0
2.2k
Oracle AI Database@AWS:サービス概要のご紹介
oracle4engineer
PRO
4
2.9k
タクシーアプリ『GO』の実践的データ活用
mot_techtalk
3
190
就職⽀援サービスにおけるキャリアアドバイザーのシフトスケジューリング
recruitengineers
PRO
1
130
Agentic ERPをどう設計するか ー 受発注エージェントを動かす、現場の知見と設計思想ー
recerqainc
1
2.2k
自律型AIエージェントは何を破壊するのか
kojira
0
150
FDE という解 ― 暗黙知と明示知をつなぐ、伴走型エンジニアリング ―
otanet
0
120
Featured
See All Featured
The Pragmatic Product Professional
lauravandoore
37
7.3k
Leveraging Curiosity to Care for An Aging Population
cassininazir
1
270
How to Grow Your eCommerce with AI & Automation
katarinadahlin
PRO
1
200
Bridging the Design Gap: How Collaborative Modelling removes blockers to flow between stakeholders and teams @FastFlow conf
baasie
0
580
Keith and Marios Guide to Fast Websites
keithpitt
413
23k
Chasing Engaging Ingredients in Design
codingconduct
0
220
GraphQLの誤解/rethinking-graphql
sonatard
75
12k
The B2B funnel & how to create a winning content strategy
katarinadahlin
PRO
1
380
The AI Revolution Will Not Be Monopolized: How open-source beats economies of scale, even for LLMs
inesmontani
PRO
3
3.5k
From π to Pie charts
rasagy
0
200
Dominate Local Search Results - an insider guide to GBP, reviews, and Local SEO
greggifford
PRO
0
190
Claude Code どこまでも/ Claude Code Everywhere
nwiizo
65
56k
Transcript
KKBOX 後端工程師 Hash@MOPCON 單體式系統邁向微服務
單體式系統 邁向微服務 單體式系統 Monolithic 02 01 03 04 微服務系統 Microservices
部署 Deployment 案例分享 Case Study
小故事
KKBOX 誒誒,可以幫我升級一下 kkbox-search 套件 嗎? Channels Direct Message 主管 +
+ 好啊~ 感謝幫忙 hash rainycheng hash Monday, September 23th rainycheng 9+ 1
None
KKBOX Channels Direct Message 主管 + + 誒誒,這個套件是不是要安裝 opencc 在主機上面?
rainycheng Friday, September 27nd rainycheng 9+ 9+ ... 你又沒有說... 系統噴 Error 才發現 rainycheng 對啊,機器沒有裝唷? hash 喔喔拍謝忘了說,麻煩你請處理一下 hash … rainycheng
None
KKBOX Channels Direct Message 主管 大人 + + Friday, October
3nd 主管 Q 9+ 9+ 安安,我想要升級 CMS 主機 PHP 版本到 7.2 hash 好的,知道了 hash Hmm… 這個主機上面有不少服務運作,需要跟其他 Project owner 確認完才可以動手唷 主管 Q 天真可愛 / CQD / wesleyliao
KKBOX Channels Direct Message 主管 + + Friday, October 3nd
rainycheng 9+ 9+ 這很麻煩耶,需要花不少時間,你很急嗎? rainycheng 不好意思想問一下 xxx 專案是否可以升級上 PHP 7.2 呢? hash 是不會但是希望可以盡快升級(汗... hash 我抽空處理,不保證什麼時候可以完成唷 rainycheng
有沒有很眼熟呢?
單體式系統 (Monolithic) 01
None
None
None
單體式系統缺點 異動套件 / 設定檔 不得隨意異動系統伺服器 上的套件或是設定檔 注意相依性 任何套件的升級,都需要 特別注意這個套件所帶來 的相依性
建置成本高 須顧及應用程式所有 相依性進行建置
微服務 02
去耦合 將服務切分成獨立的 個體,服務獨立運作 微服務 將單體式系統拆成多個小服務 這些服務都會透過定義好的介面 進行溝通 介面 服務與服務間僅有 介面相依
降低發佈風險 一次發佈一個服務
None
舒服 乾淨 清楚 明瞭
微服務真美好
注意 Latency 上升
None
注意 Latency 上升 Debug 困難
None
注意 Latency 上升 傳輸不可靠 Debug 困難 主機數成長
None
▪ 重複的程式碼 ▪ 相依性過高 ▪ 效能瓶頸 界定服務邊界
部署 03
Gitlab Open Source CI Third Party Github * V Gitlab
V V V BitBucket V V
1. 自動化檢查 2. 透過 Docker 進行不同版本的測試 3. 確保每次的 Merge 都是綠燈
Gitlab CI Installation Check Testing Deploy CI / CD
.gitlab-ci.yml Gitlab CI
Sending Merge Request Develop Continuous Integration Review & Merge Request
Continuous Deployment Run CI Pipeline 1. Install Project 2. Unit Test Build Docker Image Docker Hub / Private Docker Registry
Live Demo
案例分析 04
去耦合
None
Project 1 kkbox-search v1.x v1.x Project 2 kkbox-search v1.x Project
3 kkbox-search v1.x
Project 1 kkbox-search v1.x Project 2 kkbox-search v1.x Project 3
kkbox-search v1.x v1.x v2.x
Project 1 kkbox-search v2.x Project 2 kkbox-search v2.x Project 3
kkbox-search v2.x v1.x v2.x
Project 1 Project 2 Project 3 API Search kkbox-search v1.x
v1.x v2.x
Project 1 Project 2 Project 3 API Search kkbox-search v2.x
v1.x v2.x
Docker 與微服務帶來的方便
Server A Ubuntu 16.04 + PHP 5.6 Project A Project
A Project A Project A Project A Project A Server B Ubuntu 16.04 + PHP 5.6 Server C Ubuntu 16.04 + PHP 5.6 Server D Ubuntu 16.04 + PHP 7.2 Server E Ubuntu 16.04 + PHP 7.2 Server F Ubuntu 16.04 + PHP 7.2 Project B Project B Project B
HA Proxy Ubuntu 16.04 + PHP 5.6 Project A Cloud
Ubuntu 16.04 + PHP 5.6 Project A Ubuntu 16.04 + PHP 5.6 Project A Ubuntu 16.04 + PHP 5.6 Project B Ubuntu 16.04 + PHP 5.6 Project B Ubuntu 16.04 + PHP 5.6 Project B
HA Proxy Ubuntu 16.04 + PHP 7.2 Project A Cloud
Ubuntu 16.04 + PHP 7.2 Project A Ubuntu 16.04 + PHP 7.2 Project A Ubuntu 16.04 + PHP 5.6 Project B Ubuntu 16.04 + PHP 5.6 Project B Ubuntu 16.04 + PHP 5.6 Project B
單體式系統 邁向微服務 單體式系統 Monolithic 02 01 03 04 微服務系統 Microservices
部署 Deployment 案例分享 Case Study
你們也有這些問題嗎?
Does anyone have any questions?
[email protected]
Thank you!