はらへり日記

腹に弾丸

2017年振り返り

ちょびちょび振り返る

転職した

今年の1月、前職のアイスタイルからメルカリへと転職しました。

sota1235.hatenablog.com

明日で入社一年になるわけですが、本当に1年とは思えない濃い時間を過ごしました。

お仕事は以下の様なことをしてました。

自分の望む働き方やキャリアを考えての転職でしたが期待以上に自分のやりたいことができているのでとても満足です。

来年も引き続き死ぬ気で頑張りたい。

いろいろ発表した

今年は去年と比べると発表の回数は少なかったが大きめのイベントで登壇させてもらうことが多かった。

特に今年の目標にしていたPHPカンファレンストークでの採択が叶ってよかった。

どれも楽しかったけど、今年は「きりんさんですよね」と話しかけられることが多くてとても嬉しかった。

地の実力より多く見られてしまってるのではと感じてる場面も正直多いけどもっと精進していろんな人といろんな話ができるようになっていきたいですね。

一番嬉しかったのは東京Node学園2017で1日目のベストスピーカーになったことです。

発表する前は正直「V8のコンパイラーの話とかNode.jsの未来とか語れなくてごめんなさいごめんなさいごめんなさい」って気持ちだったので、新しい機構とかでなくても自分の経験に基いて発表してみると案外共鳴する人がいるんだなぁと肌で感じた。

あとちょっと特殊なケースで、Googleさんのイベントにゲスト登壇させていただいたりもした。

Firebase Developer Day - SPEAKERS

発表時間は短くて喋り慣れた内容だったけど、他社さんの顔に泥を塗ってはいけない気持ちで地味に一番緊張したかもしれない。

とりあえずこういう時に使えるいい感じのプロフィール写真を誰かに用意してもらおうと決意した。

副業した

昨年12月からちょうど今月までBoostnoteというOSSをやってるMAISIN&COという会社でお手伝いさせてもらってた。

boostnote.io

手伝い始めはエンジニアが私しかいない状態でデザインリニューアルをしたり、途中からフルスクラッチでWeb版の実装をしたりと、とてもいい経験をさせてもらった。

会社のフェーズが変わってきているので私は抜けますがコミットできるエンジニアを募集している&今入るととても技術的に面白いはずなのでElectronアプリをガッツリ組み上げたい人がいたらオススメです。(興味ある人いたら声かけてください)

英語を勉強しはじめた

勉強しはじめた。

sota1235.hatenablog.com

今までなんで全然英語勉強する気にならなかったのかの理由はとても単純で、やっぱ喋る機会がないと全然楽しくない。

逆に機会があると本当に楽しくなる。English Speakerのいる職場は本当におすすめしたい。

若いうちに一度、1人で英語圏の国に行って働きたいという想いが芽生えてたりするし、2週間くらい自力で旅行とかしたい。英語喋りたいマン。

その他

全体的に貯金をアウトプットする年だった。

技術的なインプットが加速した印象はあまり無くて、サービスがどうやったらよくなるのかを考えては実行しのサイクルを回しまくる1年だった。

何気なく会社のメイン活動リポジトリでマージされたPRを数えたら224個あった。

closeされたものも混ざってたりするが、弊社では1PRで1リリースなので年間200回前後リリースしてきたと思うとオソロシイ速さで走っていたんだなとしみじみする。

来年の目標は別途宣言するが、この勢いを保ったまま、インプットのメンタル面だけ今一度1年目くらいに戻して猛勉強していきたい。

来年も

今年もお世話になりました。

来年の何卒よろしくお願いします。

約1年、ゆるっと英語勉強してみての結果

この記事は

英語アドベントカレンダーの1日目の記事です。

adventar.org

(作ったのに存在忘れてましたすいません)

この記事はこんな人におすすめ

  • ゆるく英語勉強始めたい
  • 今全然英語できないけどいつかはやらなきゃいけないと思ってる

なぜおすすめか?私がちょうど一年前こんな感じだったからです。

続きを読む

SECCON2017 Online予選に参加した

参加した

