生活 今年は私生活的には良くも悪くもあまり起伏のない穏やかな年だった気がする。福岡に引っ越してきて2年目で自分含め家族も生活に慣れてきて、比較的穏やかに過ごすことができた。 車を買った 福岡に引っ越して1年の間は、休日のお出かけなどでカーシェア…
生活 去年の12月に東京から福岡に引っ越したので、今年は福岡での生活に慣れる年になった。 引っ越す前までもほとんどリモートで仕事していたので、仕事に関してはそうでもなかったけど、子ども関連が大変だった。新しい保育園のあれこれを準備したり、送迎…
というタイトルで先日 Kaigi on Rails 2021 で話してきました。 プレゼンで話せなかった内容なども含めてブログ記事にも書いておきます。 Intro Railsのことはけっこう知ってるけどNext.jsについて何も知らないという人をターゲットにしてNext.jsとは一体何…
昨日がクックパッド最終出社日で今日からヘルステックスタートアップの Ubie Discovery*1 で仕事します。 クックパッドは2015年4月に入社したので6年半弱在籍しました。過去最長記録です。思えば色々なことをやりました。新規サービスの立ち上げをやったり機…
最近は ECMAScript 自身の機能も豊富になってきて lodash のユーティリティ関数の出番はだいぶ少なってきたけど、debounce と throttle だけは未だに使う機会がまあまあある。 しかし、lodash は何も考えずに使うとバンドルサイズが肥大化するのでいい感じに…
const obj: any = { a: 1, b: "x" }; function foo<T, U>(x: U): [T, U] { return [obj[x], x]; } こういうコードがあったとする。コードの良し悪しは置いといて、U は引数から推論して、T は呼び出す側から指定したいというケース。 // こう書きたいけどエラー foo<number></number></t,>…
メリークリスマス!Adventarを支える技術 Advent Calendar 2019 の25日目、最終日です。 最終日は今後の Adventar をどうしていきたいかについて技術編と機能編に分けて書こうと思います。 技術編 細かく直したいところはいっぱいありますが、大きめトピック…
Adventarを支える技術 Advent Calendar 2019 の24日目です。 今日はこれまで Adventar が利用してきた技術がどのように変わってきたのかを書こうと思います。 2012年 リリースした年です。最初は Ruby と Rails を勉強したいと思い、何かいいサービスの題材…
Adventarを支える技術 Advent Calendar 2019 の23日目です。 今年から Adventar はオープンソースにしました。 ツールやライブラリ、言語などのソフトウェアであれば今の時代オープンソースというのは山程ありますが、サービスがオープンソースというのはそ…
Adventarを支える技術 Advent Calendar 2019 の22日目です。 さすがにネタ切れ気味なので、UI 系の細かいネタを投下します。 ユーザーアイコンが404のときにフォールバック Adventar では Twitter などのソーシャルログインを使っていて、ユーザーのアイコン…
Adventarを支える技術 Advent Calendar 2019 の21日目です。 このご時世には信じがたい話ですが、去年まで Adventar はスマホで見ると PC View を縮小するだけで、スマホでは非常に使いづらいサービスでした。今年のシステムリニューアルでは機能追加したり…
Adventarを支える技術 Advent Calendar 2019 の20日目です。 今日はエラートラッキングについて書きます。 Bugsnag エラートラッキングのサービスは色々あって、有名なのは Sentry や Airbrake あたりでしょうか。今回は Bugsnag というサービスを利用しまし…
Adventarを支える技術 Advent Calendar 2019 の19日目です。 今日は Server Side Redering (以下 SSR) した結果を CDN でキャッシュする戦略について書きます。SSR の概要については以下にも概要を書いたので一読しておくとよりわかりやすいと思います。 上…
Adventarを支える技術 Advent Calendar 2019 の18日目です。 昨日の記事で実際にかかっているコストを紹介しましたが、今日はコストを最適化するためにやったことを書きます。 Lambda を活用とスペックの調整 昨日の記事を見ても分かる通り、ECS などと比べ…
Adventarを支える技術 Advent Calendar 2019 の17日目です。 Adventar の運用コストが、何にどのぐらいかかっているかを書きます。AWS 以外は無料のサービスしか利用していないので、かかっているのは 100% AWS のコストです。AWS の構成については先日書い…
Adventarを支える技術 Advent Calendar 2019 の16日目です。 今年の Adventar のインフラはほとんど AWS を使って構築しています。AWS 以外だと、 Firebase Authentication や Bugsnag などのサービスも使っていますが、今回は AWS の構成について説明します…
Adventarを支える技術 Advent Calendar 2019 の15日目です。 今日は DB のスキーマ管理について書きます。 Rails の DB マイグレーションと Ridgepole Adventar は昨年まで Rails で作っていて、DB の マイグレーションも Rails デフォルトの機能を使ってい…
Adventarを支える技術 Advent Calendar 2019 の14日目です。 今日は Lambda , API Gateway, CloudFront などを使って、画像のリサイズサーバーを作る話を書きます。 Adventar における画像のリサイズ Adventar は記事を投稿した際に、記事の関連画像を取って…
Adventarを支える技術 Advent Calendar 2019 の13日目です。 今日は定期ジョブの実行について書きます。定期ジョブというのは cron とかで定期的にプログラムを実行するやつのことです。 実行するプログラム Adventar では、定期ジョブは一つだけしかなくて…
Adventarを支える技術 Advent Calendar 2019 の12日目です。 今日は API サーバーのデプロイについて書きます。 API サーバーは、4日目の記事 でも書いたように、gRPC のサーバーをたてています。この API サーバーは、Amazon ECS, Fargate を利用してホスト…
Adventarを支える技術 Advent Calendar 2019 の11日目です。 今日はフロントエンドのデプロイについて書きます。フロントエンドの構成は昨日の記事で書いたとおり、一部を Lambda で SSR していて、静的コンテンツは S3 で配信しています。 なので、S3 と La…
Adventarを支える技術 Advent Calendar 2019 の10日目です。 今日は Adventar の Server Side Rendering(以下 SSR)している技術構成について書きます。 インフラ構成 まず、先日の記事に書いたように、Adventar ではすべてのページを SSR しているのではな…
Adventarを支える技術 Advent Calendar 2019 の9日目です。 Adventar のフロントエンドは Nuxt.js で SPA な構成ですが、一部で Server Side Rendering(以下 SSR)をおこなっています。今日は SSR をする理由や Adventar での導入方法について書きます。 な…
Adventarを支える技術 Advent Calendar 2019 の8日目です。 今日は Firebase Authentication で苦労した点や工夫した点について書きます。 ログインの判定が遅い問題 Firebase Authentication を使って、現在のセッションがログインしているかどうかを検出す…
Adventarを支える技術 Advent Calendar 2019 の7日目です。 今日は Firebase Authentication 認証について書きます。 選定理由 まず、なぜ今回 Firebase Authentication を利用することに決めたかを説明します。検討した選択肢としては Firebase Authenticat…
Adventarを支える技術 Advent Calendar 2019 の6日目です。 今日は envoy の gRPC に関する便利機能について紹介しようと思います。 gRPC-Web proxy 4日目の記事でも書きましたが、今回は gRPC-Web の proxy レイヤーとして envoy を利用しています。envoy …
Adventarを支える技術 Advent Calendar 2019 の5日目です。 今日は gRPC-Web 導入にあたって最も苦労した Server Side Rendering(以降は SSR と書きます)の話を書きます。 前提条件 初日の記事 に書いたとおり、今回の Adventar のシステム変更の目的に、 …
Adventarを支える技術 Advent Calendar 2019 の4日目です。 今日は gRPC-Web について書きます。 gRPC-Web とは gRPC-Web は今年の10月に GA になったプロトコルで、今回の Adventar システムリニューアルでは絶対に gRPC-Web を production で使ってみる、…
Adventarを支える技術 Advent Calendar 2019 の3日目です。 今日はフロントエンドのフレームワークとして採用した Nuxt.js について感想を書こうと思います。 個人的には Vue.js よりも React のほうが好きなので、最初は Next.js を検討しましたが、ルーテ…
Adventarを支える技術 Advent Calendar 2019 の2日目です。 Adventar はオープンソースでコードを公開しているので、誰でも環境を再現することができます。ただ、システムがそこそこ複雑で、ドキュメントなども全然書いていないので、たぶんリポジトリを見て…