お知らせ 【技術コミュニティ運営者の皆さま】成長し続けるエンジニアを支援する「Forkwell」と「connpass」が連携し、connpass上でイベントを開催する技術コミュニティを2020年3月末まで支援いたします。詳しくはこちら by Forkwell

このエントリーをはてなブックマークに追加

9月

29

fukuoka.ex#30:tokyo.exとコラボ、Elixir本体コード読込会(リモートのみ)

おーい磯野、Elixir本体のソースコード読もうぜ

Organizing : tokyo.ex+fukuoka.ex

Hashtag :#tokyoex
Registration info

リモートでもくもく

Free

FCFS
13/20

Description

今回は、福岡側は会場無で、リモートからZoom参加のみとなります

Zoomでご参加の方(都心の方も含む)は、tokyo.ex側では無く、コチラのfukuoka.ex側でお申し込みください(コチラでお申込された方向けにZoom接続用URLをconnpassからのメールでお送りします)

都心付近にお住まいの方で、オフライン参加されたい方は、コチラからでは無く、下記tokyo.ex側でお申込みください

tokyo.ex#13 elixir本体ソースコードもくもくリード会
https://beam-lang.connpass.com/event/148476/

fukuoka.ex#30:tokyo.exとコラボでElixir本体コード読込会

今回は、Elixir本体のソースコードをリーディングする会を行います

冒頭で、 コードの読み方等の簡単なセッションを行なった後、各自もくもく会形式で、Elixir本体のソースコードをリーディングしていただきます(詳細は、後述の「タイムテーブル」をご確認ください)

なお、黙々と何かをすることから、この手のイベントを指して、「もくもく会」と呼びます

開催:2019年 9月 29日 (日) 13:00〜16:00

場所:(各自、NW環境のある場所)

タイムテーブル

時間 発表者 内容
12:30- - 開場
13:00 - 13:10 ohrdev 会場説明
13:10 - 13:30 - hacking elixir how-to
13:30 - 16:00 (全員) もくもく
16:00 - 17:00 - 質問タイム(tokyo.ex会場では懇親会)

事前準備

お手元に、Elixirのソースコードを、git cloneか、ダウンロードしておき、PCのエディタやIDE等で閲覧可能にしておいてください

福岡Elixirコミュニティ「fukuoka.ex」とは?

「fukuoka.ex」は、大量アクセスのあるWeb・APIサーバ構築や、ビッグデータ分析/AI・機械学習向けデータ加工といった、「膨大なアクセスやデータの高速処理」と「高い開発効率」を両立できる関数型プログラミング言語「Elixir」と、そのWebアプリケーションフレームワーク「Phoenix」を福岡で広め、ワイワイと盛り上げていくコミュニティです

Elixirは、シンプルな言語仕様により、「プログラミングが初めて」という方でも比較的とっつきやすく、同時に、関数型言語にありがちな複雑さ(トリッキーな構文、数学やアカデミックに走り過ぎる、等)無しに関数型の強力さだけを抽出した、現実のアプリケーション開発を行うエンジニアに寄り添ってくれる言語です

Phoenixは、Webアプリケーションの世界では、最もメジャーな「Ruby on Rails」を作っていたメンバーによって開発された、大量アクセスと高速分散の捌きが得意なWebアプリケーションフレームワークで、Rails同等の高度なWebアプリ開発を、とても気軽に行えます(中でも、WebSocket性能は、あらゆる言語のFW中でも最速)

「fukuoka.ex」では、MeetUp(登壇会/勉強会)やプログラミング入門会、もくもく会、ハッカソン等を通じて、「Elixir/Phoenixの習得機会」と「実際のアプリケーション開発に役立つノウハウ」の提供を定期的に行うことで、福岡でのElixirプロダクション採用を増やし、Elixirに触れることで得られる「プログラミングの楽しさ」を福岡のエンジニアに体感する機会を増やすことをビジョンに掲げています

~ Elixir/Phoenixの現状について ~

福岡Elixirコミュニティ「fukuoka.ex」とは?

「fukuoka.ex」は、大量アクセスのあるWeb・APIサーバ構築や、ビッグデータ分析/AI・機械学習向けデータ加工といった、「膨大なアクセスやデータの高速処理」と「高い開発効率」を両立できる関数型プログラミング言語「Elixir」と、そのWebアプリケーションフレームワーク「Phoenix」を福岡で広め、ワイワイと盛り上げていくコミュニティです

