From a84908b7e8a0e2423afd6b836eccf27a420270b4 Mon Sep 17 00:00:00 2001 From: nsfisis Date: Wed, 20 Sep 2023 19:56:52 +0900 Subject: feat(blog/nuldoc): change content format from DocBook to NulDoc --- .../content/posts/2022-05-01/phperkaigi-2022.ndoc | 167 +++++++++++++++++++++ 1 file changed, 167 insertions(+) create mode 100644 vhosts/blog/content/posts/2022-05-01/phperkaigi-2022.ndoc (limited to 'vhosts/blog/content/posts/2022-05-01/phperkaigi-2022.ndoc') diff --git a/vhosts/blog/content/posts/2022-05-01/phperkaigi-2022.ndoc b/vhosts/blog/content/posts/2022-05-01/phperkaigi-2022.ndoc new file mode 100644 index 00000000..512028a1 --- /dev/null +++ b/vhosts/blog/content/posts/2022-05-01/phperkaigi-2022.ndoc @@ -0,0 +1,167 @@ +--- +[article] +title = "PHPerKaigi 2022" +description = "2022-04-09 から 2022-04-11 にかけて開催された、PHPerKaigi 2022 に参加した。" +tags = [ + "conference", + "php", + "phperkaigi", +] + +[[article.revisions]] +date = "2022-05-01" +remark = "公開" +--- +
+
+ はじめに +

+ 2022-04-09 から 2022-04-11 にかけて開催された、PHPerKaigi 2022 に、 + 一般参加者として参加した。 + 弊社デジタルサーカス株式会社はダイヤモンドスポンサーとなっており、 + スポンサー枠のチケットを使わせていただいた。 +

+

+ 昨年のレポートはこちら。 +

+
+
+ 感想 +
+ 厳選おすすめトーク +

+ 多くの素晴らしいトークの中から、特におすすめのものを 5つ選んだ。 + 是非聞いてほしい。引用部分は、リンク先プロポーザルから引用している。 +

+

+ 予防に勝る防御なし - 堅牢なコードを導く様々な設計のヒント +

+
+

+ PHP はバージョンを追う毎に型宣言、例外、表明、列挙型などの機能が大幅に強化され、堅牢なコードを書くための機能が充実してきました。それらの機能はどう使うと効果的なのでしょうか。 +

+

+ 本講演では PHP 8.1 をベースにして、誤りを想定してチェックするのではなく、そもそも誤りにくい設計とはどのようなものか、つまり「予防」の観点を軸足に、堅牢なコードを導くための様々な設計のヒントをご紹介します。 +

+
+

+ PHPのエラーを理解して適切なエラーハンドリングを学ぼう +

+
+

+ PHPを使ってるとよく遭遇する Fatal error / Parse error / Warning / Notice 理解していますか?
+ これらのエラー文を理解することで、すぐにエラーの原因に気付き適切に対象できる様になります!
+ またそれらを理解した上でのエラーハンドリングを学びましょう。 +

+
+

+ エラー監視とテスト体制への改善作戦 +

+
+

+ 毎日流れてくるエラーに皆さんはどう向き合ってますか?
+ エラーを出さない事が一番ですが、完全に塞ぐ事は難しいと考えます。
+ サービス運用の中で本番環境から発生するエラー(サーバー・クライアントサイド・サードパーティ起因のエラー)への監視体制と、
+ エラー・バグ防御のためチームで行っているテストコード文化づくりの話をします。 +

+
+

+ ISUCON11のPHP実装は、何を考え、どのようにして作られていたのか +

+
+

+ 昨年開催されたISUCON11にて問題(参考実装)のPHPへの移植を担当させていただきました。 +

+

+ 最終的なソースコードこそシンプルなWebアプリケーションではありますが、その裏には
+ ・「(私の思う)良い設計」を実現するための意思決定
+ ・「ISUCONの問題」という位置付けに由来する取捨選択
+ ・移植中に遭遇したトラブルとその解決策
+ といった文脈や葛藤が存在しています。 +

+

+ 本発表はそれらを共有することで
+ ・PHPアプリケーションの設計、実装事例として役立ててもらう
+ ・ISUCONの言語移植に興味を持ってもらう
+ ・ISUCON問題移植の「実装や設計の練習をする教材」としての可能性を知ってもらう
+ ことを目的とします。 +

+
+

+ チームの仕事はまわっていたけど、メンバーはそれぞれモヤモヤを抱えていた話──40名の大規模開発チームで1on1ログを公開してみた +

+
+

+ サイボウズの大企業向けグループウェアのGaroon(ガルーン)は、PHPで開発されている20年目の製品です。ガルーン開発チームは日本で40名、ベトナムで50名の計90名ほどのチームになっています。また、コロナ禍でフルリモートでの活動がこの2年ほど継続してきました。 +

+

+ フルリモートになっても仕事はまわっており、継続的にリリースはしていましたが、一方でお互いの考えていることや感じている問題意識が見えづらくなり、モヤモヤを抱えているメンバーが増えていました。 +

+

+ このセッションでは、そういう状況で私がチーム外からジョインし、聴き役に徹しながら見える化することで状況を改善していった取り組みを紹介します。同じように大きなチームやリモートワークで難しさを感じている人に、難しさの原因への気づきや取り組みへのヒントがあれば幸いです。 +

+
+
+
+ トークン問題の作成 +

+ 今回は、PHPer チャレンジ用に弊社のトークン問題を 3題作成した。 + こちらについては別途記事にしているので、そちらを参照されたい。 +

+
+
+ PHPer チャレンジ +

+ 1位になった。
+ また、賞品として Echo Show 15 をいただいた。 +

+
+
+ カンファレンス全体への感想 +

+ 去年の参加レポ では、こんなことを書いた。 +

+
+

+ 1つ個人的な反省点としては、(中略) Discord しかりアンカンファレンスしかり「このイベントのこの瞬間にしかないコンテンツ」に触れずに、 + 後から見返せる発表やスライドに注力してしまった、ということだ。 + 発表の詳細な見直しはあとからできるのだから、今しかできないことを考えるべきだった。
+ まあ初カンファレンスだし、とお茶を濁しておこう。 +

+
+

+ この反省を踏まえ、今年は積極的にほかの場 (公式の Discord サーバや、アンカンファレンス) にも参加した。
+ これにより、参加体験の質がはるかに向上した。特に Discord に関しては、登壇者ご本人による補足や、 + 質問への回答などがおこなわれる (ことが多い) ため、特別な理由のない限り、発言はしないまでも参加はしておいたほうが良いと思われる。 +

+

+ なお、アンカンファレンスについては、1日目の終わりにトークン問題の解説放送もおこなった。 +

+

+ また、今年はオフラインとオンラインのハイブリッド開催であったが、去年の全オンラインと比べて、オンライン参加の体験が落ちていなかったのは、特筆すべきであろう。 + 今年は 3回目のワクチン接種が間に合わなかったこともあり現地参加は見送ったのだが、来年は是非オフラインで参加したい。 +

+
+
+
+ そして来年へ……? +

+ PHPerKaigi 2023 があるかどうか存じ上げないが、あるとすれば、次の 4つを目標としたい。 +

+
    +
  • プロポーザルを出す
  • +
  • PHPer チャレンジのトークン問題を 5題作成する
  • +
  • 現地に行く
  • +
  • PHPer チャレンジで圧勝する
  • +
+

+


+

+

+ 最後になりましたが、PHPerKaigi のスタッフ、スポンサー、スピーカーのみなさん、素敵な時間をありがとうございました。 +

+

+ ではまた来年。 +

+
+
-- cgit v1.2.3-70-g09d2