検索
ホームページバックエンド開発PHPチュートリアルPHP で大きなファイルをすばやく読み取る方法

PHP では、ファイルを読み取るときに、file や file_get_contents などの関数を使用するのが最も速い方法で、数行の簡単なコードで必要な関数を美しく完成させることができます。

しかし、操作されるファイルが比較的大きなファイルである場合、これらの機能は不十分である可能性があります。以下では、PHP が大きなファイルを読み取るための一般的な操作方法を説明するための要件から始めます。

要件は、約 500 万行を含む 8 億のログ ファイルがあり、PHP を使用して最後の数行の内容を返すことです。

実装方法

1. ファイル機能を直接使用して

を操作します。

file 関数はすべての内容を一度にメモリに読み込みます。PHP では、この値が設定されている場合、使用できる最大メモリは 16M に制限されます。 -1 に設定すると、メモリ使用量は制限されません。

次は、file を使用してこのファイルの最後の行を抽出するコードです:

<!--?php</span--><br />
ini_set(&#39;memory_limit&#39;, &#39;-1&#39;);<br />
$file = &#39;access.log&#39;;<br />
$data = file($file);<br />
$line = $data[count($data) - 1];<br />
echo $line;</p>

<p>?>

コード全体の実行には 116.9613 (秒) かかります。私のマシンには 2G のメモリがあり、F5 キーを押して実行すると、システムがグレーになり、ほぼ 20 分後に回復します。このような大きなファイルをメモリに直接読み込むと、非常に深刻な結果が生じることがわかります。したがって、memory_limit をあまり高く調整することはできません。そうでない場合は、コンピューター室に電話してマシンをリセットするように依頼するしかありません。

2. Linux tail コマンドを直接呼び出して、最後の数行を表示します

Linux コマンド ラインでは、tail -n 10 access.log を直接使用して、ログ ファイルの最後の数行を簡単に表示できます。PHP を使用して、tail コマンドを直接呼び出すことができます。実行 PHP コードは次のとおりです。 :

<!--?php</span--><br />
$file = &#39;access.log&#39;;<br />
$file = escapeshellarg($file); // 对命令行参数进行安全转义<br />
$line = `tail -n 1 $file`;<br />
echo $line;</p>

<p> </p>

<p>?>

コード全体の実行には 0.0034 (秒) かかります

3. PHP の fseek を直接使用してファイル操作を実行します

この方法は最も一般的な方法であり、ファイルの内容をすべて読み取る必要はなく、ポインターを介して直接操作するため、効率が非常に優れています。

fseek を使用してファイルを操作する場合、さまざまな方法があり、効率が若干異なる場合があります。一般的に使用される方法は次の 2 つです。

方法 1

最初に fseek を通じてファイルの最後の EOF を見つけ、次に最後の行の開始位置を見つけ、この行のデータを取得し、次に次の行の開始位置を見つけて、この行の位置を取得します。 $num 行目で見つかるまで続きます。

#実装コードは以下の通りです

<!--?php</span--><br />
$fp = fopen($file, "r");<br />
$line = 10;<br />
$pos = -2;<br />
$t = " ";<br />
$data = "";<br />
while ($line > 0)<br />
{<br />
while ($t != "\n")<br />
{<br />
fseek($fp, $pos, SEEK_END);<br />
$t = fgetc($fp);<br />
$pos--;<br />
}<br />
$t = " ";<br />
$data .= fgets($fp);<br />
$line--;<br />
}<br />
fclose($fp);<br />
echo $data</p>

<p> </p>

<p>?>

コード全体の実行には 0.0095 (秒) かかります

方法 2

ファイルの末尾から読み取るには fseek を使用しますが、今回は少しずつ読み取るのではなく、データを部分的に読み取るたびに、読み取られたデータが buf に配置されます。 、改行文字の数 (n) を使用して、最後の $num 行のデータが読み取られたかどうかを判断します。

#実装コードは以下の通りです

<!--?php</span--><br />
$fp = fopen($file, "r");<br />
$num = 10;<br />
$chunk = 4096;<br />
$fs = sprintf("%u", filesize($file));<br />
$max = (intval($fs) == PHP_INT_MAX) ? PHP_INT_MAX : filesize($file);<br />
for ($len = 0; $len < $max; $len += $chunk)<br />
{<br />
$seekSize = ($max - $len > $chunk) ? $chunk : $max - $len;<br />
fseek($fp, ($len + $seekSize) * -1, SEEK_END);<br />
$readData = fread($fp, $seekSize) . $readData;<br />
if (substr_count($readData, "\n") >= $num + 1)<br />
{<br />
preg_match("!(.*?\n){" . ($num) . "}$!", $readData, $match);<br />
$data = $match[0];<br />
break;<br />
}<br />
}<br />
fclose($fp);<br />
echo $data;</p>

<p> </p>

<p>?>

コード全体の実行には 0.0009 秒かかります。

方法 3

<!--?php</span--><br />
function tail($fp, $n, $base = 5)<br />
{<br />
assert($n > 0);<br />
$pos = $n + 1;<br />
$lines = array();<br />
while (count($lines) <= $n)<br />
{<br />
try<br />
{<br />
fseek($fp, -$pos, SEEK_END);<br />
}<br />
catch (Exception $e)<br />
{<br />
fseek(0);<br />
break;<br />
}<br />
$pos *= $base;<br />
while (!feof($fp))<br />
{<br />
array_unshift($lines, fgets($fp));<br />
}<br />
}<br />
<br />
return array_slice($lines, 0, $n);<br />
}<br />
<br />
var_dump(tail(fopen("access.log", "r+"), 10));</p>

<p> </p>

<p>?>

コード全体の実行には 0.0003(s) かかります


声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
トラフィックの高いウェブサイトのPHPパフォーマンスチューニングトラフィックの高いウェブサイトのPHPパフォーマンスチューニングMay 14, 2025 am 12:13 AM

thesecrettokeepingaphp-poweredwebsterunningsmootlyunderheavyloadinvolvesseveralkeystrategies:1)emform opcodecoduceSciptionexecutiontime、2)aatabasequerycachingwithiThing withiThistolessendavasoload、