会社の有志で集まってmerpoliceというチーム名で参加しました。 最終結果は1500pt, 総合125位でした。

2017.seccon.jp

WriteUp

自分が解けたものだけwrite upを書いておこうと思います

続きを読む

Firebase Dev Summitに行ってきた #FirebaseSummit

行ってきた

f:id:sota1235:20171105220724p:plain

firebase.google.com

今は会社でメルカリチャンネルというサービスのチームにいるのだが、そこでFirebaseを利用している。

その関係で出張として行かせてもらえることになった。ありがとうございます弊社。

技術関連は会社ブログに書くのでその他雑感だけ。

続きを読む

ISUCON7に出た #isucon

ISUCON7に参加しました

今年は前職の先輩と現職の先輩と組んで参加しました。

isucon.net

結果

f:id:sota1235:20171023011636p:plain

予選突破の20万台には遠く及ばず…

点数のブレが大きすぎてどの対策が効いたか全然わからなかったけど時系列でやったこととかやりたかったけど諦めたことをメモる。

タイムライン

私の担当はアプリケーションだった。

  • INDEX追加
    • (user.name)
    • (message.id, message.channel_id)
    • (haveread.user_id, haveread.channel_id)
  • SELECT *の撲滅
  • get_channel_list_infoの置き換え
    • 最終的に一箇所しか残らなかった
  • DBアクセスする前に結果返せるところは返す
    • DBアクセスした後にリクエストパラメータの有無チェックしてるようなロジックがちょいちょいあった
  • COUNT(*)COUNT(1)
  • チャンネルごとのメッセージ数カウントを専用テーブル用意して置き換え
    • 毎回COUNTせずにSELECTするだけでよくなった
    • 最初の段階で2番めに遅いクエリだったので手をつけた
  • php-fpmのチューニング
    • TCPやめてunix socketにしたり
    • 子プロセスを増やしたり
  • 使わないPHP extensionの削除
    • xdebug.so, お前のことやで
  • N+1をいくつか潰す

他のお二人には

とか諸々やってもらった。感謝…

やりたかったけどできなかった

  • /register, /loginページを静的コンテンツに
    • ロジック見ると分かるけどこの2つはPHPに捌かせる必要がない
    • HTMLの配置は一瞬だったけど優先度低かったので後回しにしたのと、nginxの設定でハマってやれなかった
  • キャッシュミドルウェアの追加
    • ログイン判定の度にselect * from userしてるのとか
    • 今回は削除更新が無かったので整合性の担保も難しくなかったはず…
  • メッセージ取得ロジック改善
  • 未読数カウントロジック修正
  • LIMIT, OFFSET殺す
  • php-fpmのさらなる調整
    • 時間無くてかなり雑に調整した
  • PHPMySQLのコネクション最適化

他にも色々アイディアはあって

  • DBサーバにもアプリを立てる
  • キャッシュ用サーバとアプリを分ける

なんて案もあったけどとにもかくにもボトルネック/iconsから他に移らなくて死んだ。

所感

とにもかくにも/iconsのリクエストを捌けて無くてしんどかった。

一番最初はDBが完全にサチっててその壁は一瞬で越えられたけどその後すぐに画像が死んでることが分かってなるほどという感じだった。

画像の脱DB化をしてもそこまでスループットが上がらず、なかなか苦しかった。

今回はそこを抜けたチームが10万の壁を越えていったのではという推測。

スギャブロエックスチームと同じ会場で解いてたので効いたところCache-Controlヘッダあたりをいじって2回目以降リクエストさせないようにしてたらしい。ぐぬぬ

一昨年、昨年参加して今年3回目だけど計測してボトルネック特定して確実に芽をつぶしていく力はついていると感じてて、それゆえに結構悔しい。

あとはぱっと直したコードにバグがあることが多くて結構時間を取られた。

今回はほぼ何も準備できなかったけど来年は手元で簡単にアプリが動かせるような環境を作る秘伝のタレを用意してそこでデバッグしたい。

とにかくですね

来年こそ100万円使って温泉行きたいです。