MYSQL の接続数と接続時間について
1. A.PHP のページにアクセスし、データベースに接続し、5 秒間 SLEEP し、その他の操作は行いません
2.永続的な接続
3 、接続タイムアウトは 10 秒に設定されています
接続がアクティブに閉じられていない場合、接続は 10 秒後に閉じる必要がありますか?ただし、5秒後に自動的にシャットダウンします。
なぜですか?
1. データベースに接続するのは、データベースを操作するときだけですか?
データベースへの接続は構成ファイルに記述されており、基本的にページはヘッダーで紹介されているデータベースを使用しますが、ページへのアクセスには必ずしもデータベース操作が必要というわけではありません。
つまり、誰かがファイルにアクセスしている限り、データベース接続が確立されます (データベース操作を実行する必要がない場合もあります)。これは悪い方法でしょうか?
MYSQL 接続の最大数は 5,000 です。5,000 人以上がアクセスした場合に問題は発生しますか?
2. もう 1 つの質問ですが、静的ページへのアクセスが非常に遅い理由は何ですか?サーバーへのリクエストの数に関係しますか? JS と画像はどうですか?
ありがとうございます
-----解決策-------------------------- ------
1. 接続タイムアウトは 10 秒に設定されています。つまり、データベースが 10 秒間接続されない場合、接続は試行されなくなります
2. 必要な場合にのみデータベースに接続します
3. 最大値MYSQL 接続の数は 5000 です。これは、5000 を超えるクライアントが同時に接続リクエストを発行するとエラーが発生することを意味します
しかし、Web サーバーによって許可される同時接続は制限されているため、これは発生しません。中規模の Web サイトには 10 個の証明書を含めることができます
4. 静的ページへのアクセスが非常に遅い理由: 1 つのディレクトリ内のファイルが多すぎる (>1000)
-----解決策---------
a.phpの実行が5秒後に終了したため、mysql 接続を含むすべてのリソースが解放されます
データベース接続は、5000 人以上のユーザーが同時にアクセスした場合にのみ問題を引き起こします。
------解決策----------------------
リンクは終了後に閉じられるはずです。 SQL 操作が完了しました。SQL 操作に 10 秒以上かかると、mysql リンクが自動的に閉じられます。