レギュラートーク(15分)

良いポストモーテムできてますか?〜障害対応を組織の「学習」に活かすための観点を身に着ける〜

o0h_ きんじょうひでき

障害、嫌ですよねぇ。
嫌だから、起こしません・・・!素晴らしいのですが、「リリース怖い」「改修怖い」では、前に進めなくなります。

1番良いのは「適切に怖がる」「転んだら盛大に学び尽くす」という態度です。
スクラムを筆頭に、「ふりかえり」の力は「組織を強くする」ためのアジャイルな組織に必須な力と考えられています。もっと広げれば、体験学習の世界でも重要なことです。

そうした、本来の「これから先に活かすふりかえり」の姿を取り返しませんか?

お伝えしたいこと

  • ただの「事実確認」で終わらせない、障害のふりかえりをやろう
  • 「同じことはもう起きない」ではなく、「組織としての課題」につなげよう
7
レギュラートーク(45分)

RDBアンチパターンと戦う - 削除フラグ 完全攻略ガイド

soudai1025 曽根 壮大

目の前に立ちはだかる削除フラグ......
削除フラグがアンチパターンであることは知っていても、目の前の削除フラグと付き合っていくしか無い...
そう思って諦めていませんか?

削除フラグを既存のアプリケーションに影響をできるだけ閉じて無くすことはできます。
テーブルから状態や属性を別のテーブルに移し、アプリケーションを壊すことなくリファクタリングしていくために必要なことを説明します。

  • 削除フラグがあるテーブルをどうやって分割するか
  • 既存のコードの振る舞いを維持しながら如何にリファクタリングするか
  • リファクタリングをやりきる ために必要なステップ

レガシィコードと向き合い、リファクタリングして、目の前のプロダクトを改善している現場のテクニック、余すこと無くお話します!

15
レギュラートーク(45分)

"課題を解決するエンジニア" になるために今からできること、必要なこと ~ 先人の言葉から学ぶ、生き残る道 ~

soudai1025 曽根 壮大

生涯エンジニアを続けたい。
しかしインターネットを見渡せば凄腕のエンジニアばかり。
このまま、自分は生き残れるのだろうか...

私も今年、38歳を越え、職場ではCTOとして決断を迫られる中、それでも新しい技術を理解し、向き合って行かねばなりません。 もちろん一日は有限ですから勉強する時間も限られます。

そんな中、私がどうやって新しい技術を理解し、未来の技術を予測し、今の技術を選定しているか。
そのために日々をどう過ごしているか。そんな "エンジニアとして生き残るためのhack" を皆さんにお伝えします。

ピカソは言った。「優れた芸術家は模倣し、偉大な芸術家は盗む。」

先人の言葉を例に上げながら、課題を解決するエンジニアになるためのロードマップをお話します。

16
レギュラートーク(45分)

オレがオブジェクト指向をやめるために必要な3つのPHP RFC

kis きしだ なおき
kis

みんな、オブジェクト指向やめたいですよね?(うんうん)
けれども、オブジェクト指向やめたいと思ってもPHPには機能が足りません。
このセッションでは、オブジェクト指向をやめてコードを書くときに大事な考え方、抽象データ型と代数的データ型、そしてそのために必要な機能とそれを提案するPHP RFCについて紹介します。

--
抽象データ型、代数的データ型の考え方と、直積型、直和型、パターンマッチングとそれを提案する「PHP RFC: Algebraic Data Types」について話そうと思います。
https://wiki.php.net/rfc/adts

15
レギュラートーク(30分)

PHP で学ぶ非同期処理

m3m0r7 めもり〜

以前まで PHP で非同期処理を扱うためには様々な制約をクリアする必要がありました。しかし,昨今の PHP では非同期処理を容易に扱うためのライブラリである Swoole や,parallel,PHP 8.1 からビルトインされた Fibers などがあります。
しかし,そもそも非同期処理とはどういったものなのでしょうか。非同期処理を調べていくと並行処理や並列処理,マルチスレッドやマルチプロセスなど様々な単語が出現しますが理解するのもハードルが高いと感じる方もいらっしゃるかと思います。
本トークは初級者から中級者向けに非同期処理について,拙著「Swooleで学ぶPHP非同期処理」からいくつか引用・補足し,非同期処理の基礎から PHP で非同期処理を実現する方法をお伝えします。

