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
Backlogのインフラを支えるAWS活用事例 / Geeks Who Drink Nulab...
Search
株式会社ヌーラボ
PRO
November 16, 2017
Technology
0
4.4k
Backlogのインフラを支えるAWS活用事例 / Geeks Who Drink Nulab AWS Edition
2017年11月10日にヌーラボ東京オフィスで開催した「Geeks Who Drink AWS Edition」の登壇資料です。Backlogのインフラを支えるAWS活用事例をご紹介しました。
株式会社ヌーラボ
PRO
November 16, 2017
Tweet
Share
More Decks by 株式会社ヌーラボ
See All by 株式会社ヌーラボ
ライティングチームだからこそできた、「どことでも繋がれるチーム」づくりの結果 / Technical Writing Meetup vol.38
nulabinc
PRO
0
30
4つの基本的な組織形態を知る ~ミンツバーグの組織論 7つの類型と力学、そしてその先へ~ より GWD in Nagoya
nulabinc
PRO
2
97
必要なのは客観性。組織変革をもたらす、より良い「対話」を生み出すための活動 #scrummikawa
nulabinc
PRO
3
1k
悪い実装例から学ぶ ウェブアクセシビリティ改善のヒント
nulabinc
PRO
1
330
ヌーラボカスタマーサクセスチームのBacklog活用
nulabinc
PRO
0
280
言葉で「ヌーラボらしさ」をどう届ける? グローバルチームでコラボレーションする大切さ
nulabinc
PRO
1
100
タスクの可視化は争いをなくす!? 夏休みを乗り切る 宿題プロジェクトマネジメント
nulabinc
PRO
2
260
情シスの申請業務におけるBacklog活用術
nulabinc
PRO
0
300
Backlogと業務プロセスのちょっといい関係
nulabinc
PRO
0
270
Other Decks in Technology
See All in Technology
【Pycon mini 東海 2024】Google Colaboratoryで試すVLM
kazuhitotakahashi
2
550
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
0
110
10XにおけるData Contractの導入について: Data Contract事例共有会
10xinc
6
680
あなたの知らない Function.prototype.toString() の世界
mizdra
PRO
1
230
100 名超が参加した日経グループ横断の競技型 AWS 学習イベント「Nikkei Group AWS GameDay」の紹介/mediajaws202411
nikkei_engineer_recruiting
1
170
DynamoDB でスロットリングが発生したとき/when_throttling_occurs_in_dynamodb_short
emiki
0
260
アプリエンジニアのためのGraphQL入門.pdf
spycwolf
0
100
AWS Lambda のトラブルシュートをしていて思うこと
kazzpapa3
2
180
BLADE: An Attempt to Automate Penetration Testing Using Autonomous AI Agents
bbrbbq
0
320
FlutterアプリにおけるSLI/SLOを用いたユーザー体験の可視化と計測基盤構築
ostk0069
0
110
AWS Media Services 最新サービスアップデート 2024
eijikominami
0
200
アジャイルでの品質の進化 Agile in Motion vol.1/20241118 Hiroyuki Sato
shift_evolve
0
180
Featured
See All Featured
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
356
29k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
126
18k
Fireside Chat
paigeccino
34
3k
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
27
840
Imperfection Machines: The Place of Print at Facebook
scottboms
265
13k
How to train your dragon (web standard)
notwaldorf
88
5.7k
BBQ
matthewcrist
85
9.3k
Producing Creativity
orderedlist
PRO
341
39k
Become a Pro
speakerdeck
PRO
25
5k
Navigating Team Friction
lara
183
14k
Scaling GitHub
holman
458
140k
RailsConf & Balkan Ruby 2019: The Past, Present, and Future of Rails at GitHub
eileencodes
131
33k
Transcript
Backlogのインフラを支える のインフラを支える AWS活用事例 活用事例 Geeks Who Drink in Tokyo -AWS
& 神楽坂 Edition-
自己紹介 自己紹介 ・山崎 ・山崎 毅 毅 ( やまさき やまさき つよし
つよし) @revsystem ・担当 ・担当 2017年 年3月 月~ Backlog SRE チーム チーム ・経歴 ・経歴 - SIerにてオンプレ環境でのインフラ設計 にてオンプレ環境でのインフラ設計/構築 構築/運用 運用 - SIerにて にてSE( という名の何でも屋 という名の何でも屋 )
None
話す内容 話す内容 ・本日話すこと ・本日話すこと - Backlogの成長と、使用している の成長と、使用しているAWSの技術 の技術 -
環境が増えると起きること 環境が増えると起きること - インフラの成長とともに取り組む改善について インフラの成長とともに取り組む改善について ・本日話さないこと ・本日話さないこと - Backlogの実装のこと の実装のこと
Backlog の成長と の成長と 使用している 使用しているAWSの技術 の技術
※2017年 年11月現在 月現在
有料契約数の推移 有料契約数の推移 2006年に 年に Backlog の正式版をリリース の正式版をリリース 2017年 年11月時点で 月時点で
有料契約数は 有料契約数は6,000、ユーザー数は 、ユーザー数は 800,000を突破。 を突破。 https://nulab-inc.com/ja/blog/backlog/pr-1711-backlog-6000-mini-game/
AWS cloud Virtual Private Cloud 主なインフラ構成と 主なインフラ構成とAWS技術 技術 VPC public
subnet VPC private subnet web CloudFront EBS nat gateway S3 CloudWatch Lambda app Git, WebDAV,SVN... Route53 Typetalk連携
フロント構成 フロント構成 EC2 Instance EC2 Instance web app EC2 Instance
EC2 Instance web app ・ ・Redisを用いてセッション情報を共有 を用いてセッション情報を共有 ・ ・web、 、appサーバともに、アプリケーションの サーバともに、アプリケーションの 負荷状況をみてスケールアウト 負荷状況をみてスケールアウト/スケールアップ スケールアップ を実施 を実施 ・ ・Auto Scalingは使用していない は使用していない ・・・ ・・・ ・・・ ・・・
DB,ストレージ構成 ストレージ構成 ・ ・DB - MySQL Auroraで運用 で運用
- ゼロダウンタイムパッチ機能より、サービスを停止せずにメンテナンスを実施 ゼロダウンタイムパッチ機能より、サービスを停止せずにメンテナンスを実施 ( 完全にゼロダウンタイムではないため、念のためメンテナンスは夜間に実施している 完全にゼロダウンタイムではないため、念のためメンテナンスは夜間に実施している ) ・ ・Git / WebDAV & SVN - ストレージ領域として ストレージ領域としてEBSを使用 を使用 - 容量追加や 容量追加やEBSサイズの最適化など、必要に応じて調整を実施 サイズの最適化など、必要に応じて調整を実施
AWS cloud ECSへのデプロイ へのデプロイ ECR ECS git push @jenkins-deploy-xxx ・
・git pushや や Typetalk botの のwebhookを利 を利 用 用 ・ ・Jenkinsで で container imageを をpull
増える運用環境 増える運用環境 2011年 年 : オンプレミスから オンプレミスからAWSへ移行。 へ移行。3環 環 境で開始
境で開始 2013年 年 : 4環境 環境 2015年 年 : 5環境 環境 2017年 年 : 7環境 環境 現在のインスタンス数は 現在のインスタンス数は200台弱。 台弱。
環境が増えると 環境が増えると 起きること 起きること
運用環境が増えると起きること 運用環境が増えると起きること ・ ・AWS 旧サービスと新サービスの混在によるメンテナンスの非効率性 旧サービスと新サービスの混在によるメンテナンスの非効率性 - EC2 Classicと
とVPC - EBS standardと とgp2以降 以降 ・リソースの上限に達することによる、一時的な運用遅延 ・リソースの上限に達することによる、一時的な運用遅延 - リージョン単位での起動可能なインスタンス数の上限 リージョン単位での起動可能なインスタンス数の上限 - Route53 登録可能ホスト数の上限 登録可能ホスト数の上限 ・インスタンス作成のたびに、同じ作業の繰り返し ・インスタンス作成のたびに、同じ作業の繰り返し などなど などなど
改善内容 改善内容 - 運用 運用 ・ ・Infrastructure as Code の実施
の実施 - Terraform, Ansible, Serverspec, awspec ・運用環境をより安定性の高いものへ移行 ・運用環境をより安定性の高いものへ移行 - EC2, ALB , RDS for Aurora, ElasticCash, VPC ・ ・AWSの情報を定期的に収集 の情報を定期的に収集 - Lambda function でメンテナンスやセキュリティ情報を取得 でメンテナンスやセキュリティ情報を取得 - Typetalkに通知してチームで共有 に通知してチームで共有
Infrastructure as Code
Infrastructure as Code - Serverspec ( サーバの構成をテスト サーバの構成をテスト )
- 変更点がレポジトリに 変更点がレポジトリに push された場合に された場合にJenkins にてテストを実施 にてテストを実施 - ミドルウェアやアプリケーションの設定値が正しいか ミドルウェアやアプリケーションの設定値が正しいか - ディスクのマウント先が正しいか ディスクのマウント先が正しいか - 必要なデーモンが起動しているか 必要なデーモンが起動しているか - awspec ( AWSリソースの設定をテスト リソースの設定をテスト ) - RDSの構成チェックやパラメータグループの設定 の構成チェックやパラメータグループの設定 - EIPが正しいインスタンスにアタッチされているか が正しいインスタンスにアタッチされているか - EBSが正しいインスタンスにアタッチされているか が正しいインスタンスにアタッチされているか - Route53に意図した に意図したDNSレコードが登録されているか レコードが登録されているか
AWSの進化を追いかけながら の進化を追いかけながら 改善を続けています 改善を続けています
インフラエンジニア募集 インフラエンジニア募集 https://nulab-inc.com/ja/about/careers/
None