1. 必要に応じて PHP を使用する – Rasmus Lerdorf
PHP の作成者である Rasmus Lerdorf ほど、PHP を合理的に使用すべき場所を理解している人はいません。彼は 1995 年に PHP 言語をリリースしました。それ以来、PHP は開発キャンプ全体を焼き尽くす大草原の火のように、世界を変えてきました。インターネットの。ただし、Rasmus はこのような理由で PHP を作成したわけではありません。 PHP は、Web 開発者の実際的な問題を解決するために生まれました。
多くのオープンソース プロジェクトと同様に、PHP は人気が高まっていますが、その人気の動機は通常の哲学では説明できず、あまりにも人気があるため、やや自画自賛的ですらあります。これは、Web のさまざまな問題を解決するためのツールの必要性によって引き起こされたケースとして使用できます。したがって、PHP が最初に登場したとき、そのようなツールのニーズはすべて PHP に集中していました。
しかし、PHPですべての問題が解決されることを期待することはできません。 Lerdorf 氏は、PHP は単なるツールであり、PHP がその能力を超えている状況は数多くあることを初めて認めました。
作業に応じて適切なツールを選択してください。私は多くの企業を訪問して PHP を導入して使用するよう説得してきましたが、これは PHP があらゆる問題に適しているという意味ではありません。これは、ほとんどの問題を解決できる単なるフロントエンド スクリプト言語です。
Web開発者として、PHPを使ってあらゆる問題を解決しようとするのは非科学的であり、時間の無駄でもあります。 PHP が動作しない場合は、ためらわずに他の言語を試してください。
2. マルチテーブルストレージを使用してスケーラビリティを向上させる – Matt Mullenweg
PHP に関するマット マレンウェグの権威に疑問を抱く人はいません。彼は、地球上で最も人気のあるブログ システム (強力なコミュニティによってサポートされています) である WordPress を開発した後、無料のブログ サイトである WordPress .com プラットフォームを立ち上げました。 WordPress MU に基づいています。現在、WordPress.com には約 400 万人のユーザーがおり、毎日 140,000 件以上の投稿を投稿しています。 (WordPress.com の統計をさらに表示するには、ここをクリックしてください。)
ウェブサイトを簡単にスケールする方法を知っている人がいるとしたら、それはマット マレンウェグです。 2006 年、Matt は WordPress のデータ構造に将来を見据えた改善を加え、WordPress MU がすべてのブログ データを 1 つの巨大なテーブルに詰め込むのではなく、ブログごとに独立した MYSQL テーブルを使用する理由を説明しました。
このアプローチをテストしましたが、スケールアウトするとコストが高すぎることがわかりました。全体的なデータ構造を使用すると、大量のトラフィックに直面してサーバー ハードウェアの問題に直面することになります。 MU内。ユーザーは個別のテーブルに分散されており、簡単に整理できます。たとえば、WordPress.com はユーザー データを 4,096 のデータベースに保存しており、これらのデータベースは大規模なデータ アクセスを分散し、トラフィックや圧力を分散することができます。
データテーブルの移植性により、コード(ブログ)の実行が高速になり、システムのスケーラビリティが向上します。 Matt は、強力なキャッシュ戦略と柔軟なデータベース利用戦略を利用して、最も人気のある Facebook と WordPress.com が PHP で安定して動作し、驚くべき量のトラフィックを処理できることを人々に示しました。
3. ユーザーを決して信用しない – Dave Child
Dave Child は、優れた「多くのプログラミング言語のチートシート」で有名な Web サイト、Added Bytes (以前の ilovejackdaniels.com) の中心人物です。 Dave は英国の多くの企業に勤務しており、プログラミング界の権威としての地位を確立しています。
Dave は PHP 開発者に多くの思慮深いアドバイスを提供し、それを「PHP で安全なコードを書く」にまとめました: ユーザーを決して信頼しないでください。ユーザーはあなたを傷つけることさえあります。
何度繰り返しても足りない Web 開発の基本原則があります。それは、ユーザーを決して信頼しないで、Web サイト上のすべてのデータ単位がユーザーから収集された悪意のあるコードであると想定しないことです。多くの場合、クライアント上のフォームによって送信されたコンテンツを検証するには JavaScript を使用する必要があります。これに慣れている場合は、これが良い習慣になります。セキュリティが重要である場合、これは学ぶべき最も重要な原則です。
Dave は現在、著書「Writing Secure PHP」シリーズの例を整理する作業を行っています。本の最後で彼は次のように述べています。
最後に、少し妄想的になってみましょう。自分のサイトが決して攻撃されることはないと考えている場合を除き、問題に正面から向き合ってください。実際に攻撃されたら、悪い状況に陥ることになるからです。すべてのユーザーをサイトに攻撃と防御をもたらすハッカーと見なし、サイトのセキュリティを保護するためにあらゆる手段を講じ、同時に対応する問題の解決策を考える必要があります。
4. PHP キャッシュをもっと使用する – Ben Balbo
Ben Balbo は、開発者とデザイナーにガイダンスを提供する Web サイトである Site Point を開発しました。彼は Melbourne PHP Development and Open Source Club のメンバーであるため、PHP について一定の理解があり、PHP キャッシュに関して一定のアイデアと経験を持っています。アクセス数は多いが更新頻度が低いサイト (ある種の CMS をベースにしたブログなど) がある場合、おそらくいくつかの修正が必要になります。これらの修正にはそれほど時間はかかりませんが、優れたパフォーマンスが得られます。 。 貢献する。 複雑で更新が速いサイトにキャッシュ メカニズムを確立したい場合、そのプロセスは複雑になる可能性がありますが、利点は明らかです。
PHP キャッシュ テクノロジは数多くありますが、Ben は次のテクノロジを推奨しました。
◆キャッシュ関数の実行結果◆有効期限を設定します
◆IEでダウンロードしたファイルをキャッシュする
◆テンプレートキャッシュ技術
◆Cache_Lite
動的言語としての PHP の特性により、頻繁に更新されないサイトにとってキャッシュ メカニズムは非常に重要です。
5. IDE、テンプレート、スニペットで PHP 開発を加速する – Chad Kieffer
Chad Kieffer は、UI デザインとデータベースの最適化から休憩を取るとき、ブログ 2 tablespoons で多くの技術的な経験を共有しています。チャドは多くの面で包括的な開発を行っているため、他のプログラマーが見つけられない問題を頻繁に見つけて、関連する経験、特に Web サイト開発方法を形成することができます。彼はウェブサイト開発のあらゆる側面に携わっているため、彼のアドバイスはウェブサイト開発の全体像を改善するのに非常に役立ちます。Chad は、Eclipse PDT (Eclipse の PHP 開発パッケージ) のような IDE を使用し、いくつかのテンプレート テクノロジとオープン ソース プロジェクトを使用することで、PHP の開発速度を効果的に向上できると考えています。
計画がコンパクトで、やるべきことリストや期限が長いため、開発者は非常にイライラします。ただし、Eclipse テンプレートなどの一部の機能を使用すると、コーディング時間とエラーの可能性を効果的に削減できます。
一般に、どんなプロジェクトでも自動化の度合いが高くなるほど、プロジェクトの完了にかかる時間は短くなります。頻繁に使用されるフレームワークやテンプレートの開発に時間をかけておけば、後でさらに時間を節約できます。同時に、Eclipse や PDT パッケージなどの IDE を使用すると、IDE が自動的に終了し、セミコロンを入力してローカルでデバッグできるため、効率が大幅に向上することがわかります。
6. PHP フィルター関数を上手に活用する – Joey Sochacki
おそらく Joey Sochacki は Matt Mullenweg ほど有名ではありませんが、経験豊富な開発者でもあり、ブログ Devolio を通じて多くの技術的経験を共有していますジョーイは、PHP コードを記述するときにフィルタリングが必要な場所がたくさんあることを発見しましたが、PHP の組み込みフィルタリング機能に注意を払うプログラマーは多くありません。
データのフィルタリングは頻繁に必要になることですが、機能豊富な PHP 組み込みフィルタリング関数の多くは知られていません。 filter_* などの PHP 組み込み関数を使用すると、データ型検証/URL/電子メールおよび IP アドレス検証/特殊文字処理などを含む、ほぼすべてのフィルタリング タスクを処理できます。
フィルタリングは複雑なものですが、joey の発見はあなたに多くのインスピレーションを与え、PHP の強力なフィルタリング機能を認識させることになると思います。
7. PHP フレームワークを使用する – Josh Sharp
Zend、CakePHP、Code Igniter、または他の PHP フレームワークを使用するべきかどうかについては多くの論争がありますが、Web 開発者の心の中には独自の測定基準があります。Josh Sharp 自身もパンとバターのサービスを提供する Web サイトを作成したため、PHP フレームワークを使用して Web サイトを開発した経験があります。彼は、プロジェクト開発に PHP フレームワークを使用すると、効果的に時間を節約し、エラーの可能性を減らすことができると信じています。なぜかというと、彼は PHP が本当に使いやすいと考えているからです。
PHP の使いやすさには時々欠陥があります。これは、構文が緩いため、多くの誤ったコードが作成されることが多いためです。ただし、PHP フレームワークを使用すると、エラーの可能性が大幅に減少します。
PHP フレームワークを使用すると、コード構造がより標準化され、時間を大幅に節約できます。
8. PHP フレームワークを使用しないでください – Rasmus Lerdorf
Josh の見解とは反対に、PHP の創始者である Rasmus Lerdorf は、PHP フレームワークを使用しない方がよいと考えています。なぜなら、フレームワークに基づいていない PHP の方がパフォーマンスが優れているからです。 Drupalcon 2008 での講演で、Rasmus 氏は「Hello World」の例を使用して、あるフレームワーク PHP と単純な PHP のパフォーマンスを比較しました。その結果、フレームワーク PHP のパフォーマンスが大幅に遅れていることがわかりました。
9. バッチ処理を使用する – Jack D. Herrington
Jack Herrington は PHP の世界に精通しているわけではなく、有名な IBM DeveloperWorks に 30 以上の記事を寄稿し、「PHP Hacks」という本も出版しているため、真の専門家です。Herrington は、バックグラウンドで実行できるプログラム スクリプトをバッチ処理と Cron を使用して置き換えることを推奨しています。Web ユーザーはオンラインでの処理を待ちたがらないため、バックグラウンドで処理する方が適しているものもあります。
確かに、場合によってはこれは少しやりすぎですが、Cron、MySQL、PHP オブジェクト指向メソッド、Pear::DB などの便利なツールを使用してバッチ処理ツールを作成するのは必ずしも簡単ではないことがわかります。 。
Jack は、cron、PHP、MySQL を使用してバックグラウンドで一部のタスクを処理する方が、マルチプロセスのビジネス ロジックよりもはるかにコスト効率が高いと考えています。
私は両方の方法を試しましたが、Cron は "Keep It Simple, Stupid" (KISS) の原則に非常に一致していると思います。バックグラウンド処理が簡単になります。マルチプロセスのビジネスロジックと比較して、メモリオーバーフローのリスクがありません。単純なバッチ スクリプトを作成し、cron で実行できます。このスクリプトは、処理する必要のあるタスクがあるかどうかを定期的にチェックし、処理後に自動的に終了するため、プロセスが停止しているかどうかを心配する必要はありません。無限ループにはまってしまいました。
10. タイムリーなエラー報告を有効にする – David Cummings
David Cummings は CMS ソフトウェア サービスの提供を専門とする会社を経営しており、PHP 開発において非常に豊富な経験を持っています。 David はかつて「最初に学んでいればよかった 2 つの PHP ヒント」を書きました。そのうちの 1 つは、時間内のエラー報告を有効にすることで、時間を大幅に節約できるというものでした。
私は人々に、最も重要なことは PHP エラー報告を最大限にすることであると伝えています
。