質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Q&A

3回答

2286閲覧

DB退避の方法

master0f

総合スコア10

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

0グッド

1クリップ

投稿2016/10/24 08:38

AWS RDSでmysql5.6を使用しています。
アクセスログを月ごとにバックアップしようとしております。

bash

1 2# $conditionに月の範囲指定をしています。 3mysqldump --defaults-extra-file=./my.conf $table --where "$condition" | gzip > $filename

ダンプを行い圧縮をして、そのファイルを別サーバにアップロードしてその後

bash

1# 先ほどの月範囲指定を引き継いでいます。 2mysql --defaults-extra-file=./my.conf $table <<EOS 3begin; 4use dbname; 5DELETE FROM $table WHERE $condition; 6commit; 7EOS

先ほどの条件の月を削除しています。

データ量とスペックにもよりますが、現在この工程で、ダンプに5分、アップロード30秒、deleteに5分で合計約10分程時間を要しており、その間max_connectionsに達してしまいDBへの書き込みが出来ない状況になっています。

このような場合、どのようにするのがベストなのでしょうか?
素人考えですが、ダンプ自体はスナップショットに退避したものから取得すれば良いと思ったのですが、deleteはそういう訳にいかず、スペックを上げるしかないのかなと思っているところです。

不勉強で恐れ入りますが、ご教授ください。
よろしくお願い致します。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

イマイチなにをしたいのか意図が読めませんが
運用しているDBからデータを削除したらバックアップとは言えませんし

とりあえずであれば、削除フラグのカラムを設けて、
先行して当該月のデータに削除フラグだけつけてしまい、あとから削除フラグの分を
本当に削除すれば少しは処理が分散できるかもしれません。

月ごとにデータを分散管理するだけならパーティショニングすれば
わざわざ外にデータを持ち出すこともないような気もしますが
運用方法しだいでしょうか・・・

投稿2016/10/24 09:27

yambejp

総合スコア114769

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

max_connectionsになる原因はなんでしょうか?
単にこの値がちょっと少ない程度であれば引き上げれば解決しそうな気もします。

投稿2016/10/24 08:51

moonphase

総合スコア6621

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

月毎に異なるテーブルにログを記録するというのはナシですか?

投稿2016/10/24 08:44

kunai

総合スコア5405

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

moonphase

2016/10/24 08:47

月次でバックアップしたものを削除しているなら、最大で一ヶ月分しか貯まっていないように思えますが、どうなんでしょうね。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問