Docker 中 MySQL 遷移策略(單節點)

目錄

    • 一、 簡介
    • 二、操作流程
      • 2.1 進入mysql容器
      • 2.2 導出 MySQL 數據
      • 2.3. 將導出的文件復制到宿主機
      • 2.4 創建 Docker Compose 配置
      • 2.5 啟動新的 Docker 容器
      • 2.6 導入數據到新的容器
      • 2.7 驗證數據
      • 2.8 刪除舊的容器(刪除操作需慎重)
    • 三、推薦配置
    • 四、寫在后面

一、 簡介

本人發現自己Docker中Mysql的時區不對,導致每次連接數據庫都需要設置時區,所以考慮進行數據庫遷移,重新搭建一個正確時間的數據庫。

二、操作流程

2.1 進入mysql容器

要進入運行中的 MySQL 容器,可以使用以下命令:

docker exec -it mysql-old /bin/bash

這里的 mysql-old 是你原來容器的名

2.2 導出 MySQL 數據

在容器內部,使用 mysqldump 工具導出所有數據庫:

mysqldump -u root -p --all-databases > /tmp/alldb.sql

2.3. 將導出的文件復制到宿主機

/tmp/alldb.sql 文件從容器復制到宿主機的指定路徑:

docker cp mysql-old:/tmp/alldb.sql Docker/mysql

2.4 創建 Docker Compose 配置

編寫 docker-compose.yml 文件,配置新的 MySQL 服務:

services:mysql:image: mysql:8.4.0container_name: mysql-docker # 設置容器名字ports: # 添加端口映射- "3306:3306"volumes:- /Users/siyuan/Docker/mysql/data:/var/lib/mysql  # 數據卷- /Users/siyuan/Docker/mysql/conf:/etc/mysql/conf.d  # 配置卷- /Users/siyuan/Docker/mysql/logs:/var/log/mysql  # 日志卷environment:MYSQL_ROOT_PASSWORD: rootTZ: Asia/Shanghai   # 設置時區,例如亞洲/上海restart: alwaysdeploy:resources:limits: # 設置合理的資源限制cpus: '0.5' # 限制容器使用半核 CPU 資源memory: 512M # 限制容器使用最多 512MB 內存

2.5 啟動新的 Docker 容器

docker-compose.yml 所在路徑下使用 docker-compose up -d 命令啟動新的容器。

2.6 導入數據到新的容器

將宿主機上的 SQL 文件導入到新的 MySQL 容器:

docker cp Docker/mysql/alldb.sql mysql-docker:/tmp/
docker exec -i mysql-docker mysql -u root -p'root' < /tmp/alldb.sql

2.7 驗證數據

登錄到新的 MySQL 容器,檢查數據是否成功導入:

docker exec -it mysql-docker mysql -u root -p
SHOW DATABASES;

連接時如果出現:

? mysql -u root -p
Enter password:
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

請在連接時使用:

mysql -u root -p -h 127.0.0.1

2.8 刪除舊的容器(刪除操作需慎重)

docker stop mysql-old
docker rm mysql-old

三、推薦配置

  • 使用具體版本號的 MySQL 鏡像,避免使用 latest 標簽。
  • 設置合理的資源限制,避免 MySQL 服務消耗過多宿主機資源。
  • 考慮使用 Docker secrets 或環境變量文件來管理密碼。
  • 確保 MySQL 用戶權限設置正確,允許從宿主機 IP 地址連接。
  • 使用 Docker Compose 的 networks 配置來管理容器網絡。
  • 實施定期備份策略,保障數據安全。

四、寫在后面

歡迎關注,會經常記錄一些工作中遇到的問題。

歡迎隨時留言討論,與君共勉,知無不答!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/38833.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/38833.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/38833.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

當年很多跑到美加澳寫代碼的人現在又移回香港?什么原因?

當年很多跑到美加澳寫代碼的人現在又移回香港&#xff1f;什么原因&#xff1f; 近年來&#xff0c;確實有部分曾經移民到美國、加拿大、澳大利亞等地的香港居民選擇移回香港。這一現象與多種因素相關&#xff0c;主要可以歸結為以下幾點&#xff1a; 疫情后的環境變化&#…