PHPでの依存関係注射:初心者向けのコード例PHPでの依存関係注射:初心者向けのコード例May 14, 2025 am 12:08 AM

コードをより明確かつ維持しやすくするため、依存関係が関心(DI)に注意する必要があります。 1)DIは、クラスを切り離すことにより、よりモジュール化されます。2)テストとコードの柔軟性の利便性を向上させ、3)DIコンテナを使用して複雑な依存関係を管理しますが、パフォーマンスの影響と円形の依存関係に注意してください。

PHPパフォーマンス:アプリケーションを最適化することは可能ですか?PHPパフォーマンス:アプリケーションを最適化することは可能ですか?May 14, 2025 am 12:04 AM

はい、最適化されたAphPossibleandessention.1)CachingingusapCutoredatedAtabaseload.2)最適化、効率的なQueries、およびConnectionPooling.3)EnhcodeCodewithBultinctions、Avoididingglobalbariables、およびUsingopcodeching

PHPパフォーマンスの最適化:究極のガイドPHPパフォーマンスの最適化:究極のガイドMay 14, 2025 am 12:02 AM

keyStrategIestsoSificlyvoostphpappliceperformanceare:1)useopcodecachinglikeToreexecutiontime、2)最適化abaseの相互作用とプロペラインデックス、3)3)構成

PHP依存性噴射コンテナ:クイックスタートPHP依存性噴射コンテナ:クイックスタートMay 13, 2025 am 12:11 AM

aphpDependencyInjectionContaineriSATOULTAINATINAGECLASSDEPTINCIES、強化測定性、テスト可能性、および維持可能性。

PHPの依存噴射対サービスロケーターPHPの依存噴射対サービスロケーターMay 13, 2025 am 12:10 AM

SELECT DEPENTENCINGINOFCENT(DI)大規模なアプリケーションの場合、ServicElocatorは小さなプロジェクトまたはプロトタイプに適しています。 1)DIは、コンストラクターインジェクションを通じてコードのテスト可能性とモジュール性を改善します。 2)ServiceLocatorは、センター登録を通じてサービスを取得します。これは便利ですが、コードカップリングの増加につながる可能性があります。

PHPパフォーマンス最適化戦略。PHPパフォーマンス最適化戦略。May 13, 2025 am 12:06 AM

phpapplicationscanbeoptimizedforspeedandEfficiencyby:1)enabingopcacheinphp.ini、2)PreparedStatementswithpordatabasequeriesを使用して、3)LoopswithArray_filterandarray_mapfordataprocessing、4)の構成ngincasaSearverseproxy、5)

PHPメールの検証:電子メールが正しく送信されるようにしますPHPメールの検証:電子メールが正しく送信されるようにしますMay 13, 2025 am 12:06 AM

PHPemailvalidationinvolvesthreesteps:1)Formatvalidationusingregularexpressionstochecktheemailformat;2)DNSvalidationtoensurethedomainhasavalidMXrecord;3)SMTPvalidation,themostthoroughmethod,whichchecksifthemailboxexistsbyconnectingtotheSMTPserver.Impl

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。