MYSQLのバックアップとローカル利用
の編集
Top
/ MYSQLのバックアップとローカル利用
[
トップ
] [
編集
|
差分
|
バックアップ
|
添付
|
リロード
] [
新規
|
一覧
|
単語検索
|
最終更新
|
ヘルプ
]
-- 雛形とするページ --
10の質問
2024/09月時点でのおすすめAI
ABC予想
AI
AI API
AI プロンプト
AIでつかわれているtransformerのまとめ
AIとIDEの共存:ドキュメント整合性のための新しいアプローチ
AIとの効果的な協働のための設計アプローチ:S式とコード生成テンプレートの活用
AIと上手に付き合うコツ:「自分らしさ」を失わないために
AIと共存する時代のソフトウェア開発:コンパイラー開発からの学び
AIの男女と美醜について学習の問題点
AIの話題
AIチャットの文脈を記憶する!Apache UnomiとModel Context Protocolで実現する次世代のAIチャット管理
AI大規模開発とTDDの意外な関係
AI関連の自分がよく見るチャンネル
ANTLR
ANTLR v3 FAQ よくある質問
ANTLR 独学
ANTLR4 独学
ANTLRでOracleのDDLを解析してみる
ANTLRチュートリアル
AOP
API
ARMマイコン基盤
ATOM SHELL理論
Access VBAメモ
Access-Control-Allow-Origin
AndroidとTensorflow
Android開発
Android開発 入門
AngularJS
Anko
Apache Bench
ArchUnitを学ぶ
Axiosとは
Axis2
BI Publisherで始めるデータ駆動型レポート作成
BPMNの勉強
BackTrack4
Blog from iPhone
Bootstrapとは
BracketName
C3 AI Applications
C3 AI エクスマキナ
CSS備忘録
CentOS
ChatGPTの話題
Chevrotainのパーサメソッド
Chevrotain一覧
Chromeエクステンション
Claud MCP
Claude sonnet computer useを実践投入してみる
Clojureの実行のお作法
Clojureの3万個以上あるライブラリエコシステム
Clojureをつかってみる
Cocoa Touch Static Library
CoffeeScript
Confluent Control Centerやってみる
C言語でオブジェクト志向な記述方法
DDD ドメイン駆動設計
DDL生成ツール
DJUnit
DMM.comのAPIとか
DOSコマンドメモ
Dashcode
DeepFloyd IF
Dockerが動かない場合の対処
DockerでLillyMolを爆速起動!化学式から合成経路を探る旅に出よう!
ES2015
Eclipse Monkey
Eclipse Plugin
Eclipseの色設定
Eclipse使いがXCode使い初めて知りたいこと
ElasticMQメモ
Elixir
Emmet
Erlangメモ
ExcelファイルをAIに読ませる
Exceptionを見やすく
Expression Tree
FLEX
FLEX リフレクション
Firebase App Check
Firebase Emulator Suite
Fisheye
FlashやJavascriptを使った演出
FlutterとReactとOptiWeb
Flutterの開発環境をDockerで整える
FormattingRules
FrontPage
GAE
GAE Data Store API
GENERAL SQL PARSER JAVA を試してみる
GLOBAL
GPT4ALL
GQL
GUIからMacPortsを管理するアプリケーション - Porticus
Generative Adversarial Networks
Gin JavaScriptで構文解析
Git Blame
Git リポジトリのクローンができないときの解決法
GitHubアクションを使ったトロイの木馬のまとめ
GitLab
GitLabRunnerを増やす
GitLabでPlantUML使ってみる
GitLabでプロジェクト管理する
GitLabの機能をそのまま使って認証システム作ったらどこまでできる?
GitLabサーバインストールとメンテ注意事項
GitとAntとSpringとJUnit
Google ClientID
Google Cloud Platform
Google Cloud Platform (GCP) と gcloud CLI 入門
Google Maps Platformを学ぶ
GoogleMapレンダリング
Googleの裏技
Google認定プロジェクトマネージャの勉強メモ
Gradioで簡単GUI作成
Grails
GraphHopperを使用した住所のジオコーディング例
GraphQL
HTM 階層型時間メモリ
HTML スクレイピング
HTML パース
HTML5
HTML5 Canvas
Hadoop
Help
If Then Maybe プログラミング
Inkscape script
InterWiki
InterWikiName
InterWikiSandBox
JAVAの記事一覧
JBoss
JDBC テーブル一覧を得る
JDBC カラム一覧を得る
JDT eclipse
JGRIB
JHIPSTER JDL
JHIPSTER OpenAPI
JHIPSTER エンティティをフィルタリングする
JHIPSTER6.1.2
JHIPSTERでスマホサイト
JHIPSTERのBLUEPRINTを作る
JHIPSTER一覧
JHipster
JHipster API FirstDepelop
JHipster エンティティを更新する
JHipster7をつかってみる
JHipsterでBuleprintを使いこなす
JHipsterのコード生成を改造
JHipsterのプロジェクトをGitLabでCI/CDする
JHipsterのプロジェクトをデプロイする
JIRAをAPI使って操作する
JMeter
JOOQとは
JSFとStruts
JSqlParser
Java Closure
Java Compiler API
Java Function
Java SQL Parserを調査する
Java Spring AOP
Java Spriteを設計してみる
Java オブジェクトのダンプ
Java ドラックできる曲線
Java 備忘録
Java 文字化け
Java11以降のJRE
Java7サンプルコード
JavaFx
JavaScriptでパーサを作る Chevrotain
Javaasist 動的にクラスを編集
Javascript グラフィックライブラリ
Javascript コーディングパターン
Javascript界隈
Javassist
JavaでSVG
Javaで関数型で引数をとる
JavaのジェネリクスTip
Javaのラムダ式
Javaの有名なライブラリ紹介
Javaは、IDEのテンプレートを使いこなせばいいよ
Javaプログラマ向けモナド
Javaメモリリーク
Jenkins
Jenkins(Hudson)メモ
Jestとは
Jhipsterマイグレーション
Json Yaml Xml Hash Scala
Kafka REST Proxy さわってみる
Kotolin
LDAPサーバをdockerで立ち上げる
LISPで自分の言語を作る
LibreOfficeのCalcをハックしてみる
Linux メモ
LiquiBaseとは
Lispの学び
Lombok
MCP「ここまでのチャットを整理して保存しておいて」
MDBをコンパクトにするVBA
MQL5 半値インジケータ作った
MQL5 小作品
MT4
MT5 EA
MT5お気に入りのインジケータ
MYSQL
MYSQLのバックアップとローカル利用
MacTool
Macにしゃべらせる
Mac用のメモ
Mattermostを使ってオンプレミスでチャット環境を作る
Maven
Mementoパターン
MenuBar
MoonsharpとLuaとUnityについて学ぶ
NILScript
NetBeanでプロファイル
Network Service Desk Engineer
Node-RED
Node-Red
Notion MCP関連について学ぶ
NumPy
OQL オブジェクト問い合わせ言語
OSコマンドインジェクション
ObjctiveC サウンド
ObjectMapperの備忘録
ObjectiveC NSString
ObjectiveC サーバ
ObjectiveC ターミナル用コマンドを作る
ObjectiveC バックグラウンド
ObjectiveC ワーニング
Oculusアプリの開発
OpenAI Swarm Examples Basic
OpenAI Swarmについて学ぶ
OpenAI Swarmについて認識を深める
OpenFeint
OpenOffice
OpenResty
OpenStreetMapを利用した車両ルーティング問題(VRP)のOptaPlanner解決例
OptaPlanner
OptaPlannerとは
OptaWeb
Outlook VBA
PHP
POSTGRESQL
Pandas Python Data Analysis Library
PdfBox Java用PDFライブラリ
Plagger
Playwrightの実用ガイド:MCPとの統合による新たな可能性
PrismaでGraphQL APIを自動生成しよう - チュートリアル
PrismaとGraphQLで作るシンプルなAPI - クイックスタート
PukiWiki
PukiWiki/1.4
PukiWiki/1.4/Manual
PukiWiki/1.4/Manual/Plugin
PukiWiki/1.4/Manual/Plugin/A-D
PukiWiki/1.4/Manual/Plugin/E-G
PukiWiki/1.4/Manual/Plugin/H-K
PukiWiki/1.4/Manual/Plugin/L-N
PukiWiki/1.4/Manual/Plugin/O-R
PukiWiki/1.4/Manual/Plugin/S-U
PukiWiki/1.4/Manual/Plugin/V-Z
PyHipster
QuartzCore
RAD
REST
RWKV
Rails3
Railsと差分開発についての考察
React.js
React.js モーダル画面
RecentDeleted
RedmineLE
Redshift
Relumeでサイトの骨格を作る
Require.js
Roo Codeを使う
Rubycocoa
RubyでScalaをコンパイルするツールをつくる
Rubyアソシエーション認定証
Ruby入門
SCALA REPL
SCALA support tool
SCALAの記事一覧
SDL3で始めるクロスプラットフォームゲーム開発 - 環境構築ガイド
SELinux
SEO
SEO Yahoo対策
SEO対策一覧
SPAM対策
SQLite
SSH
SVNをJavaで操作
SakuraZencoding
SandBox
Scala / Hadoop
Scala Process exec
Scala 遅延評価
Scala/LiftでSlim3
ScalaSigParser
ScalaWithExcel
Scala チュートリアル
Scalaで3D
ScalaでLisp
ScalaとGroovyのPOJO比較
ScalaのIDEについて
Scala言語を学ぶやさしいツール「Kojo」
Slack API やってみる
SocketAppender
Spring
Spring bootでのテストのTIPS
SpringBootとSeleniumとJunitの連携
SpringBootのSTSの新規プロジェクトでるエラーの対応
SpringSecurity SAML
Sqlite
Squirrel
StringTemplate
Stringクラス拡張
TALEND
ThreadLocal
Todo一覧
Trac Lightning
Twitter
UltraEdit
UnityでClojureCLRをREPLで使う
UnityでClojureCLRを使いたい
Unityでシューティングゲーム作る際のメモ
VBAでREST通信
VBAのコード
VBAをOpenOffice.org Basicにする
VBAをOpenOffice.org+Basicにする
VPN構築の勉強メモ
VPSやIaaSメモ
VSCodeでRuby開発
VSCodeメモ
VSCode用ChatGptのPlugin
VSCode設定
VirtualBox On Mac
Visual Studio Code プラグイン開発
Vuexとは
WBS管理の弊害
WIN32API
WSDL
Watson
WebDesign探訪
WebLogic フィルタ
WikiEngines
WikiName
WikiWikiWeb
Windows10のPowerShell でキーボードの言語切り替え
WindowsTool
Windows環境でJavaバージョンを制御する方法 - Java Shimと環境変数の活用
Windsurf
Worker Thread パターン
XBee
XDOCLET
XForms
XPath
XSL
YahooPIPES
Yahooインフォセンター
Yet Another Pragger
YouTuber
Youtubuのあれ
YukiWiki
anacondaをcygwinで使う
ansible
antlr snippet
antlr 再入門
antlrと日本語
autoit
automator
bluemix
bootstrap2
bower
ccze Colorize log files on CentOS and Ubuntu using ccze tool
centos7
cglibを使って動的コード生成
cocos2d
collection/collection.dart
cygwin
diff
dockerのローカルイメージをDocker-in-Dockerで参照する
eclipse設定
emacs 備忘録
emacs 文字列置換
emacsをviライクにする
excel tips
excelのdiff
expectで自動化
figmaにプラグインをインストールする
firebase デプロイ
flutterで、google認証させてFirebaseAuthするメモ
flutterをngrok経由で動作させる
flutter環境設定
ftp自動化
gemini
generator-jhipster-gql
git diffを使った構成管理の省力化
goをやってみる
go言語でファイルサーバ
grizzly
gulp
homebrew
iPhone Bluetoothプログラミング
iPhone iAd
iPhone 実機テスト手続き
iPhoneでグラフィックのHellowWorld
iPhoneとGmailメール
iPhoneに実機転送
iPhoneプログラミング
iPhoneプログラミング/ビューを理解すればiPhoneアプリの基礎を押さえられる
iPhoneプログラミング一覧
iPhoneプログラミング入門
iPhone開発/Interface Builder Plug-in
iPhone開発/キャプチャの取り方
intra-mart
jQuery.Flickableのメモ
java spring boot 認証 memo
jersey
jhipster-codeにアノテーション追加してみる
jhipsterのテンプレート改造準備
jparsecドキュメント日本語訳
jparsec入門
kafkaの勉強
log4j2の脆弱性
mac diff
mailcowのインストール
marmaid
memcached
metabaseはダッシュボードなのか
minecraft マイクラ あるきながら、高速ダンジョン作成
mqttの勉強
nginx_lua
nginxのメモ
node_moduleをnpm linkを使って自分用にする
npm
openapi generator
openapi-generatorをコンパイル
openstack
oraclerac
play framework 1.2.5 sample
play! framework
play!framework selenium
playframework テンプレート
postmanとopenapi
postman使ってみる
prezi プレゼン
pukiwikiで行動管理
pukiwikiに類似したツール
pukiwiki勉強
pukiwiki記事一覧
python
python3のwindowsでの日本語文字化け対応
pythonでseleniumを使う
pythonのテストに使うライブラリ
rails5
rate.jsを使ってみる
reactでポップアップ表示
redmine
ruby on rails 6.0.0
scala
scala 99problem 32~
scala prototype.zip
scala repl
scala sbaz
scala spring
scala/インストール
scalaでまだ不勉強なところ
scalaのインストール
selenium
slack api
spark
spring boot
spring initializerをつかってプロジェクトのひな型をゲットする
spring-test
springboot
springboot env
storybook
sublimetext2
swagger
tracについて
ubuntu
vaadin
vue を typescriptで開発
vue 共通部品作成
vue.js memo
vue.jsとは
vue.jsのデバッグ
vue一覧
webの編集画面のよくあるパターン
windows環境構築
wordpress
xamppについて
•Axis2の本家のスタートガイドによるWebサービスの作り方
「AI促進法」国会審議をDXする提案メモ
「Computer use」Claude 3.5 SonnetでPCを操作
【Javascript】【CLIライブラリ】commanderの勉強
【MQL5】KuniRangeBreakoutEA
いまさらながらC++
おすすめされたフリーソフト
びっくりする短いコード
もう合成ルート探索で迷わない! ASKCOSでスマートに逆合成解析!
アクター
アニメーション
アノテーション
アプリコット
アプリコット PukiWiki
アプリコード
アプリコード林邦行
イラストのエフェクト
インテンショナルプログラミング
カスタマイズjhipster7.9.3イメージ
カブロボ
ガイガーカウンター
クラスとハッシュマップの関係
クラック対策
クロス集計
コマンドラインという概念への考察
コマンドラインの出力に色を付ける
コミニュケーション
コラッツ予想:シンプルな数学の問題が隠す深遠な謎
コード生成
サロゲートキーを使ったテーブル設計
シェルのサンプル
シェルサンプル
スクレイピング
スレッドプログラミングメモ
ソースtoソース変形
ターミナルをAppleScriptで制御
テキストエディタ作成javascriptフレームワーク
テスト用まっさらDBをdockerでたてる
テスト駆動
テレワーク環境の比較
ドット絵
ナイアシンと脂質代謝に関する新仮説
バイオビルダー合成生物学メモ
バグの少ない設計のためのValueObject
パフォーマンスチューニング
フロントエンドとバックエンド(API)を1つのリポジトリで管理するメリット
フロントエンドのテストの結合テストを減らすには?
プッシュ技術
プログラマーじゃない人に覚えてほしいプログラムのコメントの書き方
プロジェクト管理スプレッドシート
プロンプトエンジニア以外のこれからのAI技術者
マイクラ 有名ディメンション モッド
マクスウェル方程式
メタ
ラムダ計算について考える
リベリカJava13いいみたい
リモートワークでのプロジェクト注意点
レイアウトツール
ログ解析
世界の構文解析グラマーたち
予定表
予定表/2009-12-14
予定表/2009-12-18
予定表/2009-12-19
予定表/2009-12-22
予定表/2009-12-23
予定表/2009-12-24
事業の心構え
事業計画方針
五蘊と経営を磨く徳目表
人工知能とCUDA
人工知能コンペKaggle
仕様書のフォーマットについての考察
他言語サイトサンプル作成
仮説Oracleの罠
作曲と効果音作り
共和分
効率的なAI活用戦略:S式ベースの問題解決ライブラリの構築
口コミ
古いRails5を入れる
哲学
大文字小文字変換
学習をHackする
扶養とシステム
投薬のみのガンの治療薬
擬似コーディングのすすめ
放射能対策
数式を扱う
文章を書く
新エネルギー
新年の抱負2010
新技術 プログラム編
日本のゼネコン式IT開発が失敗する理由
最近更新したページ
未来技術/新技術
枯れた技術の水平思考
株価データ
業界の動向
構文解析の記事一覧
正規表現
気象データ
流れるようなインタフェース
究極の集中状態を実現する:プログラマーのためのディープワーク実践ガイド
管理画面の生成におけるopenapiとJDLなどの考察
細胞の若返り
経済のことをまとめてみる
脆弱性
脳腫瘍の開発中治療薬LY367385とリンゴ酢
自分でPlaggerみたいなのを作るためのメモ
話せるAIの記事のリンク
論語/学而第一
負荷テスト
販売/デスクトップPC
販売/ノートパソコン
販売/外部ストレージ
起業
酸化グラフェン
開発哲学
電子出版
電子出版の記事一覧
非可換幾何学
顧客分析のデシル分析とRFM分析
DIコンテナについて考える
MP3から携帯着うたを作る方法
#contents * 想定する利用環境というか状況 [#i0c39bbe] 開発用のDBを個人に用意されていないプロジェクトで、ローカル開発ができるようにしたい状況 BashシェルとDockerを使って以下を行う MYSQLのバックアップ Dockerを使ってバックアップしたファイルをローカルで動作させる ** ファイル構成 [#gdedff2b] . ├── .env # 環境変数設定 ├── docker-compose.yml # Docker環境設定 ├── functions.sh # 共通関数定義 ├── export.sh # エクスポート実行スクリプト └── import.sh # インポート実行スクリプト └── docker ├── Dockerfile.txt └── my.cnf *** .env [#fd78edfa] 環境変数の設定 *** MySQL Configuration [#me0ff17c] 以下を.bash_profileなどに保管する # .env # MySQLの設定 MYSQL_HOST=localhost MYSQL_PORT=3306 MYSQL_USER=your_username MYSQL_PASSWORD=your_password MYSQL_DATABASE=your_database MYSQL_ROOT_PASSWORD=your_root_password # エクスポート設定 EXPORT_DIR=./mysql_backup # Docker設定 DOCKER_CONTAINER_NAME=mysql_container DOCKER_MYSQL_PORT=3307 ** docker/Dockerfile.txt [#ie5f8de0] 日本語が使えるように設定しておく # 必要なパッケージのインスト # syntax=docker/dockerfile:1 FROM mysql:8.4 # 必要なパッケージのインストール RUN microdnf update -y \ && microdnf install -y glibc-locale-source glibc-langpack-ja \ && rm -rf /var/cache/dnf \ && localedef -f UTF-8 -i ja_JP ja_JP.UTF-8 ** docker-compose.yml [#a97cf4d5] version: '3.8' services: mysql: build: context: ./docker dockerfile: Dockerfile.txt container_name: ${DOCKER_CONTAINER_NAME} restart: always environment: MYSQL_DATABASE: ${MYSQL_DATABASE} MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD} MYSQL_USER: ${MYSQL_USER} MYSQL_PASSWORD: ${MYSQL_PASSWORD} LANG: ja_JP.UTF-8 LANGUAGE: ja_JP:ja LC_ALL: ja_JP.UTF-8 ports: - '${DOCKER_MYSQL_PORT}:3306' volumes: - mysql-data:/var/lib/mysql - mysql-logs:/var/log/mysql - ./docker/my.cnf:/etc/mysql/conf.d/my.cnf volumes: mysql-data: mysql-logs: ** my.cnf [#b879560b] [mysqld] # 文字コードの設定 character-set-server=utf8mb4 collation-server=utf8mb4_unicode_ci # 日本語対応 init_connect='SET NAMES utf8mb4' skip-character-set-client-handshake # SQLモード設定 sql_mode=STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION # InnoDBの設定 innodb_buffer_pool_size=256M innodb_log_file_size=64M innodb_flush_log_at_trx_commit=2 innodb_flush_method=O_DIRECT # パフォーマンス設定 innodb_file_per_table=1 innodb_buffer_pool_instances=2 # ログ設定 log_error=/var/log/mysql/mysql-error.log slow_query_log=1 slow_query_log_file=/var/log/mysql/mysql-slow.log long_query_time=2 # クエリログ(開発環境のみ有効にすることを推奨) # general_log=1 # general_log_file=/var/log/mysql/mysql-general.log # 最大接続数設定 max_connections=100 max_connect_errors=10000 # タイムアウト設定 wait_timeout=60 interactive_timeout=60 # その他の設定 max_allowed_packet=64M explicit_defaults_for_timestamp=1 # バイナリログ設定(必要な場合のみ有効化) # log-bin=/var/log/mysql/mysql-bin.log # binlog_expire_logs_seconds=604800 # max_binlog_size=100M ** functions.sh [#c32e1339] #!/bin/bash # functions.sh # MySQLデータベースの移行に関する共通関数 # 環境変数の読み込みと検証 load_env() { if [ ! -f .env ]; then echo "Error: .env file not found" exit 1 fi source .env # 必須環境変数の検証 local required_vars=( "MYSQL_HOST" "MYSQL_PORT" "MYSQL_USER" "MYSQL_PASSWORD" "MYSQL_DATABASE" "MYSQL_ROOT_PASSWORD" "EXPORT_DIR" "DOCKER_CONTAINER_NAME" "DOCKER_MYSQL_PORT" ) for var in "${required_vars[@]}"; do if [ -z "${!var}" ]; then echo "Error: Required environment variable $var is not set" exit 1 fi done } # 初期化 init() { load_env mkdir -p "${EXPORT_DIR}" mkdir -p "logs" } # Dockerコマンドのエイリアス関数 docker_mysql_exec() { docker exec -i "${DOCKER_CONTAINER_NAME}" mysql \ -u"${MYSQL_USER}" \ -p"${MYSQL_PASSWORD}" \ "$@" } # エクスポートファイル名の生成 generate_export_filenames() { local timestamp=$(date +%Y%m%d_%H%M%S) local schema_file="${EXPORT_DIR}/${MYSQL_DATABASE}_schema_${timestamp}.sql" local data_file="${EXPORT_DIR}/${MYSQL_DATABASE}_data_${timestamp}.sql" echo "${schema_file}|${data_file}" } # 最新のエクスポートファイルを取得 get_latest_export_files() { if [ ! -d "${EXPORT_DIR}" ]; then echo "Error: Export directory not found" return 1 } local latest_schema=$(ls -t "${EXPORT_DIR}"/*_schema_*.sql 2>/dev/null | head -n1) local latest_data=$(ls -t "${EXPORT_DIR}"/*_data_*.sql 2>/dev/null | head -n1) if [ -z "${latest_schema}" ] || [ -z "${latest_data}" ]; then echo "Error: Export files not found" return 1 fi echo "${latest_schema}|${latest_data}" } # ログ出力関数 log_message() { local level=$1 local message=$2 local timestamp=$(date '+%Y-%m-%d %H:%M:%S') echo "[${timestamp}] [${level}] ${message}" echo "[${timestamp}] [${level}] ${message}" >> "logs/migration_$(date +%Y%m%d).log" } # MySQLデータのエクスポート export_mysql_data() { local schema_file=$1 local data_file=$2 if [ -z "${schema_file}" ] || [ -z "${data_file}" ]; then log_message "ERROR" "Export filenames not provided" return 1 } log_message "INFO" "Starting database export..." log_message "INFO" "Exporting schema to: ${schema_file}" # スキーマ(DDL)のエクスポート mysqldump --host="${MYSQL_HOST}" \ --port="${MYSQL_PORT}" \ --user="${MYSQL_USER}" \ --password="${MYSQL_PASSWORD}" \ --no-data \ --set-gtid-purged=OFF \ --skip-add-locks \ --skip-comments \ --routines \ --triggers \ "${MYSQL_DATABASE}" > "${schema_file}" 2>> "logs/migration_$(date +%Y%m%d).log" if [ $? -ne 0 ]; then log_message "ERROR" "Failed to export schema" return 1 fi log_message "INFO" "Exporting data to: ${data_file}" # データ(DML)のエクスポート mysqldump --host="${MYSQL_HOST}" \ --port="${MYSQL_PORT}" \ --user="${MYSQL_USER}" \ --password="${MYSQL_PASSWORD}" \ --no-create-info \ --set-gtid-purged=OFF \ --skip-add-locks \ --skip-comments \ --complete-insert \ --extended-insert=FALSE \ "${MYSQL_DATABASE}" > "${data_file}" 2>> "logs/migration_$(date +%Y%m%d).log" if [ $? -ne 0 ]; then log_message "ERROR" "Failed to export data" return 1 fi log_message "INFO" "Export completed successfully" return 0 } # DockerコンテナへのMySQLデータのインポート import_mysql_to_docker() { local schema_file=$1 local data_file=$2 if [ -z "${schema_file}" ] || [ -z "${data_file}" ]; then local latest_files=$(get_latest_export_files) if [ $? -ne 0 ]; then log_message "ERROR" "No export files found" return 1 fi schema_file=$(echo "${latest_files}" | cut -d'|' -f1) data_file=$(echo "${latest_files}" | cut -d'|' -f2) log_message "INFO" "Using latest export files:" log_message "INFO" "Schema: ${schema_file}" log_message "INFO" "Data: ${data_file}" fi # Dockerコンテナが実行中か確認 if ! docker ps | grep -q "${DOCKER_CONTAINER_NAME}"; then log_message "INFO" "Starting Docker containers..." docker-compose up -d log_message "INFO" "Waiting for MySQL to start..." local max_attempts=30 local attempt=1 while [ $attempt -le $max_attempts ]; do if docker_mysql_exec -e "SELECT 1" &>/dev/null; then break fi log_message "INFO" "Attempt $attempt of $max_attempts: MySQL not ready yet..." sleep 2 ((attempt++)) done if [ $attempt -gt $max_attempts ]; then log_message "ERROR" "MySQL failed to start within the expected time" return 1 fi fi # データベースが存在しない場合は作成 log_message "INFO" "Creating database if not exists" docker_mysql_exec -e "CREATE DATABASE IF NOT EXISTS ${MYSQL_DATABASE};" if [ $? -ne 0 ]; then log_message "ERROR" "Failed to create database" return 1 fi # スキーマ(DDL)のインポート log_message "INFO" "Importing schema from ${schema_file}" docker_mysql_exec "${MYSQL_DATABASE}" < "${schema_file}" if [ $? -ne 0 ]; then log_message "ERROR" "Failed to import schema" return 1 fi # データ(DML)のインポート log_message "INFO" "Importing data from ${data_file}" docker_mysql_exec "${MYSQL_DATABASE}" < "${data_file}" if [ $? -ne 0 ]; then log_message "ERROR" "Failed to import data" return 1 fi log_message "INFO" "Import completed successfully" return 0 } # データベースの状態確認 check_database_status() { log_message "INFO" "Checking database status..." # テーブル一覧の取得 log_message "INFO" "Getting table list..." docker_mysql_exec "${MYSQL_DATABASE}" -e "SHOW TABLES;" # テーブル数の取得 log_message "INFO" "Getting table count..." docker_mysql_exec "${MYSQL_DATABASE}" -e " SELECT COUNT(*) as total_tables FROM information_schema.tables WHERE table_schema='${MYSQL_DATABASE}';" # データベースのサイズ情報 log_message "INFO" "Getting database size information..." docker_mysql_exec "${MYSQL_DATABASE}" -e " SELECT table_schema as database_name, ROUND(SUM(data_length + index_length) / 1024 / 1024, 2) as size_mb FROM information_schema.tables WHERE table_schema='${MYSQL_DATABASE}' GROUP BY table_schema;" } # 初期化の実行 init ** export.sh [#g0238a46] #!/bin/bash # export.sh # MySQLデータベースのエクスポートスクリプト # スクリプトのディレクトリを取得 SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)" # 共通関数の読み込み source "${SCRIPT_DIR}/functions.sh" # ヘルプメッセージ show_help() { echo "Usage: $0 [options]" echo echo "Options:" echo " -h, --help Show this help message" echo " -v, --verbose Enable verbose output" echo echo "Environment variables (from .env file):" echo " MYSQL_HOST MySQL host" echo " MYSQL_PORT MySQL port" echo " MYSQL_DATABASE Database name" echo " EXPORT_DIR Export directory" echo echo "Example:" echo " $0 --verbose" } # コマンドライン引数の解析 VERBOSE=0 while [[ $# -gt 0 ]]; do case $1 in -h|--help) show_help exit 0 ;; -v|--verbose) VERBOSE=1 shift ;; *) echo "Unknown option: $1" show_help exit 1 ;; esac done # エクスポート処理の開始 log_message "INFO" "Starting database export process" if [ $VERBOSE -eq 1 ]; then log_message "INFO" "Using configuration:" log_message "INFO" " Host: ${MYSQL_HOST}" log_message "INFO" " Port: ${MYSQL_PORT}" log_message "INFO" " Database: ${MYSQL_DATABASE}" log_message "INFO" " Export Directory: ${EXPORT_DIR}" fi # エクスポートファイル名の生成 files=$(generate_export_filenames) schema_file=$(echo "${files}" | cut -d'|' -f1) data_file=$(echo "${files}" | cut -d'|' -f2) # エクスポートの実行 if export_mysql_data "${schema_file}" "${data_file}"; then log_message "INFO" "Export completed successfully" log_message "INFO" "Schema file: ${schema_file}" log_message "INFO" "Data file: ${data_file}" exit 0 else log_message "ERROR" "Export failed" exit 1 fi
spamではない場合はチェックをいれてください。
タイムスタンプを変更しない
#contents * 想定する利用環境というか状況 [#i0c39bbe] 開発用のDBを個人に用意されていないプロジェクトで、ローカル開発ができるようにしたい状況 BashシェルとDockerを使って以下を行う MYSQLのバックアップ Dockerを使ってバックアップしたファイルをローカルで動作させる ** ファイル構成 [#gdedff2b] . ├── .env # 環境変数設定 ├── docker-compose.yml # Docker環境設定 ├── functions.sh # 共通関数定義 ├── export.sh # エクスポート実行スクリプト └── import.sh # インポート実行スクリプト └── docker ├── Dockerfile.txt └── my.cnf *** .env [#fd78edfa] 環境変数の設定 *** MySQL Configuration [#me0ff17c] 以下を.bash_profileなどに保管する # .env # MySQLの設定 MYSQL_HOST=localhost MYSQL_PORT=3306 MYSQL_USER=your_username MYSQL_PASSWORD=your_password MYSQL_DATABASE=your_database MYSQL_ROOT_PASSWORD=your_root_password # エクスポート設定 EXPORT_DIR=./mysql_backup # Docker設定 DOCKER_CONTAINER_NAME=mysql_container DOCKER_MYSQL_PORT=3307 ** docker/Dockerfile.txt [#ie5f8de0] 日本語が使えるように設定しておく # 必要なパッケージのインスト # syntax=docker/dockerfile:1 FROM mysql:8.4 # 必要なパッケージのインストール RUN microdnf update -y \ && microdnf install -y glibc-locale-source glibc-langpack-ja \ && rm -rf /var/cache/dnf \ && localedef -f UTF-8 -i ja_JP ja_JP.UTF-8 ** docker-compose.yml [#a97cf4d5] version: '3.8' services: mysql: build: context: ./docker dockerfile: Dockerfile.txt container_name: ${DOCKER_CONTAINER_NAME} restart: always environment: MYSQL_DATABASE: ${MYSQL_DATABASE} MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD} MYSQL_USER: ${MYSQL_USER} MYSQL_PASSWORD: ${MYSQL_PASSWORD} LANG: ja_JP.UTF-8 LANGUAGE: ja_JP:ja LC_ALL: ja_JP.UTF-8 ports: - '${DOCKER_MYSQL_PORT}:3306' volumes: - mysql-data:/var/lib/mysql - mysql-logs:/var/log/mysql - ./docker/my.cnf:/etc/mysql/conf.d/my.cnf volumes: mysql-data: mysql-logs: ** my.cnf [#b879560b] [mysqld] # 文字コードの設定 character-set-server=utf8mb4 collation-server=utf8mb4_unicode_ci # 日本語対応 init_connect='SET NAMES utf8mb4' skip-character-set-client-handshake # SQLモード設定 sql_mode=STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION # InnoDBの設定 innodb_buffer_pool_size=256M innodb_log_file_size=64M innodb_flush_log_at_trx_commit=2 innodb_flush_method=O_DIRECT # パフォーマンス設定 innodb_file_per_table=1 innodb_buffer_pool_instances=2 # ログ設定 log_error=/var/log/mysql/mysql-error.log slow_query_log=1 slow_query_log_file=/var/log/mysql/mysql-slow.log long_query_time=2 # クエリログ(開発環境のみ有効にすることを推奨) # general_log=1 # general_log_file=/var/log/mysql/mysql-general.log # 最大接続数設定 max_connections=100 max_connect_errors=10000 # タイムアウト設定 wait_timeout=60 interactive_timeout=60 # その他の設定 max_allowed_packet=64M explicit_defaults_for_timestamp=1 # バイナリログ設定(必要な場合のみ有効化) # log-bin=/var/log/mysql/mysql-bin.log # binlog_expire_logs_seconds=604800 # max_binlog_size=100M ** functions.sh [#c32e1339] #!/bin/bash # functions.sh # MySQLデータベースの移行に関する共通関数 # 環境変数の読み込みと検証 load_env() { if [ ! -f .env ]; then echo "Error: .env file not found" exit 1 fi source .env # 必須環境変数の検証 local required_vars=( "MYSQL_HOST" "MYSQL_PORT" "MYSQL_USER" "MYSQL_PASSWORD" "MYSQL_DATABASE" "MYSQL_ROOT_PASSWORD" "EXPORT_DIR" "DOCKER_CONTAINER_NAME" "DOCKER_MYSQL_PORT" ) for var in "${required_vars[@]}"; do if [ -z "${!var}" ]; then echo "Error: Required environment variable $var is not set" exit 1 fi done } # 初期化 init() { load_env mkdir -p "${EXPORT_DIR}" mkdir -p "logs" } # Dockerコマンドのエイリアス関数 docker_mysql_exec() { docker exec -i "${DOCKER_CONTAINER_NAME}" mysql \ -u"${MYSQL_USER}" \ -p"${MYSQL_PASSWORD}" \ "$@" } # エクスポートファイル名の生成 generate_export_filenames() { local timestamp=$(date +%Y%m%d_%H%M%S) local schema_file="${EXPORT_DIR}/${MYSQL_DATABASE}_schema_${timestamp}.sql" local data_file="${EXPORT_DIR}/${MYSQL_DATABASE}_data_${timestamp}.sql" echo "${schema_file}|${data_file}" } # 最新のエクスポートファイルを取得 get_latest_export_files() { if [ ! -d "${EXPORT_DIR}" ]; then echo "Error: Export directory not found" return 1 } local latest_schema=$(ls -t "${EXPORT_DIR}"/*_schema_*.sql 2>/dev/null | head -n1) local latest_data=$(ls -t "${EXPORT_DIR}"/*_data_*.sql 2>/dev/null | head -n1) if [ -z "${latest_schema}" ] || [ -z "${latest_data}" ]; then echo "Error: Export files not found" return 1 fi echo "${latest_schema}|${latest_data}" } # ログ出力関数 log_message() { local level=$1 local message=$2 local timestamp=$(date '+%Y-%m-%d %H:%M:%S') echo "[${timestamp}] [${level}] ${message}" echo "[${timestamp}] [${level}] ${message}" >> "logs/migration_$(date +%Y%m%d).log" } # MySQLデータのエクスポート export_mysql_data() { local schema_file=$1 local data_file=$2 if [ -z "${schema_file}" ] || [ -z "${data_file}" ]; then log_message "ERROR" "Export filenames not provided" return 1 } log_message "INFO" "Starting database export..." log_message "INFO" "Exporting schema to: ${schema_file}" # スキーマ(DDL)のエクスポート mysqldump --host="${MYSQL_HOST}" \ --port="${MYSQL_PORT}" \ --user="${MYSQL_USER}" \ --password="${MYSQL_PASSWORD}" \ --no-data \ --set-gtid-purged=OFF \ --skip-add-locks \ --skip-comments \ --routines \ --triggers \ "${MYSQL_DATABASE}" > "${schema_file}" 2>> "logs/migration_$(date +%Y%m%d).log" if [ $? -ne 0 ]; then log_message "ERROR" "Failed to export schema" return 1 fi log_message "INFO" "Exporting data to: ${data_file}" # データ(DML)のエクスポート mysqldump --host="${MYSQL_HOST}" \ --port="${MYSQL_PORT}" \ --user="${MYSQL_USER}" \ --password="${MYSQL_PASSWORD}" \ --no-create-info \ --set-gtid-purged=OFF \ --skip-add-locks \ --skip-comments \ --complete-insert \ --extended-insert=FALSE \ "${MYSQL_DATABASE}" > "${data_file}" 2>> "logs/migration_$(date +%Y%m%d).log" if [ $? -ne 0 ]; then log_message "ERROR" "Failed to export data" return 1 fi log_message "INFO" "Export completed successfully" return 0 } # DockerコンテナへのMySQLデータのインポート import_mysql_to_docker() { local schema_file=$1 local data_file=$2 if [ -z "${schema_file}" ] || [ -z "${data_file}" ]; then local latest_files=$(get_latest_export_files) if [ $? -ne 0 ]; then log_message "ERROR" "No export files found" return 1 fi schema_file=$(echo "${latest_files}" | cut -d'|' -f1) data_file=$(echo "${latest_files}" | cut -d'|' -f2) log_message "INFO" "Using latest export files:" log_message "INFO" "Schema: ${schema_file}" log_message "INFO" "Data: ${data_file}" fi # Dockerコンテナが実行中か確認 if ! docker ps | grep -q "${DOCKER_CONTAINER_NAME}"; then log_message "INFO" "Starting Docker containers..." docker-compose up -d log_message "INFO" "Waiting for MySQL to start..." local max_attempts=30 local attempt=1 while [ $attempt -le $max_attempts ]; do if docker_mysql_exec -e "SELECT 1" &>/dev/null; then break fi log_message "INFO" "Attempt $attempt of $max_attempts: MySQL not ready yet..." sleep 2 ((attempt++)) done if [ $attempt -gt $max_attempts ]; then log_message "ERROR" "MySQL failed to start within the expected time" return 1 fi fi # データベースが存在しない場合は作成 log_message "INFO" "Creating database if not exists" docker_mysql_exec -e "CREATE DATABASE IF NOT EXISTS ${MYSQL_DATABASE};" if [ $? -ne 0 ]; then log_message "ERROR" "Failed to create database" return 1 fi # スキーマ(DDL)のインポート log_message "INFO" "Importing schema from ${schema_file}" docker_mysql_exec "${MYSQL_DATABASE}" < "${schema_file}" if [ $? -ne 0 ]; then log_message "ERROR" "Failed to import schema" return 1 fi # データ(DML)のインポート log_message "INFO" "Importing data from ${data_file}" docker_mysql_exec "${MYSQL_DATABASE}" < "${data_file}" if [ $? -ne 0 ]; then log_message "ERROR" "Failed to import data" return 1 fi log_message "INFO" "Import completed successfully" return 0 } # データベースの状態確認 check_database_status() { log_message "INFO" "Checking database status..." # テーブル一覧の取得 log_message "INFO" "Getting table list..." docker_mysql_exec "${MYSQL_DATABASE}" -e "SHOW TABLES;" # テーブル数の取得 log_message "INFO" "Getting table count..." docker_mysql_exec "${MYSQL_DATABASE}" -e " SELECT COUNT(*) as total_tables FROM information_schema.tables WHERE table_schema='${MYSQL_DATABASE}';" # データベースのサイズ情報 log_message "INFO" "Getting database size information..." docker_mysql_exec "${MYSQL_DATABASE}" -e " SELECT table_schema as database_name, ROUND(SUM(data_length + index_length) / 1024 / 1024, 2) as size_mb FROM information_schema.tables WHERE table_schema='${MYSQL_DATABASE}' GROUP BY table_schema;" } # 初期化の実行 init ** export.sh [#g0238a46] #!/bin/bash # export.sh # MySQLデータベースのエクスポートスクリプト # スクリプトのディレクトリを取得 SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)" # 共通関数の読み込み source "${SCRIPT_DIR}/functions.sh" # ヘルプメッセージ show_help() { echo "Usage: $0 [options]" echo echo "Options:" echo " -h, --help Show this help message" echo " -v, --verbose Enable verbose output" echo echo "Environment variables (from .env file):" echo " MYSQL_HOST MySQL host" echo " MYSQL_PORT MySQL port" echo " MYSQL_DATABASE Database name" echo " EXPORT_DIR Export directory" echo echo "Example:" echo " $0 --verbose" } # コマンドライン引数の解析 VERBOSE=0 while [[ $# -gt 0 ]]; do case $1 in -h|--help) show_help exit 0 ;; -v|--verbose) VERBOSE=1 shift ;; *) echo "Unknown option: $1" show_help exit 1 ;; esac done # エクスポート処理の開始 log_message "INFO" "Starting database export process" if [ $VERBOSE -eq 1 ]; then log_message "INFO" "Using configuration:" log_message "INFO" " Host: ${MYSQL_HOST}" log_message "INFO" " Port: ${MYSQL_PORT}" log_message "INFO" " Database: ${MYSQL_DATABASE}" log_message "INFO" " Export Directory: ${EXPORT_DIR}" fi # エクスポートファイル名の生成 files=$(generate_export_filenames) schema_file=$(echo "${files}" | cut -d'|' -f1) data_file=$(echo "${files}" | cut -d'|' -f2) # エクスポートの実行 if export_mysql_data "${schema_file}" "${data_file}"; then log_message "INFO" "Export completed successfully" log_message "INFO" "Schema file: ${schema_file}" log_message "INFO" "Data file: ${data_file}" exit 0 else log_message "ERROR" "Export failed" exit 1 fi
テキスト整形のルールを表示する