【STM32】溫濕度采集與OLED顯示

一、任務要求 1. 學習I2C總線通信協議&#xff0c;使用STM32F103完成基于I2C協議的AHT20溫濕度傳感器的數據采集&#xff0c;并將采集的溫度-濕度值通過串口輸出。 任務要求&#xff1a; 1&#xff09;解釋什么是“軟件I2C”和“硬件I2C”&#xff1f;&#xff08;閱讀野火配…

2025第13屆常州國際工業裝備博覽會招商全面啟動

常州智造 裝備中國|2025第13屆常州國際工業裝備博覽會招商全面啟動 2025第13屆常州國際工業裝備博覽會將于2025年4月11-13日在常州西太湖國際博覽中心盛大舉行&#xff01;目前&#xff0c;各項籌備工作正穩步推進。 60000平米的超大規模、800多家國內外工業裝備制造名企將云集…

C++中的RAII(資源獲取即初始化)原則

C中的RAII&#xff08;Resource Acquisition Is Initialization&#xff0c;資源獲取即初始化&#xff09;原則是一種管理資源、避免資源泄漏的慣用法。RAII是C之父Bjarne Stroustrup提出的設計理念&#xff0c;其核心思想是將資源的獲取&#xff08;如動態內存分配、文件句柄、…

最細最有條理解析:事件循環(消息循環)是什么?進程與線程的定義、關系與差異

目錄 事件循環&#xff1a;引入 一、瀏覽器的進程模型 1.1、什么是進程&#xff08;Process&#xff09; 1.2、什么是線程&#xff08;Thread&#xff09; 1.3、進程與線程之間的關系聯系與區別 二、瀏覽器有哪些進程和線程 2.1、瀏覽器的主要進程 ①瀏覽器進程 ②網絡…

ctfshow sqli-libs web561--web568