9
レギュラートーク(30分)

PhpStormとGitHub CopilotでAIと協働する

ippey_s 角田 一平

ChatGPTやGitHub Copilot Xなど、今年に入ってさらに熱くなってきたAI業界。
今年からGitHub Copilotを使い、AIと一緒にプログラムを書いていますが、私たちの仕事にも大きな変化が訪れる気配を感じます。

今セッションでは、PhpStormとGitHub Copilotを使ったライブコーディングを行いながら、AIと協働するメリットや気をつけるべき点などをご紹介します。

17
レギュラートーク(45分)

PHPerも(?)本を読もう

uzulla uzulla

「いい本ありますか?」しばしば聞かれます。紹介したとして貴方は本当に読んでいるのか…?というのはさておき、本を読むというのは一般的にはメリットのある行為です。

紹介した本が本当に読まれているのかはさておき(???)、聞かれたときに答える最近の本をご紹介するのは当然として、さらに一歩進み、「読んだ本を経典・正義にするな」という話をしたいと思います。

なお、PHP以外の本もご紹介します。なぜならPHPの本がないから…ではなく、万物は大体同じだからです。
PHP以外の本を読む事により、あらたなインサイトを貴方がえられるように頑張ってみたいと思います。

まあ、そうはいうても私の趣味もはいりますので、「これが聖書…!」と言う受け止め方はしないでくださいね!!

8
レギュラートーク(45分)

使おう!!xdebug!!

uzulla uzulla

PHPは実のところ非常にデバッグがしやすい言語です。なぜならxdebugという非常に優秀なデバッガがあり、それを支えるエコシステムが存在するからです。xdebugを使うことで便利に、詳細に、迅速にデバッグを行うことができます。

しかしながら「xdebugなんていらないよ!print debugで十分!」という声もよく聞きます。

そんなことはない!!(断言)

ということで、多機能なxdebugで単なるステップ実行以上をご紹介します。

こんな魔法のような事までできる!そうxdebugならね!!

話さないこと

  • xdebugのインストール方法(ググればでてきますし、個々の環境で差があるので)
14
レギュラートーク(45分)

愉快なイベント駆動型システム アンチパターン

ex_takezawa ytake

イベントソーシングやCDCなどのテクニックは、
レガシーシステムの移行やデータ移行・データパイプライン、
リアクティブシステム構築に欠かせない重要な要素です。
しかし、取り入れ方を間違えると致命的なアンチパターンに陥ってしまうこともあるんです。
例えば、状態をもたせないイベントでマテリアライズドビュー化してしまったり、
巨大なランタイムを持たせてしまったハンドラ、
分割しすぎて時系列を無視したイベント、
まったく互換性のないメッセージなどなど。
でも大丈夫!少しのミドルウェアの知識やドメインについての知識があれば、これらの問題は防ぐことができます。
ここでイベントソーシングやCDC、Outboxについて説明しながら、複雑さに立ち向かう方法を楽しくお伝えします!
実際にやってしまった失敗談や成功談をもとに、
これらのテクニックが何なのかをわかりやすく説明します。一緒に楽しく学びましょう!

このセッションはPHPにフォーカスしたものではなく、システムやアプリケーション全般に関するトークとなります。

19
レギュラートーク(30分)

ぼくの PhpStorm の使い方を見せるからみんなの使い方も見せてくれ!!

chatii ちゃちい

超強力な統合開発環境 PhpStorm
今や多くの PHPer にとって無くてはならないエディタでありIDEであることに疑いはありません
多機能であるがゆえ、「えっ、何そんな便利機能があるの?知らんかった!」がまれによく発生します

PhpStorm を使い始めてそろそろ12年 (マジかよ) になりますが
まったく使いこなせている気がしません

ライブで「こんな機能あるんだよ」を紹介しますので
おおーなどと反応したり
こんな機能もあるぞーなど紹介(ガヤ)してほしいです