Elixirは、シンプルな言語仕様により、「プログラミングが初めて」という方でも比較的とっつきやすく、同時に、関数型言語にありがちな複雑さ(トリッキーな構文、数学やアカデミックに走り過ぎる、等)無しに関数型の強力さだけを抽出した、現実のアプリケーション開発を行うエンジニアに寄り添ってくれる言語です

Phoenixは、Webアプリケーションの世界では、最もメジャーな「Ruby on Rails」を作っていたメンバーによって開発された、大量アクセスと高速分散の捌きが得意なWebアプリケーションフレームワークで、Rails同等の高度なWebアプリ開発を、とても気軽に行えます(中でも、WebSocket性能は、あらゆる言語のFW中でも最速)

「fukuoka.ex」では、MeetUp(登壇会/勉強会)やプログラミング入門会、もくもく会、ハッカソン等を通じて、「Elixir/Phoenixの習得機会」と「実際のアプリケーション開発に役立つノウハウ」の提供を定期的に行うことで、福岡でのElixirプロダクション採用を増やし、Elixirに触れることで得られる「プログラミングの楽しさ」を福岡のエンジニアに体感する機会を増やすことをビジョンに掲げています

~ Elixir/Phoenixの現状について ~

Elixir/Phoenixにとって、2016~2018年は、

  • マルチコアのCPU全てをフル活用できる「Flow」や「GenStage」
  • 動的生成されたマルチプロセスを監視・自動再起動できる「Dynamic Supervisor」
  • Webフレームワーク「Phoenix」のHTTP/2対応やwebpack対応
  • IoTコアライブラリ「Nerves」と、クラウド上からファームウェア更新を叶える「NervesHub」

といったElixirならではの革新的な独自機能を出しつつ、「Elixir/Phoenixのみで、Webプロダクト開発やSI案件開発を不自由無く行える」フェーズへと進化しています

Githubに登録されているElixirライブラリも、36,000件を突破し、2年前の7,000件程度と比べ、5倍以上へと急増しました

2014~2015年付近は、Elixirも未だ未成熟で、「Erlangを覚えなければElixirは使えない」という認識が一般的でしたが、現状は、Elixir単独で充分にプロダクト開発/SI案件開発を行える状況へと変わってきています

また、2017年にはGCP(Google Cloud Platform)でのElixir採用、2018年にはAWSでのカスタムランタイム採用、といった、大手クラウドでのElixir採用という追い風もありました

福岡においても、Elixir/Phoenixをプロダクト開発/SI案件開発で採用されるケースが増え、他言語よりも明らかにレスポンス速度が速いWeb+DBが数日で構築できた事例や、1年以上ダウンせずに運用が回った事例など、実運用の実績も増えています(福岡以外でも、SlackやLINE、ニコニコ動画、mixi、gumi等での活用事例もあります)

全世界で見れば、2014年は、200社程度しか採用していなかったのが、2016年は1,100社を超え、現在は、ゲームサーバだけに限らず、フィンランドやスウェーデン、イギリスを始めとする、金融/証券/SNS/メッセージング基盤などの分野で活用されており、世界的にも有名なSlackやDiscordでも積極的に活用されています

そしてElixir/Phoenixにとっての2019年は、以下を完備し、スマホ開発やクラウドへの接続性も大幅に増強されました

  • Phoenixで、JavaScript無のElixirのみで、フロント処理を動的生成できる「LiveView」
  • 対障害性を備え、Amazon SQSとも接続できる並列ライブラリ「Broadway」
  • Prometheus等の外部監視系への容易な接続を実現する「Telemetry」

今は、まさにElixir/Phoenixを始めるには、もっとも美味しいタイミングと言えるでしょう

海外と福岡のおける導入企業/規模/事例は、以下fukuoka.exポータルにて紹介しています
https://fukuokaex.fun

更に、fukuoka.exでは、これまでの言語では表現できなかったような次世代の高生産性Web/API開発スタイルの確立や、大規模インフラでもDBサーバをネックにしないためのスケールアウトの仕組み、ElixirとGCP上のAIエンジンを繋いだ画像解析システム、数倍のパフォーマンスを発揮できるGPU/FPGA活用、Elixirプロセスよりも更に軽量なプロセスライブラリ実装、ElixirによるElixirコンパイラ開発といった、先端領域でのElixir活用も、今まさに熱く展開しています

「でもElixirって、使いづらくて覚えにくい『関数型言語』でしょ?」

一般的に「関数型言語」と言えば、言語の習得が難しく、組織として選定しづらいイメージがありますが、Elixirは、言語仕様や構文がシンプルかつ簡単なので、「育成や習得の容易性」を切り捨てること無く、関数型のメリットも享受できます