web561 ?id-1 or 1--?id-1 union select 1,2,3--?id-1 union select 1,(select group_concat(column_name) from information_schema.columns where table_nameflags),3-- Your Username is : id,flag4s?id-1 union select 1,(select group_concat(flag4s) from ctfshow.f…

擴展學習|風險評估和風險管理:回顧其基礎上的最新進展

文獻來源&#xff1a;[1]Aven, T. (2016). Risk assessment and risk management: Review of recent advances on their foundation. European journal of operational research, 253(1), 1-13. 文章簡介&#xff1a;大約30-40年前&#xff0c;風險評估和管理被確立為一個科學領…

數據結構 - C/C++ - 鏈表

目錄 結構特性 內存布局 結構樣式 結構拓展 單鏈表 結構定義 節點關聯 插入節點 刪除節點 常見操作 雙鏈表 環鏈表 結構容器 結構設計 結構特性 線性結構的存儲方式 順序存儲 - 數組 鏈式存儲 - 鏈表 線性結構的鏈式存儲是通過任意的存儲單元來存儲線性…

技術分享:分布式數據庫DNS服務器的架構思路

DNS是企業數字化轉型的基石。伴隨微服務或單元化部署的推廣&#xff0c;許多用戶也開始采用分布式數據庫將原來的單體數據庫集群服務架構拆分為大量分布式子服務集群&#xff0c;對應不同的微服務或服務單元。本文將從分布式數據庫DNS服務器的架構需求、架構分析兩方面入手&…

1_插入排序_循環不變式

01_插入排序 #include<stdio.h>void insert_sort(int arr[], int n); void printArray(int arr[], size);int main() {int arr[] {1, 2, 3, 22, 5, 9};int n sizeof(arr) / sizeof(arr[0]);printf("打印原始數組:\n");prinfArray(arr, n);insert_sort(arr, …

湖北大學2024年成人高考函授報名專升本市場營銷專業介紹

在璀璨的學術殿堂中&#xff0c;湖北大學如同一顆璀璨的明珠&#xff0c;熠熠生輝。為了滿足廣大社會人士對于繼續深造、提升自我、實現職業夢想的渴望&#xff0c;湖北大學特別開設了成人高等繼續教育項目&#xff0c;為廣大有志之士敞開了一扇通往知識殿堂的大門。 而今&…

【FFmpeg】av_write_frame函數

目錄 1.av_write_frame1.1 寫入pkt&#xff08;write_packets_common&#xff09;1.1.1 檢查pkt的信息&#xff08;check_packet&#xff09;1.1.2 準備輸入的pkt&#xff08;prepare_input_packet&#xff09;1.1.3 檢查碼流&#xff08;check_bitstream&#xff09;1.1.4 寫入…

【創建者模式-建造者模式】

概要 將一個復雜對象的構建與表示分離&#xff0c;使得同樣的構建過程可以創建不同的表示。 建造者模式包含以下角色 抽象建造者類&#xff08;Builder&#xff09;&#xff1a;這個接口規定要實現復雜對象的那些部分的創建&#xff0c;并不涉及具體的部件對象的創建。具體建…

什么是ISR?

ISR&#xff08;Interrupt Service Routine&#xff0c;中斷服務程序&#xff09;是一個用于處理硬件中斷的特定程序。中斷是硬件或軟件引起的事件&#xff0c;會暫時打斷當前正在運行的任務&#xff0c;以便緊急處理某個事件。ISR的目的是快速響應中斷信號&#xff0c;執行所需…

在WSL Ubuntu中啟用root用戶的SSH服務

在 Ubuntu 中&#xff0c;默認情況下 root 用戶是禁用 SSH 登錄的&#xff0c;這是為了增加系統安全性。 一、修改配置 找到 PermitRootLogin 行&#xff1a;在文件中找到 PermitRootLogin 配置項。默認情況下&#xff0c;它通常被設置為 PermitRootLogin prohibit-password 或…

一篇文章學會【node.js安裝以及Vue-Cli腳手架搭建】

一.為什么搭建Vue-Cli (1).傳統的前端項目結構&#xff1a; 一個項目中有許多html文件&#xff0c;每一個html文件都是相互獨立的&#xff0c; 如果需要在頁面中導入一些外部依賴的組件&#xff0c;就需要在每一個html文件中都需要導入&#xff0c;非常麻煩 (2).現在的前端…

A股低開高走,近3000點,行情要啟動了嗎?

A股低開高走&#xff0c;近3000點&#xff0c;行情要啟動了嗎&#xff1f; 今天的A股&#xff0c;讓人瞪目結舌了&#xff0c;你們知道是為什么嗎&#xff1f;盤面上出現2個重要信號&#xff0c;一起來看看&#xff1a; 1、今天兩市低開高走&#xff0c;銀行板塊護盤指數&…

Windows 下后臺啟動java項目的 jar 包

java -jar swagger.jar 的dos窗口 后臺啟動 jar 包&#xff1a; 使用 javaw.exe 啟動 jar 包&#xff0c;并不會在窗口打印日志&#xff0c;而且會直接在后臺運行進程&#xff0c;關掉窗口&#xff0c;進程繼續跑 javaw -jar swagger.jar 關閉進程&#xff1a; 后臺啟動的 …

大數據面試題之Spark(7)

Spark實現wordcount Spark Streaming怎么實現數據持久化保存? Spark SQL讀取文件&#xff0c;內存不夠使用&#xff0c;如何處理? Spark的lazy體現在哪里? Spark中的并行度等于什么 Spark運行時并行度的設署 Spark SQL的數據傾斜 Spark的exactly-once Spark的RDD和p…

大話C語言:第26篇 靜態庫

1 靜態庫概述 C語言靜態庫&#xff08;Static Library&#xff09;是一種包含一組目標文件的歸檔文件&#xff0c;這些目標文件通常是由多個C語言源文件編譯而成的。靜態庫在程序編譯時被鏈接到目標程序中&#xff0c;成為程序的一部分&#xff0c;因此在運行時不再需要額外的…