(ショートカットキーの話はしないです)
(PhpStorm を使っていない方はその便利さに圧倒されてください)

8
レギュラートーク(45分)

その場にいる皆さんと一緒にオレオレフレームワークを作ってみましょう

o0h_ きんじょうひでき

FWの気持ちを理解できると、きっと素敵ですよね
その為に「自分でFWを作ってみる」というアプローチがあります。今風の要件を備えた物を自作する事で、普段使っているFWを読み解く勘所を掴みやすくするのです

PHPerKaigi 2023では、FWの自作は開発者のレベルを高めるはずだ!という仮定のもと、今風のFWの要件を考察し実装するというテーマのトークを行いました
今回のトークでは、その際に得たFWを例に、実際に動くものを作り上げていく事に主眼を置いて発表します
ハンズオンっぽい形やライブコーディング風の説明を多く取り入れるので、是非その場で一緒に手を動かしながら聞いてください

狙い

  • FW、怖くないやい!読める!と思える
    • 普段から気軽にFWのコードリーディングをしちゃう人を増やす
  • DIコンテナの使われ方(FWがどう依存を注入しているか)を掴む
  • PSR-15/ミドルウェアパターンのイメージを掴む

対象

内容

  1. 作成するFWの概要
  2. FWを作ってみる
  3. 2を使って簡単なアプリを作成する

「2. FWを作ってみる」のスコープ

  • ルーティング、ディスパッチ
  • PSR-15のミドルウェア
  • コンテンツの描画(プレゼンテーション層)
  • コンテンツを出力するEmitter
  • ユースケースの処理(アクション)

※ 以下は実装を割愛

  • DIコンテナ(PSR-11): league/containerを利用
  • HTTP Factories(PSR-17): nyholm/psr7を利用
  • DB層(”モデル”): 割愛
3
レギュラートーク(30分)

すばやく実装するための戦略とテクニック 2023年版

77web 菱田裕美

2018年のPHPカンファレンス関西で発表した「すばやく実装するための戦略とテクニック」から5年、「速さは力」をモットーに相変わらずスピードを出してコードを書いています。
自分では「長く在籍してドメイン知識がついたせいでは?」と思っていましたが、副業に行っても、転職しても、やはり「プルリクが光速」「レビューが追いつかない」と同僚から褒められたりクレームを言われたりします。
文系ですし、20代半ばで初心者からPHPを始めた身なので、才能があるわけではありません。
速さを実現するために積み重ねている工夫や使っているテクニックを、2023年現在の内容にアップデートしてお伝えします。

18
レギュラートーク(15分)

「リモート時代」に拡大する、地方のエンジニアの活躍の場・存在意義

Tooka_91 tooka_91

私のキャリアの直近3~4年は、東京のエンジニア採用に加え、地方のエンジニア採用をしてきました。
採用活動を通じて、地方のエンジニアが現地に根を張り、活躍することに非常に大切な意味があると思っています。
特にリモート普及後、「フルリモート」「現地の企業」「地方拠点」など、企業の選択肢も格段に増えてきました。

■話をしたいと思っていること
・関東と地方のキャリアの違い
・リモート普及後の地方のエンジニアの変化
 ・どのような活躍の仕方があるか
 ・逆にどのような問題がおきているか
 ・技術コミュニティの在り方の変化
・リモート時代の地方のエンジニアの存在意義
 ・地方でエンジニアが活躍することにどのような存在意義や価値があるのか

日本社会は、労働力減少や少子高齢化など直面している問題が山積みで、関東一極型の働き方は難しくなっています。
福岡であったり、それ以外の地域でのエンジ二アが活躍・活動する場所が増えていったり、居住地を含めた柔軟な働き方は今後ますます必要になっていくため、地方でキャリアの挑戦をしたいと考えている人の後押しになる発表を目指していきたいと思います。

私自身の経験を通じて、地方のエンジニアの活躍・地域ITコミュティの重要性についてお話したいと思います。

7
レギュラートーク(15分)

PSR-14: Event Dispatcherを肴に「イベント」について理解を深める

o0h_ きんじょうひでき