関数型のメリットは、以下の通りです

  • 状態が無いことで、同じ入力を何度行っても同じ出力しか返さないので、意図しない挙動にならない
  • 変数がイミュータブル(作成後にその状態が不変)なので、マルチスレッドや並行処理で競合しない
  • プログラム構造が小さな関数群で構成され、シンプルに保たれるため、変更容易性が向上する
  • 少ないコードで、凝縮度の高い高度な処理が書ける
  • リスト設計に慣れていくと、他言語で数百行かかる複雑な処理も、数行のコードで組むことが可能になる
  • できあがったコードは、オブジェクト指向言語の1/100の量になることもあり、見た目も100倍エレガント
  • オブジェクト指向言語経験者の移行は大変(関数型全般に言える)だが、移行後は、何倍も生産性が高まる

更に、「Elixirならでは」の以下メリットも上乗せされます

  • 習得がカンタンなので、プログラミング経験が無い入門者・初級者向け
  • 関数の引数でのパターンマッチが可能で、呼出時の事前条件チェックや関数呼び分けには、快感すら感じる
  • JSONパースが得意なので、Google APIやBacklog API等、様々なWeb APIとの連携に強い
  • マルチコアCPUを簡単にフル活用できる
  • マルチクラスタ(AWS、GCP、Azure)のスケールアウトも楽々実現
  • 長期間の安定運用を実現してきた「Erlang VM」の元で動作する
  • データ変換とバイナリデータ検索に特化しているので、ファイルヘッダ解析やIoT/ドローン制御にも向いている

実際に、Elixirがどの位カンタンに習得できるかと言うと、たった3つの関数を覚えるだけ、30分~1時間もあれば、Web+DB/Web+API/Webグラフ表示まで実現できてしまいます

通常の関数型言語と一線を画す、このElixir/Phoenixのパワーを直接体感してみたい方は、「ExcelでElixirマスター」シリーズをご覧ください

Media View all Media

If you add event media, up to 3 items will be shown here.

Feed

piacere

piacere published fukuoka.ex#30:tokyo.exとコラボ、Elixir本体コード読込会(リモートのみ).

09/24/2019 14:03

fukuoka.ex#30:tokyo.exとコラボ、Elixir本体コード読込会(リモートのみ) を公開しました!

Group

Ended

2019/09/29(Sun)

13:00
17:00

開催日時が重複しているイベントに申し込んでいる場合、このイベントには申し込むことができません

Registration Period
2019/09/24(Tue) 14:02 〜
2019/09/29(Sun) 13:00

Location

皆様のご自宅含む、NW接続ができる環境なら、どこでも

皆様のご自宅含む、NW接続ができる環境なら、どこでも

Organizer

Attendees(13)

dododo8m

dododo8m

fukuoka.ex#30:tokyo.exとコラボ、Elixir本体コード読込会(リモートのみ) に参加を申し込みました!

yaza_ta

yaza_ta

fukuoka.ex#30:tokyo.exとコラボ、Elixir本体コード読込会(リモートのみ) に参加を申し込みました!

HidetakaOgawa

HidetakaOgawa

fukuoka.ex#30:tokyo.exとコラボ、Elixir本体コード読込会(リモートのみ)に参加を申し込みました!

hisaway_ex

hisaway_ex

fukuoka.ex#30:tokyo.exとコラボ、Elixir本体コード読込会(リモートのみ)に参加を申し込みました!

sibazuke

sibazuke

fukuoka.ex#30:tokyo.exとコラボ、Elixir本体コード読込会(リモートのみ)に参加を申し込みました!

kumi0514

kumi0514

fukuoka.ex#30:tokyo.exとコラボ、Elixir本体コード読込会(リモートのみ)に参加を申し込みました!

sla10132000

sla10132000

fukuoka.ex#30:tokyo.exとコラボ、Elixir本体コード読込会(リモートのみ) に参加を申し込みました!

shoz_f

shoz_f

fukuoka.ex#30:tokyo.exとコラボ、Elixir本体コード読込会(リモートのみ) に参加を申し込みました!

torifukukaiou

torifukukaiou

fukuoka.ex#30:tokyo.exとコラボ、Elixir本体コード読込会(リモートのみ) に参加を申し込みました!

16

16

fukuoka.ex#30:tokyo.exとコラボ、Elixir本体コード読込会(リモートのみ)に参加を申し込みました!

Attendees (13)

Canceled (1)