ホームページ データベース mysql チュートリアル SQL Server ディスク要求タイムアウト 833 エラーの原因と解決策_MsSql

SQL Server ディスク要求タイムアウト 833 エラーの原因と解決策_MsSql

Jun 28, 2017 pm 03:41 PM
server タイムアウト 間違い

この記事では、SQL Server ディスク要求タイムアウトの 833 エラーの原因と解決策を主に紹介します。必要な友達は参考にしてください。

最近、SQL Server サーバーの応答が非常に遅く、クライアント要求でエラーが発生しました。データベース内 ディスク要求が完了するまでに 15 秒以上かかったというエラー メッセージがエラー ログに表示されます。

この種の問題の場合、ストレージ システムやディスクの障害なのか、SQL Server 自体の問題なのか、それともアプリケーションが原因なのか?どうやって解決すればいいでしょうか?

この記事では、この問題を引き起こす特定の要因の簡単な分析を行いますが、潜在的な可能性をすべてカバーできるわけではないため、同様の問題が発生した場合は、具体的な分析を行う必要があります。

SQL Server のディスク リクエスト タイムアウト

英語版のエラー エラー メッセージ は次のとおりです:

SQL Server で %d 回の I/O リクエストが発生し、%d を超える時間がかかりましたデータベース ID %d のファイル [%ls] の完了まで秒です。OS ファイル ハンドルは 0x%p です。0
最新のロング I/O のオフセットは %#016I64x

中国語版のエラー メッセージは次のとおりです。以下の通り

SQL Server は、データベース ID %4! のファイル [%3!] に対して、完了までに %2! 秒以上かかる I/O 要求を検出しました。オペレーティング システムのファイル ハンドルは 0x%5! です。最新の長期 I/O のオフセットは %6!

メッセージ情報のエラーメッセージ No.833 を参照

具体的な 833 エラーアプリケーションディスクリクエストタイムアウト現象

具体的なエラー状況は次のとおりです:

SQL Server はデータベース n 内のファイル *** に対する m 個の I/O 要求を検出しましたが、完了するまでに 15 秒以上かかりました。オペレーティング システムのファイル ハンドルは *** です。最新の長期 I/O オフセットは次のとおりです: ***

つまり、データベース ファイルの自動拡張中にエラーが発生しました。

さらに興味深いのは、DBA がこのエラー メッセージをストレージ システムの障害または不安定性が原因である可能性があると考え、ストレージ (接続されたディスクではなく SAN ストレージ) を担当するエンジニアに報告したことです。

ストレージ エンジニアはストレージに問題はないと思ったが、サーバーを確認したところ、サーバーが異常でメモリが「ほぼ満杯」だったという。ストレージを担当するエンジニアが専門の DBA ではないことを考慮すると、SQL Server データベース サーバーのメモリ使用量についてあまり詳しくない可能性があるため、この質問をするのは当然のことです。

データベースサーバーが使用するストレージは高性能のSANストレージであるため、ストレージはサービスとして存在し、他のサーバーでディスクリクエストが発生する可能性は低いです。ストレージ障害」は、単にストレージ障害として識別されます。

それでは、その理由は何でしょうか?

データベースエンジンエラー833の意味

まず、この833エラーの具体的な意味を見てみましょう。これは古典的な本に非常に明確に書かれています。

要するに、SQL Server がディスクの読み取りと書き込みを要求したときに、ビジーなディスクまたはその他の要因が発生し、15 秒以上完了していないことを意味します
たとえば、データの読み取りと書き込みの場合、多忙またはその他の問題により、応答が遅すぎるか、応答が十分にタイムリーではありません。これは間違いなく SQL Server の外部サーバーの応答時間に重大な影響を及ぼします。

上記は単純な分析です。この問題は一般的ではなく、ストレージ システムに問題がある可能性は低いため、現在のサーバー自体の要因を突き止める可能性が非常に高くなります。

原因分析

専用の SQL Server サーバーであるため、他のアプリケーションからのリクエストはなく、おそらく sqlserver データベースへのリクエストに関連しています。

実際、この問題が発生する前に、サーバーは通常非常に安定しています (CPU が 60% を超えることはほとんどなく、メモリの PLE は 20 分以上安定しており、ディスク IO 遅延は低いなど)。 .)、しかし、時々、しばらくの間、けいれんが発生します

けいれんが発生すると、CPU が約 80% に急上昇し、メモリの PLE が大幅に低下し、IO 遅延が大幅に増加します。

SQL Server の Session からのみ開始できます。SQL Server でアクティブなセッションを観察すると、特定の種類の SQL ステートメントの query 時間が非常に長いことがわかりました。一定期間内の SQL クエリ 内部実行の頻度は比較的高いです。

しかし、通常の状況では、この種の SQL の実行効率はまだ比較的高いのに、なぜ突然非常に低くなるのでしょうか。

