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
転職早々Elixir + Phoenixに入門している話
Search
ponday
June 20, 2018
Technology
2
1.7k
転職早々Elixir + Phoenixに入門している話
ponday
June 20, 2018
Tweet
Share
More Decks by ponday
See All by ponday
関数型でGoFのデザインパターンやってみる
honda
1
1.5k
TypeScriptの型表現
honda
10
3.1k
Web Componentsの今
honda
1
450
これまでのReact、これからのReact
honda
0
320
Gatsbyお試し
honda
0
120
styled-components or emotion?
honda
0
700
Web ComponentsとAngular
honda
0
140
Atomic Design周りについての私見
honda
1
760
え、まだWeb Componentsを未来の技術だと思ってるの?
honda
2
860
Other Decks in Technology
See All in Technology
2025-12-27 Claude CodeでPRレビュー対応を効率化する@機械学習社会実装勉強会第54回
nakamasato
4
1.4k
戰略轉變:從建構 AI 代理人到發展可擴展的技能生態系統
appleboy
0
180
CQRS/ESになぜアクターモデルが必要なのか
j5ik2o
0
650
サラリーマンソフトウェアエンジニアのキャリア
yuheinakasaka
7
2.2k
2025年のデザインシステムとAI 活用を振り返る
leveragestech
0
700
プロンプトエンジニアリングを超えて:自由と統制のあいだでつくる Platform × Context Engineering
yuriemori
0
160
AI駆動開発ライフサイクル(AI-DLC)の始め方
ryansbcho79
0
300
小さく、早く、可能性を多産する。生成AIプロジェクト / prAIrie-dog
visional_engineering_and_design
0
340
「アウトプット脳からユーザー価値脳へ」がそんなに簡単にできたら苦労しない #RSGT2026
aki_iinuma
8
4.1k
AIエージェントを5分で一気におさらい!AIエージェント「構築」元年に備えよう
yakumo
1
140
産業的変化も組織的変化も乗り越えられるチームへの成長 〜チームの変化から見出す明るい未来〜
kakehashi
PRO
1
340
善意の活動は、なぜ続かなくなるのか ーふりかえりが"構造を変える判断"になった半年間ー
matsukurou
0
290
Featured
See All Featured
Leo the Paperboy
mayatellez
1
1.3k
How to Grow Your eCommerce with AI & Automation
katarinadahlin
PRO
0
84
We Have a Design System, Now What?
morganepeng
54
8k
Google's AI Overviews - The New Search
badams
0
890
Digital Projects Gone Horribly Wrong (And the UX Pros Who Still Save the Day) - Dean Schuster
uxyall
0
120
Producing Creativity
orderedlist
PRO
348
40k
Skip the Path - Find Your Career Trail
mkilby
0
38
Tell your own story through comics
letsgokoyo
0
770
New Earth Scene 8
popppiees
0
1.3k
Are puppies a ranking factor?
jonoalderson
0
2.6k
Sharpening the Axe: The Primacy of Toolmaking
bcantrill
46
2.6k
Scaling GitHub
holman
464
140k
Transcript
転職早々Elixir + Phoenixに入門している話 VEGA Tech Meetup #1 / Jun 20th,
2018 ponday (@ponday_dev)
株式会社ベガコーポレーション R&Dグループ エンジニア Profile Honda, Yusuke (@ponday_dev) ng-fukuoka(Angular福岡ユーザグループ)オーガナイザ Like - TypeScript
/ RxJS / Angular - Elixir - Python 4月に中途入社したばかり 元々サーバサイドの趣味フロントエンドエンジニア 最近は仕事で画像処理とか機械学習とかElixirとか いよいよ何エンジニアと名乗れば良いのか迷子
最近、Elixir + Phoenix に入門しました
None
Elixir - 並列処理などを得意とするプログラミング言語 - Rubyライクな構文(とよく言われる) - 作者がRailsのコミッター - Erlang VM上で動作
- Erlangも一つのプログラミング言語 - 99.9999999%を謳う安定性が魅力
None
Phoenix Framework - Elixir向けのWeb Application Framework - Railsライクな構成、エコシステム - 作者がRailsのコミッター(Elixirの作者とは別人)
採用の経緯 新プロダクトの技術選定 今回は非サーバレスで いつもならRails じゃあ今回もRails?
面白くなくない? 分かる
新天地へ
Elixir Go言語 - Rubyに似ているらしい - 安定性が高いらしい - ちゃんと触ったことはない - 採用実績には劣る印象
- 福岡に活発なコミュニティがある - シンプル - パフォーマンス良いらしい - 軽く触ったことはある - 採用実績は増えている印象 - fukuoka.goなどイベントもある 候補は2つ
どうせなら新しい言語! せやな
検証してみた
負荷テスト - 実際にデモサイトを作成し、EC2にデプロイする - DBへの挿入/更新処理が発生するAPIに一斉にアクセス → どの程度のリクエストまで耐えれる? - 負荷ツールにはGoadを利用 -
(参考)https://qiita.com/quickguard/items/995d8e28d53e569bab73
負荷テスト結果 多重度 リクエスト数 エラー数 10 100 0 20 100 0
50 500 0 200 1000 0 200 5000 0 300 7000 0 耐えて欲しい 落としたい!
そしてついに、300多重/8000reqで落ちた!
Goad(負荷ツール)が
結論 落とせなかった
負荷テスト概観 - パフォーマンスもなかなか - 高負荷の状態でも100ms 〜 200ms程度でレスポンスが返っている - 高負荷状態でも処理自体に失敗することがなかった -
高付加でエラーになった場合に、プロセスを立ち上げ直して処理を続行して いるのでは? - サーバスペックが弱くても動作できるのは良い - 今回のテストはEC2のt2.mediumで実施
Elixir / Phoenixについての所感
所感① Rubyとはそれほど似てない - ぱっと見は確かにRubyっぽい - 書いてみると全然似てない - Elixir特有の構文をよく使う - そもそもクラスがない
- クラスがないのでインスタンスメソッドなんてものもない - (個人的には)Rubyより読み書きしやすい
所感② 読みやすい - 柔軟な記法 - 文ではなく式 - パイプライン演算子 - 処理が簡潔に書ける
- パターンマッチが超強力 - 最初は慣れが必要
所感③ 情報の少なさは否めない - 特にPhoenix周辺の情報 - 日本語情報の量には期待してはならない - 福岡はQiita含めて活発なコミュニティがあるのでまだ敷居は低いはず - エラーメッセージが直感的ではないことがまれにある
- 経験によるカバーも必要になってくる?
所感③ 情報の少なさは否めない - 特にPhoenix周辺の情報 - 日本語情報の量には期待してはならない - 福岡はQiita含めて活発なコミュニティがあるのでまだ敷居は低いはず - エラーメッセージが直感的ではないことがまれにある
- 経験によるカバーも必要になってくる?
所感④ ライブラリには困る場合も - 標準のライブラリは結構充実 - Erlangのライブラリも使えるので少なくはない - AWSなどのサービスのサポートはまだまだ - 反面、GraphQLサーバを実装するためのライブラリなどは既にあったりする
Elixirコード例
パイプライン演算子 - Elixirの特徴的な構文 - 関数呼び出しを “|>” でつなげて記述 - 処理の順序が分かりやすくなる
パイプライン演算子 JavaScript Elixir
パイプライン演算子 DB操作の例 ※ Phoenix標準のDBライブラリ『Ecto』の書き方
パターンマッチ - いわゆる正規表現とは違う - 関数の処理だけでなく、関数呼び出しなどいろいろな場面で 利用される - 活用することで表現できる幅が一気に広がる
パターンマッチ
パターンマッチ 基本形(代入ではなくパターンマッチ)
パターンマッチ foo属性を持つオブジェクトとマッチ
パターンマッチ foo属性の値が1のオブジェクトとマッチ
パターンマッチによる型制約もどき - 本来Elixirは動的型付け言語 - パターンマッチを活用すると、ゆるい型制約もどきが実現でき る - 「特定のプロパティを持つ型」みたいな書き方もできる
パターンマッチによる型制約もどき => user: ponday, gender: male => エラー
パターンマッチによる型制約もどき
パターンマッチを利用した条件分岐 - 関数呼び出し時にもパターンマッチが適用される - 同名の関数が複数存在する場合、指定のパターンに初めに マッチしたものが実行される - 上手く使うとif文が不要に
パターンマッチを利用した条件分岐 これが
パターンマッチを利用した条件分岐 こうなる
まとめ - Elixir、良い - 普通に書けばそこそこのパフォーマンスで、堅牢 - エコシステムも充実 - 表現力豊かな構文で書いてて楽しい -
慣れは必要ながら簡潔で読みやすい - ライブラリなどはこれからな面も - とはいえ福岡はコミュニティが活発 情報交換もしやすい分ハードルは低い
Elixir、一緒にやりませんか?
Thank you !!