PHPのフレームワークやライブラリを作成する人に向けて、「みんながこういうノリで実装してくれたら嬉しいな」を形にした「PSR」と呼ばれる取り決めがあります。

https://www.php-fig.org/psr/psr-14/

「PSR-4(オートローディングに関する規約)」「PSR-7(HTTPメッセージの取り扱い表現方法に関する規約)」「PSR-12/PER Coding Style(コードのスタイルに関する規約)」などは、耳にしたことがある人も多いのではないでしょうか。

そんなPSRの中に、「PSR-14: Event Dispatcher」があります。イベントやその発行・購読についての規約です。
この14番は、どちらかというと知られていない部類のような気もしています!

このセッションで、改めてスポットライトを当ててみましょう。
「PSR-14とはどういうもので、リアルワールドにおいてはどのような実装があるのか」について知ってみませんか?

話すこと

  • PSR-14は何を狙ったものなのか
    • この取り決めが議論され形になった背景には、どのようなプログラミング上の課題があったのか。何を解決するものなのか
    • = 「Observerパターンとどう付き合うか」みたいな話
  • PSR-14を用いた実装例(ライブラリ)を覗いてみる
2
レギュラートーク(30分)

#駆け出しエンジニアリングマネージャー 向け、「コーチングってどうやってマネジメントに役に立つの」

o0h_ きんじょうひでき

マネジメント、「私には無理」とか「億劫だな、やりたくないな」と思っている人も多いでしょうか?
その一方で、組織は何かしらの期待を持って、プログラマーに対して「マネジメント職をやってほしい」と依頼をしてくる事があります。

さて、最近では「マネジメント」というと「1on1をしよう」という話がありませんか。
そして、「1on1」と聞くと「コーチングを〜〜」という単語も、関連して想起されることがあるのではないでしょうか。

では、「1on1」「コーチング」という言葉から、何を思い浮かべますか?
あるいは「良い1on1」「良いコーチング」を自分の言葉で説明できるでしょうか。
私は、プレイヤー→リーダー→マネジメント(8人程度)→マネジメント(15人程度)→ジュニアなマネジメントも対象に含むマネジメント(35人程度)と、職務上の役割がシフトしてきました。
それに備えて、パーソナルコーチングのトレーニングを受けたり、組織開発や臨床心理学の領域に近いような学習も進めています。

そんな経験の中で、個人的には「コーチングのマインドやスキルを知ることで、良かった・明らかに役に立っている」と感じています。
本トークでは、主観的な経験を踏まえて「なぜ、どうやって、どうして役に立ったのか」をシェアしていきます

本トークの想定聴衆

  • マネジメント職を担う(これから取り組む)上で、人と向き合う「難しさ」を感じている人
  • コーチングという言葉は知っているが、それが何をもたらすのか・どういった概念なのかを知らない・興味がある人
  • メンティーの立場から「効果的な1on1を実施できていない」と感じている人

本トークのねらい

  • マネジメント(する側・される側)における、「幅」を増やして、苦しさや辛さを少し軽減する
  • いち個人と向き合って、その人のエネルギーを充実させることの楽しさを知ってもらう

免責

  • 発表者はコーチングのトレーナーとしての訓練を受けているわけではなく、プロとしてコーチ業を提供している訳ではありません
    • そのため、本セッションは「コーチングのやり方」を提供する事は目的としません
4
レギュラートーク(15分)

WordPressのFargate移行で思った以上に苦戦した話

みんな大好きWordPress!世界のWebサイトの4割以上と圧倒的シェアを誇る皆様御存知のPHP製超有名CMS!
そんなCMSで作られたWebサイトのインフラをリプレースする機会に恵まれたので、イキって「時代はコンテナ!冪等性こそ至高!」とEC2からFargateに載せ替えようとしたら大失敗?!

今回のトークでは上記のEC2からFargateへのリプレースプロジェクトにおいて得られた知見を共有させて頂きます。

お話すること

  • 実際に行った移行手順
  • ハマったポイントとその解決策
  • リプレースしてみた感想
4
レギュラートーク(15分)

PHPのビルトインウェブサーバーを本番環境で使ってはいけないN個の理由

takeokunn たけてぃ

