$30 off During Our Annual Pro Sale. View Details »
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
今からでも間に合うphp5.5からphp7.2にバージョンアップした話 #phpcon
Search
kosa3
December 15, 2018
Technology
5
1.7k
今からでも間に合うphp5.5からphp7.2にバージョンアップした話 #phpcon
PHP Conference 2018でのLT会登壇資料です。
kosa3
December 15, 2018
Tweet
Share
More Decks by kosa3
See All by kosa3
3ヶ月でphp5.5から7.2にバージョンアップした現在と今後の向き合い方 #PHPerKaigi 2019
kosa3
1
3.9k
Other Decks in Technology
See All in Technology
Snowflake Industry Days 2025 Nowcast
takumimukaiyama
0
120
Kiro を用いたペアプロのススメ
taikis
4
1.9k
[Neurogica] 採用ポジション/ Recruitment Position
neurogica
1
130
フルカイテン株式会社 エンジニア向け採用資料
fullkaiten
0
9.9k
AWSインフルエンサーへの道 / load of AWS Influencer
whisaiyo
0
220
「図面」から「法則」へ 〜メタ視点で読み解く現代のソフトウェアアーキテクチャ〜
scova0731
0
520
202512_AIoT.pdf
iotcomjpadmin
0
150
テストセンター受験、オンライン受験、どっちなんだい?
yama3133
0
170
AWS運用を効率化する!AWS Organizationsを軸にした一元管理の実践/nikkei-tech-talk-202512
nikkei_engineer_recruiting
0
170
意外と知らない状態遷移テストの世界
nihonbuson
PRO
1
270
AgentCore BrowserとClaude Codeスキルを活用した 『初手AI』を実現する業務自動化AIエージェント基盤
ruzia
7
1.6k
100以上の新規コネクタ提供を可能にしたアーキテクチャ
ooyukioo
0
260
Featured
See All Featured
[RailsConf 2023] Rails as a piece of cake
palkan
58
6.2k
HDC tutorial
michielstock
0
280
Breaking role norms: Why Content Design is so much more than writing copy - Taylor Woolridge
uxyall
0
120
Agile Leadership in an Agile Organization
kimpetersen
PRO
0
58
RailsConf & Balkan Ruby 2019: The Past, Present, and Future of Rails at GitHub
eileencodes
141
34k
Groundhog Day: Seeking Process in Gaming for Health
codingconduct
0
66
How People are Using Generative and Agentic AI to Supercharge Their Products, Projects, Services and Value Streams Today
helenjbeal
1
82
Learning to Love Humans: Emotional Interface Design
aarron
274
41k
ReactJS: Keep Simple. Everything can be a component!
pedronauck
666
130k
Tell your own story through comics
letsgokoyo
0
770
Digital Projects Gone Horribly Wrong (And the UX Pros Who Still Save the Day) - Dean Schuster
uxyall
0
110
Information Architects: The Missing Link in Design Systems
soysaucechin
0
720
Transcript
今からでも間に合う php5.5からphp7.2に バージョンアップした話 菅原 佑太 / kosa3 株式会社ウエディングパーク
・結婚・婚約指輪の口コミサイト 「Ringraph」の運用・開発責任者 ・サーバーサイドエンジニア ・Serverless Framework, Nuxt.js勉強中 菅原 佑太 株式会社ウエディングパーク 新卒3年目/チーフエンジニア
kosa3
・ウエディングパークの姉妹サイト ・2015年 9月からサービススタート(3歳) ・クチコミ数2万件以上 ・php + CodeIgniterで構成
それは突然のことでした…
「社内で実施している セキュリティチェックで 1つお願いしたいことがあるんだが...」 上司
「なんですか?」 ぼく
「PHPのバージョンアップを お願いしてもよいかな?」 上司
「いつまでにですか?」 ぼく
「3ヶ月くらいで…」 上司
「ちょ、調査します!!!」 ぼく
None
既に2016年でサポート終了
今回あげるバージョンは7.2
早速、工数見積もり調査を開始
phpの公式ドキュメントから 移行について洗い出し、 該当するか調べる 調査 その1
None
大体つまずきそうなところは分かった!
Docker環境を作り、 phpのバージョンをあげて検証してみる 調査 その2
$ docker-compose up
None
まぁまぁここまでは想定内… きっと他のミドルやモジュールの 関係だろう
調査結果
・Codeigniter Framework ・CentOS ・Apache ・node.js ・ruby ・composer ・mod_small_light module ・mcrypt
module ・その他モジュールやクライアントライブラリなど PHP以外に必要なバージョンアップ
None
3ヶ月で終わるのこれ…
急遽エンジニア2人増員
・動くようにする ・ログなどのエラーが出ないようにする ・リファクタリング(コードレビュー負荷軽減、 余計なロジック周りのテストの影響範囲を抑える) やるべきこと やらないこと
バージョンアップPJでの課題3選 ・暗号化モジュールmcryptの完全非推奨 ・画像リサイズmod_small_lightのアーキテクチャ変更 ・既存システムの不具合
バージョンアップPJでの課題3選 ・暗号化モジュールmcryptの完全非推奨 ・画像リサイズmod_small_lightのアーキテクチャ変更 ・既存システムの不具合
・php7.2からmcrypt暗号化モジュールが完全非推奨 => 全てOpenSSLに変更 mcryptの完全非推奨
mcryptよりOpenSSLの方が処理速度も良いらしい 【参照】 http://yut.hatenablog.com/entry/20140228/1393543543 mcryptの完全非推奨
バージョンアップPJでの課題3選 ・暗号化モジュールmcryptの完全非推奨 ・画像リサイズmod_small_lightのアーキテクチャ変更 ・既存システムの不具合
・mod_dimsなど他モジュールで代用 ・コンテンツサーバーを用意 ・serverless でリサイズ関数を作成する 画像リサイズmod_small_lightのアーキテクチャ変更 mod_small_lightの後継者探し (サーバー負荷も抑えたい)
・mod_dimsなど他モジュールで代用 ・コンテンツサーバーを用意 ・serverless でリサイズ関数を作成する 画像リサイズmod_small_lightのアーキテクチャ変更 Apache2.4でmod_small_lightの後継者探し (ついでにサーバー負荷も抑えたい) =>姉妹サイトの「DRESPIC」がlambdaでの 画像リサイズを導入していたので横展させてもらう
アーキテクチャ
バージョンアップPJでの課題3選 ・暗号化モジュールmcryptの完全非推奨 ・画像リサイズmod_small_lightのアーキテクチャ変更 ・既存システムの不具合
・全体に及ぶ影響から全範囲を開発・テストする ・意図せぬ不具合を発覚(Sentry, 監査) ・修正 & 報告書 => 工数に入れていない&対応に時間がかかる 既存システムの不具合
まとめ
よかったこと ・PJ開発ルールの統一 ・ミドルのバージョンをモダンにできた ・WAF、CloudFrontなどアーキテクチャを追加 ・SEO対策、パフォーマンス施策など打てた ・php-cs-fixerを導入し、コードの統一した ・テストコードを導入し、CircleCIで自動テストを運用できた
課題だったこと ・全体工数見積もりの算出 ・既存システムの不具合にかかるリソースコスト ・現行システムの運用案件の並行開発
最後に
タイトなスケジュールでも 事前にやることやらないことを 明確化することで最低限のリソースで 進めることができました (今回だけかも…)
でもやっぱり バージョンはこまめにあげましょう
ご静聴ありがとうございました