序文最近、データの欠落やデータの損失に関するフィードバックをユーザーから受け取ることがあります。表現型の観点から見ると、この種の問題はデータベース レベルでは最も緊急の問題です。客観的な条件は別として、この種の問題に対する唯一のリカバリ方法はバックアップ リカバリ + Binlog 再生であり、通常は時間がかかり、ビジネスに大きな影響を与えます。 しかし、安定性を重視したソフトウェアであるため、データ損失の可能性は実際には非常に低いため、これらのフィードバックの問題は本当に「データ損失」に関するものなのでしょうか? 問題の説明ある日の正午、ビジネス アカウントでデータベースにログインした後、ビジネス データベースが消えたというユーザーからのフィードバックを受け取りました。 原因分析この質問を受けたとき、雰囲気はまだ非常に緊張していました。一方では、調査のためにデータベースへのログインを許可するようユーザーに連絡し、他方では、最近どのような変更が行われたかを確認するためにユーザーとコミュニケーションを取っていました。 データベースにログインした後、ビジネス データベースが存在することがわかりました。ユーザーからのフィードバック「ビジネス データベースが消えた」と合わせて、当初はビジネス アカウントに権限がないと判断しました。show grants で確認したところ、ビジネス アカウントには USAGE 権限しかなく、次のような結果でした。 mysql> 権限を表示します。 +----------------------------------+ | テスト@% の助成金 | +----------------------------------+ | *.* の使用権限を 'test'@'%' に付与 | +----------------------------------+ セット内の 1 行 (0.00 秒) このアカウントには最低限の権限しか与えられていないため、「業務データを見ることができない」のは明らかで、再認証後、問題は解決しました。調査の結果、次のような同じ名前の別のアカウントで初期認証操作が行われたことが判明しました。 mysql> 権限を表示します。 +-------------------------------------------------------------+ | [email protected].% への許可 | +-------------------------------------------------------------+ | prd_name.* のすべての権限を 'test'@'10.120.117.%' に付与します | +-------------------------------------------------------------+ セット内の 1 行 (0.00 秒) マイSQL> 拡大する「データ損失」という現象に関して、データベース全体のレベルでデータが「失われている」が、データベース自体は正常である場合、問題は今回のケースと同じ、つまり権限エラーである可能性が高いです。この問題の原因として、一般的に次の 2 つの可能性があります。1. ログインしたアカウントが同じ名前の別のアカウントと一致している。2. 認証に問題があり、ビジネス アカウントに権限がない。もちろん、最悪のケースは間違いなくデータベース削除操作です。バイナリログを解析することによってのみ、この操作の実行時間を特定できます。 もう 1 つのカテゴリは、「部分的なデータ損失」です。テーブルが欠落している、テーブル内の一部のデータが欠落しているなどです。厳密に言えば、MySQL の権限制御はテーブルおよび列レベルで実行できますが、実際には一般的に使用されていないため、この種の問題は権限エラーによっても発生する可能性があります。ほとんどの場合、更新または削除時に where 条件がないなど、操作が間違っていることが原因です。この場合、履歴バックアップを使用し、binlog を使用して復元することしかできません。この操作は、Tencent Cloud では「ロールバック」機能としてカプセル化されています。 総括するこの種の問題に遭遇した場合は、少し時間を取って問題を観察してください。この非常に緊急かつ深刻な「データ損失」問題を解決するには、再認証に数秒しかかからない場合があります。 上記は、MySQL データ損失の詳細な原因と解決策です。MySQL データ損失の詳細については、123WORDPRESS.COM の他の関連記事に注意してください。 以下もご興味があるかもしれません:
|
<<: Spring Boot Docker パッケージング ツールの概要
>>: 写真をアップロードして顔を認識する Vue+axios サンプルコード
MySQL カスタム値は、値を保存するための一時的なコンテナです。サーバーへの接続がアクティブである...
1. 分散ストレージシステムの概要情報技術の継続的な発展により、利便性がもたらされる一方で、データ量...
1.backup.shスクリプトファイルを作成する #!/bin/sh ソースフォルダ=/データ ...
最近、本番環境のデータベースがログデータを狂ったように書き込み、主キー値のオーバーフローを引き起こし...
目次必要:アイデア:レッスン:テキストを共有する:要約する必要:インターフェイスからサブメニュー デ...
導入:従来の画像検証コードと比較して、スライダー検証コードには次の利点があります。サーバーは検証コー...
目次1. Vueフロントエンドを構成する1. クロスドメイン構成を開発する2. 本番環境のクロスドメ...
自分のウェブサイトを構築する予定なので、618 プロモーションを利用して Tencent Cloud...
utf8mb4 エンコーディングは utf8 エンコーディングのスーパーセットであり、utf8 と互...
この記事では、WeChatアプレットのカスタムタブバーコンポーネントの具体的なコードを参考までに紹介...
ナビゲーションバーのサブメニューを再帰的に生成すると、メニューは正常に生成できるが、マウスをホバーす...
目次1. Dockerをインストールする2. ソナーイメージをインストールする3. ソナーを使ってコ...
Tomcat テストで 404 問題が発生します。問題は次のとおりです。 HTTP ステータス 40...
しばらく前にシステムを再インストールしましたが、バックアップを取っていなかったので、コンピューター上...
フロントエンドプロジェクトのパッケージ化.env.productionを見つけて、自分のIPまたはド...