PHPのビルトインウェブサーバーを使ったことはありますか?
Laravelユーザーの方ならお馴染みの「php artisan serve」というコマンドで使用しているかもしれません。

実際HerokuやAWS ECSのLaravelデプロイ時に「php artisan serve」を使用する例もちらほら見受けられますし、公式サイトでもこのようなサンプルが紹介されています。

しかしながら、php公式がビルトインウェブサーバーを本番環境で使用することを禁止しています。
https://www.php.net/manual/ja/features.commandline.webserver.php

実際にビルトインウェブサーバーを使用した経験に基づいて、その弊害についてお話ししながら、ビルトインウェブサーバーの注意点をまとめてみました。

9
LT(5分)

実演!!ホワイトボードツールを使ってPHPのコードリーディングを捗らせる

o0h_ きんじょうひでき

見知らぬコード、深いスタック、多様なクラスやメソッド・・・・
それらに立ち向かうのは、楽しくもあり大変でもあることですね!頭がパンクしちゃうこともしばしば!

どうしたら、少しでも効率よく・安心しながらコードリーディングを進められるでしょう。
ポイントは、「要点を掴む(=肝心でない所は脳みそからflushする)」「振り回されない(=コードを行ったり来たりしやすくする)」事だと思います。
それを実践するためのツールや技法を用意できると良いですよね。

脳内で補いきれない所は、「道具」で補って賢くやりましょう。
Xdebugのステップ実行と、ホワイトボードツール(Miro)の付箋とメモを活用することで、とっても効果的にコードの理解を進めることができます!

ある程度複雑なライブラリを例に、実際に「どうやったのか」をお見せします。

4
レギュラートーク(45分)

40分ひたすらxUnit Patternsのコンテンツを紹介します

o0h_ きんじょうひでき

「翻訳してほしい技術書」あるいは「鈍器」として名高い、xUnit Test Patternsという書籍があります。
読んだことはありますでしょうか?あるいは、「名前は聞いたことあるけど・・」という方も、非常に多いと思います。

「興味があるし、役に立つとは確信しているのに、読んで見るに至っていない」
それは何故なのでしょう?要因の1つとして、 あなたの興味が足りないから という不都合な事実はありませんか!!

このトークでは、「どんな事が書かれているのか」を、時間が許す限り紹介していきます。
物量も情報量も多い書籍なので、興味を持っても「全部読む」のハードルは引き続き高いかも知れません。
それでも、「どんな事が分かる本なのか、自分の求めるヒントになりそうなのか」「どういう風に、読んでいけな良いのか」の解像度が上がってしまえば、きっと手にとってみたくなりますよね・・!
「45分」枠のうち、自己紹介やまとめの時間を除いて「40分」でxUTPアトラクトを目指していきます。

このトークのねらい

  • 聴いている人の中にある、ユニットテストに対する”怖さ”を少しでも取り除く
  • チームの「ユニットテスト力」を高めるための形式知をインストールする。あるいは、インストールの仕方(引き出し)を増やす

話すこと

  • xUTPの全貌
  • どんな事が書かれていて、どんな時に/どんな人に役に立つか
  • どんな風に使っていけば良さそうか
3
レギュラートーク(30分)

再発明し<作っ>てあそぼう!Composer

o0h_ きんじょうひでき

Composer大好きな皆さん、その愛をもっと強い形でぶつけてみたいな〜と思ったことはありませんか?
好きなものを自分のものにするには、やはり作ってみるのが1番ですよね。
既に高い完成度で存在しているComposerを、コレを機にわざわざバラバラにして再発明してみましょう!

このトークのねらい

  • Composer内部の主要な概念/実装についての解釈を進めて、理解を深める
  • それによって普段使っているツールの気持ちをちょっと理解する

このトークで得られるもの

  • (Packagist等のリモートや、ローカルファイルなどの)レポジトリ情報・パッケージ情報の内容を理解できる
  • それらを扱うためのプログラムとしてのComposerの仕組みを理解できる
  • PHPのautoloaderの設定方法について理解できる

やること

  • composer installcomposer dumpautoload の「端折った」実装を行い、解説します
  • そのために前提知識として必要な概念の解説をします
6