序文最近、データの欠落やデータの損失に関するフィードバックをユーザーから受け取ることがあります。表現型の観点から見ると、この種の問題はデータベース レベルでは最も緊急の問題です。客観的な条件は別として、この種の問題に対する唯一のリカバリ方法はバックアップ リカバリ + 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 サンプルコード
この記事では、サイコロゲームを実装するためのWeChatアプレットの具体的なコードを参考までに共有し...
——「MySQL in Simple Terms (第 2 版)」からのメモ数値型整数型バイト最小最...
uwsgi+nginx プロキシ Django をデプロイする場合、uwsgi を使用したアクセスは...
iPad でページをデバッグするにはどうすればいいですか? iOS 5 をご利用の場合、iPad の...
インターネットにはすでにこの種の記事が溢れていますが、私がこれをまだ書いている理由は単純です。それは...
1. 問題の原因友人の @水米田 から、POSITION に基づくマスタースレーブについて質問があり...
CSS3 アニメーションで実現したシンプルでクールな効果。最終的な効果は次のようになります。 ページ...
設定ファイルに直接 サーバー{ listen 80 default; # IPへの直接アクセスを禁止...
序文MySQL データベースを使用する場合、クライアントはデータベース サーバーにリクエストを送信す...
序文JavaScriptはWebフロントエンドで広く使われている言語の一つであり、Webアプリケーシ...
通常の説明%はどのクライアントでも接続できることを意味しますlocalhostはローカルコンピュータ...
このキー属性の機能は何ですか?まずは公式の説明を見てみましょう。 kekey 属性は主に、新しいノー...
1. はじめにDocker には、タスクを構成する複数の Docker コンテナをオーケストレーショ...
Vue での img の動的スプライシングを見てみましょう。src 画像アドレス、具体的な内容は次の...
このチュートリアルの動作環境: Windows 7 システム、vue 2.9.6 バージョン、DEL...