データベースから画像を選択してエンコードするときにパフォーマンスの問題が発生するため、これは非常に重要です代替戦略を検討します。
MySQL では、バイナリ アセットをデータベースではなくファイルとして保存することをお勧めします。通常、Web サーバーはデータベース コンテンツに比べてファイルに対して優れたキャッシュ メカニズムを提供するため、このアプローチによりパフォーマンスが向上します。
Base64 エンコーディングは次の機能を提供します。圧縮効果はなく、画像サイズが約 33% 増加します。このオーバーヘッドはパフォーマンスに大きな影響を与える可能性があります。
画像をデータベースに直接保存する代わりに、ファイル システムまたは次のようなクラウド ストレージ サービスに保存します。アマゾンS3。ファイル パスをデータベースに保存すると、Web サーバーによる効率的な取得とキャッシュが可能になります。
Gzip などの圧縮技術は、特定のファイル タイプでは、画像は通常、すでに圧縮されています。さらに圧縮しようとすると、オーバーヘッドが増加して最小限の節約になる可能性があります。
セキュリティが懸念される場合は、アクセス制御メカニズムを実装して、画像ファイルにアクセスできる人を制限します。役割ベースのアクセスにより、承認されたユーザーのみが画像の表示またはダウンロードの権限を持つことが保証されます。
以上がデータベース イメージの取得が遅いのはなぜですか? 最適化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。