アクティブなセッションの対応する実行計画を確認したところ、このタイプのアクティブなセッションの待機ステータスは IO 待機 (PAGEIOLATCH_SH) であり、SQL の実行は完全に予期しないことがわかりました。

同様のクエリが比較的頻繁に実行されるため、SQLの実行効率が低下すると、そのようなSessionがサーバー上に大量に蓄積されることになります

なぜSQL文は正常に実行されるのでしょうか?突然非常に遅くなりました

その理由は、ある時点で SQL Server が統計情報の update を自動的にトリガーしたためです。これは比較的大きなテーブルですが、統計情報の更新のためのデフォルトのサンプリング率では十分ではありません、サンプリング率が十分でない場合、この統計情報は完全に利用できません。

統計情報の自動収集が完了すると、現在収集されている統計情報に基づいて、前の SQL ステートメントに対して効率的であると思われる方法 (インデックス シークではなくテーブル スキャン) を発行します。実際には、この方法は合理的ではありません。
これにより、対応する SQL がクエリを実装するために不当な実行プランを使用することになり、クライアントが大量のセッションを送信し、非効率な方法で実行が遅くなります。

そのため、CPU が急増し、IO レイテンシが増加し、メモリの PLE が大幅に低下します。

これを理解するのは難しくありません。何十ものクエリセッションが不当な方法でディスクにリクエストを行っており、ディスクはアクティブなセッションからのデータリクエストでビジー状態であり、データまたは index ファイルが原因で応答できません。自動拡張リクエストにより、冒頭で述べた問題が発生しました。

最終的には、インデックスの再構築により解決しました(統計情報の更新を促進する、もちろん純粋な統計情報の更新も可能です)。長期的な予防のためには、閾値とサンプリング率を人為的に定義するジョブを手配する必要があります。統計情報更新のお知らせです。

概要:

