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
運用について - 2020 Chatwork サマーインターンシップ
Search
tan-yuki
December 09, 2020
Technology
0
710
運用について - 2020 Chatwork サマーインターンシップ
tan-yuki
December 09, 2020
Tweet
Share
More Decks by tan-yuki
See All by tan-yuki
モノリスから小さなシステムへ / Chatworkシステム移行の現在地と今後について@開発生産性カンファレンス
tanakayuki
3
4.3k
2024-03-16 社員30人 → 300人のフェーズを経験し見えてきた、 エンジニアとして成長するための考え方
tanakayuki
5
1.4k
リリースから12年! Chatworkの過去をふりかえり ~ ChatworkとPHPの歩み ~
tanakayuki
0
450
フィーチャーチーム化への取り組みと、それを支える組織マネジメント体制
tanakayuki
2
22k
Chatworkから学ぶインフラサービス提供の心得.pdf
tanakayuki
0
1.4k
ChatWorkとPHPと私
tanakayuki
14
15k
開発者からみたCloudSearch
tanakayuki
2
2.6k
git
tanakayuki
3
520
Other Decks in Technology
See All in Technology
デジタル化・DX推進あるある
y150saya
0
240
OCI で始める!! Red Hat OpenShift / Get Started OpenShift on OCI
oracle4engineer
PRO
1
110
四国のあのイベントの〇〇システムを45日間で構築した話 / cloudohenro2024_tachibana
biatunky
0
300
なぜクラウドサービスで Web コンソールを提供するのか
shuta13
4
2k
Optuna: a Black-Box Optimization Framework
pfn
PRO
1
100
AWSを始めた頃に陥りがちなポイントをまとめてみた
oshanqq
1
3.4k
事前準備が肝!AI活用のための業務改革
layerx
PRO
1
120
エンジニア視点で見る、 組織で運用されるデザインシステムにするには
shunya078
1
290
Mocking in Rust Applications
taiki45
1
360
自社サービスのための独自リリース版Redmine「RedMica」の取り組み
vividtone
0
1.1k
Monitor GraalVM Native Apps with OpenTelemetry
logico_jp
0
120
FastConnect の冗長性
ocise
0
7.2k
Featured
See All Featured
ReactJS: Keep Simple. Everything can be a component!
pedronauck
663
120k
Six Lessons from altMBA
skipperchong
26
3.3k
Principles of Awesome APIs and How to Build Them.
keavy
125
16k
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
354
29k
Imperfection Machines: The Place of Print at Facebook
scottboms
263
13k
Docker and Python
trallard
39
3k
Making Projects Easy
brettharned
113
5.8k
Gamification - CAS2011
davidbonilla
79
4.9k
What’s in a name? Adding method to the madness
productmarketing
PRO
21
3k
Java REST API Framework Comparison - PWX 2021
mraible
PRO
27
7.4k
Why You Should Never Use an ORM
jnunemaker
PRO
53
8.9k
Documentation Writing (for coders)
carmenintech
65
4.3k
Transcript
運用について 2020サマーインターンシップ Chatwork株式会社 開発本部 副本部長 兼フロントエンド開発部MGR 田中 佑樹
アジェンダ 1. SaaSシステムにおける運用とは? 2. 運用を侮るなかれ 3. メトリクスとモニタリング 4. 緊急対応(オンコール対応) 5.
セキュリティ 6. まとめ 2
01 SaaSシステムにおける運用とは?
01 SaaSシステムにおける運用とは?
SaaSとは?
SaaSとは? Software as a Service • ソフトウェアをパッケージとして利用するのではなく、クラウド(インターネッ ト)経由で利用する形態のこと • ChatworkもSaaS
6
SaaSのメリット • 必要な分だけ利用する ◦ → コストが安く抑えられる • 需要の急増に対応しやすい • スポットでの利用もしやすい
7
SaaSのデメリット • SaaSシステムがダウンしていると、そのシステムを利用できなくなる ◦ → 自社業務がSaaS運営母体依存となってしまう • クラウド経由での利用となるため、ネットワークコストがかかる • セキュリティ上の懸念
8
運用とは?
運用とは? 10 引用) https://ja.wikipedia.org/wiki/%E3%82%B7%E3%82%B9%E 3%83%86%E3%83%A0%E9%81%8B%E7%94%A8 > システム運用(システムうんよう)はシステムがもつ機能を発揮させ用いること、 また継続的に発揮させるためにシステムを維持管理することである
SaaSにとって運用は生命線 • SaaSの特性上、1つのシステムを長期間に渡って安定稼働させることが至上命題 • 長期間にわたって安定稼働させるために重要なことはなにか? ◦ いろいろある ◦ いろいろあるが、その1つが運用設計 11
• 抽象的にいうと ◦ Check <-> Do の仕組みづくり • 具体的にいうと ◦
監視システム設計(Checkの仕組み) ◦ 運用体制の確立(Doの仕組み) 運用設計でやること 12
• 問題が発生している(あるいは発生しそうな)ことを検知できず、なにもせずに 「システムがとまりました!」じゃ済まされない • 稼働中のシステムに問題がないか?を検知する仕組み ◦ → システム監視、モニタリング、メトリクス 監視システム設計 13
• 運用メンバー選定 ◦ ボランティア運用は必ず破綻する ▪ 役割の明確化とそのインセンティブ設計が非常に重要 • 発生しうる運用業務のリストアップ • それらの運用業務フローの設計
◦ 障害対応手順フロー確立 ◦ マニュアル / ドキュメンテーションの整備 ◦ etc... 運用体制の確立 14
• 使用している各種ライブラリの定期的な棚卸し、バージョンアップデートの定型化 • 使用している外部システムの棚卸しの定型化 • アカウントの棚卸しの定型化 • etc... ほかにもあるよ!運用設計でやること 15
• 運用設計をもとにした運用業務が日々ついてまわる ◦ → システムが増えれば増えるほど、運用業務は重くのしかかってくる 運用業務 16
• 組織体制の代表的なものとして、機能別組織と機能横断型組織がある • 機能別組織 ◦ 能力で別れている ▪ サーバーサイド部 ▪ フロントエンド部
▪ プロダクトマネジメント部 ▪ ・・・ • 機能横断型組織 ◦ ある目的をもった、職能・職種を横断して結成したチーム ▪ APIチーム ▪ 管理画面チーム ▪ ・・・ Appendix. 機能別組織と機能横断型組織 17
Appendix. 機能別組織と機能横断型組織 機能別組織のメリット • 特定の技能に関する専門性が高めやすい • 運用に必要な技術をチーム内で確立しやす い 18 機能別組織のデメリット
• 複数システムを運用している場合、 1チームでの運用対象のシステムが多く なってしまう → 運用コスト増 • 複数のシステムを1チームで運用すること で、責任の所在が不明確になりやすい
Appendix. 機能別組織と機能横断型組織 機能横断型組織のメリット • システムごとにチームが紐付いているた め、開発と運用がセットで考えられやすい (DevOps) 19 機能横断型組織のデメリット •
チームごとの垣根は高くなり、知識の共有 がしにくくなる • 各チームで車輪の再発明が行われやすい
• Chatworkは現在、機能別組織の体制 ◦ これは、アーキテクチャ上の背景や歴史的背景が要因 • 現在、運用観点、あるいはオーナーシップをもったPM&Dev共同のチームを作り上 げるために機能横断型組織を目指している Appendix. 機能別組織と機能横断型組織 20
機能別組織 / 機能横断型組織について、 くわしくはこちらの本をチェック! https://www.amazon.co.jp/dp/B079TLW41L/r ef=dp-kindle-redirect?_encoding=UTF8&btkr =1
02 運用を侮るなかれ
• 「運用」は軽視されがちな気がする ◦ これはきっと「運用」というもの自体に技術的な面白みがなく、それよりも 「機能開発」に注力したくなるエンジニアの性ではないでしょうか (※個人の感想です) 運用を侮るなかれ 22
• 「運用」というものどう取り扱うかより、 「運用」というものをなるべく発生させないことに注目が置かれやすい (これはこれで正しい) • ただし、この考えが行き過ぎると、 だれも「運用」ということに向き合わない組織ができてしまう 運用を侮るなかれ 23
よくあること
• 運用業務が重くなってくる・・・ • → 自動化しよう! よくあること 25
• → 自動化が進む・・・ • → ピタゴラスイッチシステムが出来上がる よくあること 26
• → ピタゴラスイッチシステムが突然動かなくなる • → ピタゴラスイッチシステムがどう稼働していたのかわからない・・・ よくあること 27
εε=ヽ( `Д´)ノ ウワァァァン
結局、運用が必要 29 • ピタゴラスイッチシステム自体もシステムになるので、 このシステム自体の「運用」も考える必要がある • 「運用」を軽くしようとしたはずなのに、 結局また「運用」が必要になってくる・・・
我々は運用から逃れることはできない 結論
・・・ということで、運用というものは必ずついてまわる話になります。 例にあげたものは一例ですが、それでも全てを自動化というのは夢のまた夢、 ドラ◦もんが叶えてくれるまで待ちましょう。 (※個人の感想です) 結局、運用が必要 31
現状、技術力を伸ばしたいと思ってる人が多いと思いますが、 それと同じくらい、もしかしたらそれ以上に 「運用設計力」 というものは必要になってきます。 (※個人の感想です) エンジニアとして必要なスキルとは? 32
運用設計力とはなにか?
よくわからない
よくわからないが経験上、おそらく下記のような能力。 • 状況分析力、課題設定力 • 現実的な業務フローの設計力 • 業務フロー図の作成(PlantUMLなど)等のドキュメンテーション力 • 定義した業務フローを現場に落とし込む説得力、政治力、プレゼン力 ならべると、基本的なビジネススキルっぽい。
運用設計力? 35
おそらく、この中にも 「エンジニアとして生きていくには、技術力さえ上げていればいい」 と考えている人はいるのではないでしょうか? エンジニアとして必要なスキルとは? 36
しかし、現実そんなに甘くはない
もちろん、先述したようなことをやらない働き方もあるかと思います。 ただ、伝えたいこととしては、先述のような運用まわりのことを しっかりできるエンジニアは非常に重宝されます。 (※個人の感想です) エンジニアとして必要なスキルとは? 38
03 メトリクスとモニタリング
メトリクスとモニタリングはなぜ重要か? 何が起こっているのか、問題が発生していないか把握するため。 40
メトリクスとモニタリングはなぜ重要か? 何が起こっているか、何もわからない世界線 41 ユーザー 「サーバー落ちてる!」 「クソアプリやん!」 「なにも問題ないな!」 「ヨシ!」 エンジニア
メトリクスとモニタリングはなぜ重要か? 要するに、状況把握のためのツール。 状況把握ができれば課題発見につながり、 課題発見ができればやるべきアクションは自ずと見えてくる。 42
Chatworkの事例
Datadog 外部監視サービスの1つ • AWSとのIntegrationがしやすく、ダッシュボードをかんたんに作れるのが特徴。 Dashboard例 https://p.datadoghq.com/sb/df22702ab-290bf9e3fb 44
Datadog 45
NewRelic 外部監視サービスの1つ • Datadogとかぶる部分は多い • Datadogのほうが細かく設定してダッシュボードを作れるのと、AWSともシームレ スな連携が可能 • NewRelicは何もしなくてもある程度のメトリクスが俯瞰できる •
いろいろカスタマイズしたい! → Datadog • なにも考えたくない! → NewRelic Chatworkはどちらも使ってます 46
NewRelic Webサーバーメトリクス 47
NewRelic Browserメトリクス 48
PagerDuty オンコール対応のためのツール • 各種ツールと連携し、エラーレートが高まったら 決まった人に電話がかかる悪魔のようなシステム • Chatworkではオンコール当番をローテーションしていて、 24時間365日すぐ対応できるようにしている 49
BigQuery アプリログ保管場所 • TB、PB級のログを即座に解析できる • 状況調査のときにBigQueryを用いてログ解析、 エラー等の特定イベントの調査をする • Google App
Scriptを用いて定期的にBigQueryから エラーログを抽出し、Chatwork上に通知している 50
04 緊急対応(オンコール対応)
Chatworkでは先述のようなモニタリングの仕組みを用いて、 24/365 の監視体制を敷いている。 24/365で運用しなければいけないSaaSシステムにおいて、 また重要になってくるのが緊急対応です。 緊急対応(オンコール対応) 52
その時は突然やってきます。 社内ユーザーからの報告や、監視ツールのアラート通知など、さまざまな角度から 報告が上がってきます。 たいへんだ!Chatworkが危ない! 53
サービスダウンするとどうなるか?
Twitterで「帰る」という報告が来る もう、仕事できないので帰りますね 今日は帰るしかないですね・・・ 55
Yahooトレンドにのる 56 • ダウンタイム15分程で3位 • 緊急地震速報より上
RocketNewsに載る https://rocketnews24.com/2016/11/21/838345/ 57
Chatworkの障害対応フロー
• ざっくり ◦ 異常事態に気づいたら報告 ◦ 障害対応チームがビデオ会議にてコミュニケーションを取る ▪ コミュニケーションリーダーを決める ◦ 開発
▪ 復旧に向けた調査&アクション ◦ ビジネスサイド(PM & サポート & 広報) ▪ ユーザーコミュニケーション方法の決定、実施 ◦ コミュニケーションリーダー ▪ 復旧の状況をヒアリング、ビジネスサイドへの報告 ▪ その他もろもろのファシリテート Chatworkの障害対応フロー 59
• 障害が落ち着いたら ◦ 臨時のChatworkのグループチャットを作成 ◦ そのグループチャットで障害に関するコミュニケーション、再発防止策につい ての議論 Chatworkの障害対応フロー 60
05 セキュリティ
セキュリティ対策の重要性 • 昨今、セキュリティに関する関心が非常に高まっている • 背景 ◦ 高度化するサイバー手口 ◦ 多数の情報漏えい等のセキュリティインシデントの事例 62
セキュリティインシデント事例 Coincheck事件 • 2018年1月26日、仮想通貨取引所「Coincheck」が 外部からのハッキング攻撃を受ける • 580億円相当の仮想通貨「NEM(ネム)」が盗難された • 事件後はマネックス傘下で経営再建 63
セキュリティインシデント事例 7pay事件 • サービスローンチ3日目に不正利用が発生 • 他ユーザーになりすまし決済ができてしまう、 致命的なセキュリティホールがあった • ローンチからわずか2ヶ月後にサービス停止を発表 64
セキュリティインシデント事例 これらは対岸の火事ではない。 当然どんな企業にだってありえる話、もちろんChatworkも例外ではない。 65
• セキュリティインシデントは起こったら一発アウト ◦ リスク管理の一環として定期的なセキュリティリスクの棚卸しをするべき セキュリティ運用 66
セキュリティの運用とは? • 抽象的にいうと ◦ Check <-> Do の仕組みづくり • 具体的にいうと
◦ リスク管理(Checkの仕組み) ◦ リスクに対するアクション(Doの仕組み) セキュリティ運用 67
リスク管理 • 脆弱性診断 ◦ 定期的なセキュリティスキャンの実施 • 脆弱性情報の収集 • 権限棚卸し ◦
システムのアカウント等の権限を定期的にチェック ◦ 不必要なアカウントがないか、権限がないか ◦ 退職者などの権限はすべて削除されているか • etc... セキュリティ運用 68
リスクに対するアクション • セキュリティホールに対するプログラム修正 • 開発フローの標準化 • これらを専任に対応するチームの設立 • etc…本当に色々 セキュリティ運用
69
Chatworkにおけるセキュリティ対策
Chatworkにおけるセキュリティ対策 最近、ようやくセキュリティチームを立ち上げた 今まで • なにかあったら後追いで穴を塞ぐ対応 • 攻めのセキュリティ対策ができていなかった これから(予定) • リスク管理、それに対するアクションを回す
◦ 定期的なセキュリティスキャン ◦ セキュリティコンサルとの定例 71
Chatworkにおけるセキュリティ対策 BugBounty運用 • BugBountyとは? > 「脆弱性報奨金制度」や「バグ報奨金制度」と呼ばれています。公開しているプログ ラムにバグがあることを想定して報奨金をかけて公開し、一般人(ホワイトハッカー) がバグを発見して脆弱性を報告して報奨金を受け取るという制度になっています。 72 引用)https://cybersecurity-jp.com/column/27759
Chatworkにおけるセキュリティ対策 BugBounty.jpというサービスに登録 • 月だいたい30件程度の報告があり • その中で、だいたい1~2件を脆弱性として認定し、報奨金を与えている • ほとんどが海外からの報告、英語でのやり取り 73
Chatworkにおけるセキュリティ対策 開発フロー標準化(予定) • ログ出力指針の策定 • データの取扱についての指針を策定 ◦ データ暗号化指針 ◦ ハッシュアルゴリズムのルール決め
◦ etc… 74
06 まとめ
運用重要だよ • 運用の重要な要素の一つとして、システム監視と緊急対応について紹介したよ • Chatworkがやってることとして、セキュリティの運用を紹介したよ まとめ 76
まとめ これらの運用は非常に重たい、本当に重たい。 きっと積極的にやりたい人はいないはず。 いないけど、経営として非常に重要。 経営としてこの重要性をみんなに理解を得て、みんなでやっていくという姿勢が大事。 ボランティア運用はかならず破綻する(大切なことなので2回いいました) 77
働くをもっと楽しく、創造的に