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
CA Tech JOB 成果発表
Search
wafuwafu13
March 31, 2021
Programming
1
660
CA Tech JOB 成果発表
wafuwafu13
March 31, 2021
Tweet
Share
More Decks by wafuwafu13
See All by wafuwafu13
はてなサマーインターン成果報告 ~xyz記法とマイクロサービス~
wafuwafu13
0
1.3k
Other Decks in Programming
See All in Programming
DevNexus - Create AI Infused Java Apps with LangChain4j
kdubois
0
130
JAWS Days 2025のインフラ
komakichi
1
350
Amazon Bedrockマルチエージェントコラボレーションを諦めてLangGraphに入門してみた
akihisaikeda
1
160
.NET Frameworkでも汎用ホストが使いたい!
tomokusaba
0
210
もう僕は OpenAPI を書きたくない
sgash708
6
1.9k
Go 1.24でジェネリックになった型エイリアスの紹介
syumai
2
310
Datadog Workflow Automation で圧倒的価値提供
showwin
1
310
『テスト書いた方が開発が早いじゃん』を解き明かす #phpcon_nagoya
o0h
PRO
9
2.6k
5分で理解する SOLID 原則 #phpcon_nagoya
shogogg
1
410
Djangoにおける複数ユーザー種別認証の設計アプローチ@DjangoCongress JP 2025
delhi09
PRO
4
510
The Clean ArchitectureがWebフロントエンドでしっくりこないのは何故か / Why The Clean Architecture does not fit with Web Frontend
twada
PRO
55
18k
Better Code Design in PHP
afilina
0
180
Featured
See All Featured
Improving Core Web Vitals using Speculation Rules API
sergeychernyshev
11
540
Making Projects Easy
brettharned
116
6k
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
233
17k
Rails Girls Zürich Keynote
gr2m
94
13k
How To Stay Up To Date on Web Technology
chriscoyier
790
250k
Intergalactic Javascript Robots from Outer Space
tanoku
270
27k
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
115
51k
A Tale of Four Properties
chriscoyier
158
23k
YesSQL, Process and Tooling at Scale
rocio
172
14k
実際に使うSQLの書き方 徹底解説 / pgcon21j-tutorial
soudai
175
52k
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
11
1.3k
Git: the NoSQL Database
bkeepers
PRO
428
65k
Transcript
自己紹介 氏名: 田川裕隆(たがわひろたか) 大学: 同志社大学社会学部社会学科 2回 配属: 23卒実践就業型インターン@AWA 得意技術: JS/TS
興味: 大規模サービス/テスト自動化/自然言語処理 マイブーム: 音楽(YOASOBI/ヨルシカ/ずとまよ)/読書(エッセイ集)/OSS活動(any潰し/テスト追加) リンク集: https://wafuwafu13.hateblo.jp/
配属先紹介 配属先: AWA株式会社 (1) サブスクリプション型(定額制)音楽ストリーミングサービスを提供 ユーザー同士がリアルタイムに、同じ空間で同じ音楽を楽しみながらチャットができるオンライン空間 『LOUNGE(ラウンジ)』をリリース (2) メンター: 山下さん/佐々木さん
(1) https://www.cyberagent.co.jp/corporate/overview/awa/ (2) https://news.awa.fm/jpn/2021/3/9/lounge-launch
やったこと • Terraform のバージョンアップ (v0.12 => v0.13) • 本番LOUNGEサーバーのリソース増強 (Terraform/Datadog)
• LOUNGE検索の追加 (MongoDB/Mongo Connector/Elasticsearch/Jenkins/Ansible) • ドキュメント作成 (DocBase) • LOUNGEの検索処理 (Go/gRPC/grpc-gateway)
背景と用語 用語 MySQL MongoDB Elasticsearch database database index table collection
mapping raw (record) document document column field field 背景 LOUNGEを将来的に検索できるようにしておきたい 検索周辺のコードやツールは 1年以上触られていない コード、ドキュメント、過去の issueを参考に実装 LOUNGE = Room
アーキテクチャ Mongo Connector admin admin user rooms searchRooms search Elasticsearch
Head grpc-gateway terminal rooms
MongoDB admin rooms searchRooms • LOUNGE検索用collectionであるsearchRoomsのスキーマをGo で定義 • 定義からアクセス用コードを Goで自動生成
(I/Oの型安全) • roomsのCRUDに合わせてsearchRoomsもCRUD
Jenkins/Elasticsearch/Elasticsearch Head • LOUNGE検索用のindexをJenkinsのJobで作成 • Elasticsearch Head で index等を可視化 Elasticsearch
Head
Ansible/Mongo Connector/papertrail Mongo Connector searchRooms • MongoDBのデータをElasticsearchに同期 • ECSを使う以前の歴史的経緯 •
JenkinsのJobとしてAnsibleのsshがうまくい かなかったのでローカルで実行 • papertrailでログ監視
gRPC/grpc-gateway admin user search • LOUNGE検索用のproto定義、コード生成 • マイクロサービス間の通信 • grpc-gatewayでデバッグ
• クリーンアーキテクチャ • admin画面作る時間は足りなかった grpc-gateway terminal rooms
感想 Mongo Connector Elasticsearch Head • 夕会すごい • Go読みやすい •
インフラ周り楽しい • 触るレポジトリ多かった • サービスの歴史の理解が重要 • 意外と自走できる部分はあった grpc-gateway