データベースサーバーの問題の多くは、観察された現象の一部に対応して連鎖反応プロセスであり、その反応は表面に現れているものとは異なる可能性が非常に高くなります (ディスク要求のタイムアウト、問題はストレージのせい?これらは問題の根本的な原因ではありません。
問題に直面したとき、私たちは根源に立ち返り、最も根本的な原因を見つけなければなりません。それが問題解決の鍵となります。

以上がSQL Server ディスク要求タイムアウト 833 エラーの原因と解決策_MsSqlの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホット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衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

操作を完了できません (エラー 0x0000771) プリンター エラー 操作を完了できません (エラー 0x0000771) プリンター エラー Mar 16, 2024 pm 03:50 PM

プリンターの使用中に、操作を完了できませんでした (エラー 0x00000771) などのエラー メッセージが表示された場合は、プリンターが切断されている可能性があります。この場合、以下の方法で問題を解決できます。この記事では、Windows 11/10 PC でこの問題を解決する方法について説明します。エラー メッセージ全体には、「操作を完了できませんでした (エラー 0x0000771)」が示されています。指定されたプリンターは削除されました。 Windows PC で 0x00000771 プリンター エラーを修正する プリンター エラーを修正するには、操作を完了できませんでした (エラー 0x0000771)。指定されたプリンターは Windows 11/10 PC で削除されています。次の解決策に従ってください: 印刷スプールを再起動します

Windows サンドボックスの起動に失敗しました - アクセスが拒否されました Windows サンドボックスの起動に失敗しました - アクセスが拒否されました Feb 19, 2024 pm 01:00 PM

Windows サンドボックスは、「Windows サンドボックスを開始できない、エラー 0x80070005、アクセスが拒否されました」というメッセージで終了しますか?一部のユーザーは、Windows サンドボックスを開けないと報告しました。このエラーが発生した場合も、このガイドに従って修正できます。 Windows サンドボックスの起動に失敗しました - アクセスが拒否されました Windows サンドボックスが「Windows サンドボックスを開始できません、エラー 0x80070005、アクセスが拒否されました」というメッセージで終了する場合は、管理者としてログインしていることを確認してください。このタイプのエラーは、通常、権限が不十分であることが原因で発生します。したがって、管理者としてログインして、問題が解決するかどうかを確認してください。問題が解決しない場合は、次の解決策を試すことができます。 管理者として Wi-Fi を実行します。

HTTPステータスコード460の原因を明らかにする HTTPステータスコード460の原因を明らかにする Feb 19, 2024 pm 08:30 PM

HTTP ステータス コード 460 の復号化: このエラーはなぜ発生しますか?はじめに: 日常のネットワーク使用では、HTTP ステータス コードを含むさまざまなエラー プロンプトに遭遇することがよくあります。これらのステータス コードは、リクエストの処理を示すために HTTP プロトコルによって定義されたメカニズムです。これらのステータス コードの中には、比較的まれなエラー コード 460 があります。この記事では、このエラー コードを詳しく説明し、このエラーが発生する理由を説明します。 HTTP ステータス コード 460 の定義: まず、HTTP ステータス コードの基本を理解する必要があります。

Windows Update プロンプト エラー 0x8024401c エラーの解決策 Windows Update プロンプト エラー 0x8024401c エラーの解決策 Jun 08, 2024 pm 12:18 PM

目次 解決策 1 解決策 21. Windows Update の一時ファイルを削除します。 2. 破損したシステム ファイルを修復します。 3. レジストリ エントリを表示および変更します。 4. ネットワーク カード IPv6 をオフにします。 5. WindowsUpdateTroubleshooter ツールを実行して修復します。 6. ファイアウォールをオフにします。およびその他の関連するウイルス対策ソフトウェア。 7. WidowsUpdate サービスを閉じます。解決策 3 解決策 4 Huawei コンピュータの Windows アップデート中に「0x8024401c」エラーが発生する 症状 問題 原因 解決策 まだ解決されませんか?最近、システムの脆弱性のため、Web サーバーを更新する必要があります。サーバーにログインすると、エラー コード 0x8024401c が表示されます。

新しい仮想マシンの作成中に、サーバーでエラー 0x80070003 が発生しました。 新しい仮想マシンの作成中に、サーバーでエラー 0x80070003 が発生しました。 Feb 19, 2024 pm 02:30 PM

Hyper-V を使用して仮想マシンを作成または起動するときにエラー コード 0x80070003 が発生した場合は、権限の問題、ファイルの破損、または構成エラーが原因である可能性があります。解決策には、ファイルのアクセス許可の確認、破損したファイルの修復、正しい構成の確認などが含まれます。この問題は、さまざまな可能性を 1 つずつ除外することで解決できます。エラー メッセージ全体は次のようになります。 [仮想マシン名] の作成中にサーバーでエラーが発生しました。新しい仮想マシンを作成できません。構成ストアにアクセスできません: システムは指定されたパスを見つけることができません。 (0x80070003)。このエラーの考えられる原因は次のとおりです。 仮想マシン ファイルが破損しています。これは、マルウェア、ウイルス、またはアドウェアの攻撃によって発生する可能性があります。このようなことが起こる可能性は低いですが、完全にそうなることはできません。

パイオニアエラーコードKadena-Keeslerを修正 パイオニアエラーコードKadena-Keeslerを修正 Feb 19, 2024 pm 02:20 PM

Call of Duty: Vanguard のプレイ中に Kadena-Keesler エラーが発生した場合は、この記事が役立つ可能性があります。一部のプレイヤーからのフィードバックによると、このゲームは Windows PC、Xbox、PlayStation、その他のプラットフォームでこの問題が発生しているとのことです。このエラーが発生すると、次のエラー メッセージが表示される場合があります。 接続に失敗しました。ネットワーク接続に失敗しました。オンラインまたはローカル ネットワーク経由でプレイするには、アクティブなインターネット接続が必要です。 [理由: Kadena-Keesler] 次のエラー メッセージが表示される場合もあります。 接続に失敗しました オンライン サービスにアクセスできません。 [理由: Kadena-Keesler] Xbox でのこのエラーの別の例は次のとおりです: アクティブなネットワーク接続が必要です

Oracle エラー 3114 の解釈: 原因と解決策 Oracle エラー 3114 の解釈: 原因と解決策 Mar 08, 2024 pm 03:42 PM

タイトル: Oracle エラー 3114 の分析: 原因と解決策 Oracle データベースを使用すると、さまざまなエラー コードが頻繁に発生しますが、その中で比較的一般的なのはエラー 3114 です。このエラーには通常、データベース リンクの問題が関係しており、データベースへのアクセス時に例外が発生する可能性があります。この記事では、Oracle エラー 3114 を解釈し、その原因について説明し、エラーを解決するための具体的な方法と関連するコード例を示します。 1. エラー 3114 の定義 Oracle エラー 3114 パス

Xiangxiangfuzhai アプリでエラーが表示されるのはなぜですか? Xiangxiangfuzhai アプリでエラーが表示されるのはなぜですか? Mar 19, 2024 am 08:04 AM

表示エラーは、Xiangxiang Fuzhai アプリで発生する可能性のある問題です。一部のユーザーは、Xiangxiang Fuzhai アプリでエラーが表示される理由がわからない場合があります。ネットワーク接続の問題、バックグラウンド プログラムの多さ、誤った登録情報などが原因である可能性があります。ユーザー向けにアプリ表示エラーの解決方法を編集部が紹介しますので、興味のある方はぜひご覧ください! Xiangxiang Fuzhai アプリでエラーの回答が表示されるのはなぜですか: ネットワーク接続の問題、バックグラウンド プログラムが多すぎる、間違った登録情報など。 詳細: 1. [ネットワークの問題] 解決策: デバイスの接続ネットワーク ステータスを確認し、再接続するか、別のネットワーク接続を選択してください。使用できます。 2. [バックグラウンド プログラムが多すぎる] 解決策: 実行中の他のプログラムを閉じてシステムを解放すると、ソフトウェアの実行速度が向上します。 3. 【登録情報に誤りがある場合】

See all articles