danimal141's resume
This project is maintained by danimal141
@danimal141
事業部内のプロダクトチーム全般に関わりながらエンジニアリングマネージャーとして活動しています。今は開発の比重は少なめで、各プロダクトチームの開発戦略や開発目標をPdMや事業責任者とともに策定し、それを各エンジニアメンバーの目標と連動させることで大きな組織成果を出すことに注力しています。あとは事業部全体のエンジニア組織づくりや採用活動によく時間を使っています。
それまではリードエンジニアとして新規事業立ち上げに関わり、「急速な事業成長を支えるために開発チームやソフトウェアアーキテクチャをどのように進化させていくか」というテーマとひたすら向き合っていました。
開発だけでなく、総合格闘技のような戦い方で事業や組織に貢献するのが比較的得意だと思っています。振り返ってみても非エンジニアメンバーとエンジニアメンバーの間に入って適切に言葉を翻訳し、事業や組織を前に進めるようなことをよくやっている気がします。
創業メンバー(執行役員)として参画し、自社プロダクト開発を担当しました。
創業から3,4年ほどはCEO、CTO、私の3名体制で少数チームでPMFを目指す形を取っていたため、バックエンド、フロントエンド、インフラ (AWS)、ネイティブ (iOS)の全ての開発に携わってきました。
追加の資金調達が完了した後は事業上、自社AIの開発がもっとも重要になったため、CTOがAI開発、私がWebのプロダクト開発とエンジニア採用・育成に主に責任を持つように分担しました。
プロダクト開発に関しては引き続きCTOにコードレビューに入ってもらいフィードバックを受けながら、なるべく私やチームメンバーのみで技術的な意思決定ができる体制にしていきました。またエンジニア採用に関しては海外エンジニアの採用も検討していたため、開発チームの公用語を英語にしつつ、スカウトの作成、面談設計、採用後のオンボーディング設計、1on1導入なども私主導で行いました。英語学習プロセスに関してはこちらもご一読いただけると幸いです。
メディア、画像認識API、toB向けSaaS、AIレコメンドエンジンなど、様々な開発に関わってきたのですが、網羅すると長くなり過ぎてしまうため抜粋して記載します。
SNS、メディア上のファッションデータを定期的にクローリングし、自社の画像認識AIに解析させ、その結果を蓄積して分析できるようにしたものです。
データ収集基盤は以下のようなものになります。
1に関してはコマンドラインをGoで実装し、定期的にコマンドを実行するような仕組みにしています。またTwitterのようにAPIが提供されていないメディアも対象だったため、そういったメディア向けのスクレイピングAPIを別途Railsで実装し、それをGoのコマンドライン経由で呼べるようにしました。
3に関してはAWS Glueのクローラを定期的にキックするコマンドラインをKotlinで実装しました。
各社の持つデータアセットが大きな競争優位性になる昨今、データ収集や分析の基盤開発に包括的に携わることができたのは貴重な経験でした。
資金調達後、エンジニア採用・育成の責任者としてエンジニア組織拡大の役割も兼任していました。大戦略として当時からエンジニア採用は激化していたため、
というものを掲げました。
そしてグローバル人材にリーチできるAngelListやJustaというサービスを活用して候補者プールを管理しつつ、英語での採用プロセス設計、実行、改善などをプロダクト開発と並行して行いました。結果、私の在籍期間中に3人の海外エンジニアの採用が決まりました。一人目に採用したメンバーに関してはほぼ未経験という状態から入社し、私の後任テックリードとして活躍するまでに成長してくれました。
メインのWebアプリケーションです。
創業当時、私とCTOの2名体制で開発のすべてを担っていたのですが、私はそれまでフロントエンド以外の実務経験がありませんでした。そのため私はフロントエンドまわりのベースを整えることで信頼貯金を作りながら、それを切り崩してCTOが作っていくバックエンドのコードやインフラの設定をキャッチアップしていくようなスタイルで開発がスタートしました。
そこから半年ほどでバックエンドやインフラ含めてある程度は自走できるようになってきたため、それ以降は2名で優先度順に並んだ開発Issueを上から交互に取っていくようなスクラム開発的なスタイルに落ち着きました。
「画像を定期的にクローリングする機能」「画像にメタデータを付与するSPA管理画面」「商品レコメンド機能」「Payment機能」など、プロダクトに必要な機能開発を一通り担当しました。一部を切り出して派生プロダクトを作ることも多かったので立ち上げ、設計から実装、リリースすべてに責任を持つ機会にも恵まれました。最終的にはピボットしたのですが当初はtoCサービスとして育てていく想定だったため、iOSアプリ開発もその中で2年ほど経験しています。
結果を出せないと会社が潰れるというプレッシャー下での開発経験から、本当に多くのことを学びました。「いくら開発者体験を磨いても、いくらきれいな設計にこだわっても、顧客に使われていないのであれば意味がない」という今の私の価値観もここでの開発が原体験になっていると思います。
自社タイトルのチームにフロントエンドエンジニアとして参画しました。既存のガワネイティブ部分のJavaScriptのパフォーマンスチューニングや新規イベント関連の実装を主に担当していました。
クライアント先に常駐し、クライアント側で編成された新規事業立ち上げチームのフロントエンドエンジニアとして参画しました。担当はマークアップ全般とフロントエンド (JavaScript / jQuery)開発です。
どちらかというとウォーターフォールに近い開発スタイルだったため、リリースまでに約50ページに渡るページのコーディングをする必要がありました。そのためベトナムのオフショアチーム (フロントエンドエンジニア数名 + ブリッジエンジニア1名)の力を借りて、日本語が話せるブリッジエンジニアの方経由で仕様の認識を皆で揃えつつ、各エンジニアメンバーへの技術的なフィードバックはSkypeで英語でコミュニケーションを取りながら行いました。
当時、私自身も新卒1年目でフロントエンドエンジニアとしてキャリアをスタートしたばかりだったのですが、必死で技術をキャッチアップしつつ、ベースを作って他のメンバーに引き継ぐような、ミニテックリードのような働き方を経験させていただきました。
キャリアの大半をスタートアップや新規事業立ち上げのような環境で過ごしているので、0->1開発や総合格闘技的な戦い方で成果を出すのが比較的得意なタイプです。開発を担当するのであればなるべくユーザストーリ単位でフルスタックに責任を持ちたいです。逆に人材が比較的豊富で専門性を強く求められるような環境だとあまりバリューが出せないかもしれません (e.g. バックエンドチームに所属してスペシャリティを発揮するような働き方)。
技術のみを追求するというよりは事業や組織にも興味があるタイプなので、非エンジニアメンバーと議論したり、チームメンバーをサポートしたり、カジュアル面談やミートアップ等で社外のエンジニアの方とお話するのが結構好きだったりします。最高のチームで文化祭前夜のような空気でプロダクト開発がしたいです。
技術スタックとしてはRailsとReact.js(TypeScript)が一番使い慣れていて、次にGoという感じです。必要があれば基本何でも勉強して身につけます。後はブランクはありますが、開発のコンテキストであれば英語環境下でも問題なく働けると思います。
事業や組織のフェーズや直面している課題に応じて「自分が何をすべきか」を考え、一番レバレッジの効く戦い方で成果を出せることが強みだと思います。どうぞよろしくお願いいたします。
成果を出すために必要なことは何でもやりますが、強いて言うなら現場レイヤーよりはマネジメント・経営レイヤーに軸足を置いた事業・組織課題の解決に貢献したいです。開発組織や戦略を作って、成果が出るまで徹底的にオペレーションを磨いたり、生成AIのようなテクノロジーによって組織全体で大幅な開発生産性向上を狙ったり、そういった活動に関心があります。