亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Docker中mysql鏡像保存與導入的方法詳解

 更新時間:2025年05月09日 16:35:37   作者:my向陽而生  
Docker 的 MySQL 鏡像保存通常有兩種場景:一種是保存鏡像本身的修改(如配置、初始化數(shù)據(jù)),另一種是持久化保存容器運行時產(chǎn)生的數(shù)據(jù)(如數(shù)據(jù)庫表、用戶數(shù)據(jù)),這篇文章主要介紹了Docker中mysql鏡像保存與導入的方法詳解,需要的朋友可以參考下

一、Docker中mysql鏡像保存

Docker 的 MySQL 鏡像保存通常有兩種場景:一種是保存鏡像本身的修改(如配置、初始化數(shù)據(jù)),另一種是持久化保存容器運行時產(chǎn)生的數(shù)據(jù)(如數(shù)據(jù)庫表、用戶數(shù)據(jù))。以下是具體方法:

方法 1:保存鏡像修改(通過 docker commit)

如果修改了容器內(nèi)的配置或希望保存初始化數(shù)據(jù),可以將容器提交為新的鏡像:

# 1. 停止 MySQL 容器
docker stop <container_name>
# 2. 提交容器為新的鏡像
docker commit <container_name> my-mysql-custom
# 3. 保存鏡像為 .tar 文件(可選,用于遷移或備份)
docker save my-mysql-custom > my-mysql-custom.tar

注意事項:

  • 不推薦長期依賴此方法:數(shù)據(jù)庫數(shù)據(jù)頻繁變化,鏡像體積會膨脹。
  • 適合保存初始配置(如修改 my.cnf 或預裝工具),不適合保存動態(tài)數(shù)據(jù)。

方法 2:持久化數(shù)據(jù)(使用 Docker Volumes)

MySQL 的官方鏡像默認將數(shù)據(jù)存儲在容器內(nèi)的 /var/lib/mysql。為了永久保存數(shù)據(jù),需通過**卷(Volume)綁定掛載(Bind Mount)**將數(shù)據(jù)映射到宿主機。

方案 1:使用 Docker Volume

# 1. 創(chuàng)建 Volume
docker volume create mysql_data
# 2. 啟動容器時掛載 Volume
docker run -d \
  --name mysql-container \
  -e MYSQL_ROOT_PASSWORD=your_password \
  -v mysql_data:/var/lib/mysql \
  mysql:tag
# 數(shù)據(jù)會永久保存在 Volume 中

方案 2:使用宿主機目錄(Bind Mount)

# 1. 創(chuàng)建宿主機目錄
mkdir -p /host/path/mysql/data
# 2. 啟動容器時綁定目錄
docker run -d \
  --name mysql-container \
  -e MYSQL_ROOT_PASSWORD=your_password \
  -v /host/path/mysql/data:/var/lib/mysql \
  mysql:tag
# 數(shù)據(jù)會永久保存在宿主機的 /host/path/mysql/data 目錄

如何備份數(shù)據(jù)?

# 直接備份 Volume 或綁定目錄的內(nèi)容
cp -r /host/path/mysql/data /backup/mysql-data

方法 3:導出數(shù)據(jù)庫內(nèi)容(通過 mysqldump)

即使不保存鏡像或卷,也可以通過 SQL 導出數(shù)據(jù):

# 1. 導出數(shù)據(jù)庫到 SQL 文件
docker exec mysql-container \
  mysqldump -u root -p"your_password" --all-databases > backup.sql
# 2. 恢復數(shù)據(jù)到新容器
cat backup.sql | docker exec -i new-mysql-container \
  mysql -u root -p"your_password"

總結

場景推薦方法
保存鏡像配置docker commit + docker save
持久化動態(tài)數(shù)據(jù)Volume 或 Bind Mount
遷移或備份數(shù)據(jù)庫mysqldump 導出 SQL

關鍵原則:

  • 數(shù)據(jù)庫動態(tài)數(shù)據(jù)(如表、用戶)永遠通過 Volume/Bind Mount 持久化。
  • 鏡像僅用于保存靜態(tài)配置(如預置的 my.cnf 或初始化腳本)。
  • 定期使用 mysqldump 備份 SQL 更安全可靠。

二、導入保存的Mysql鏡像

以下是導入已保存的 MySQL 鏡像及其數(shù)據(jù)的完整方法,具體取決于你之前保存鏡像或數(shù)據(jù)的方式:

場景 1:導入通過 docker save 保存的鏡像文件(.tar格式)

如果鏡像通過 docker save 導出為 .tar 文件(如 my-mysql-custom.tar),按以下步驟導入:

步驟:

# 1. 導入鏡像到本地 Docker
docker load -i my-mysql-custom.tar
# 2. 查看是否導入成功
docker images
# 應看到名為 `my-mysql-custom` 的鏡像
# 3. 運行容器(注意掛載數(shù)據(jù)卷)
docker run -d \
  --name mysql-restored \
  -e MYSQL_ROOT_PASSWORD=your_password \
  -v mysql_data:/var/lib/mysql \  # 掛載 Volume 確保數(shù)據(jù)持久化
  my-mysql-custom

關鍵說明:

  • 鏡像不包含動態(tài)數(shù)據(jù):如果原鏡像通過 docker commit 保存了容器內(nèi)的數(shù)據(jù)(如 /var/lib/mysql),新容器默認仍會覆蓋這些數(shù)據(jù),除非顯式掛載 Volume。
  • 必須掛載 Volume:建議啟動時掛載 Volume(或綁定宿主機目錄),否則容器重啟后數(shù)據(jù)可能丟失。

場景 2:直接使用已存在的自定義鏡像(無需 .tar 文件)

如果鏡像已存在于本地(如通過 docker commit 生成),直接運行即可:

# 直接啟動容器(掛載 Volume)
docker run -d \
  --name mysql-custom \
  -e MYSQL_ROOT_PASSWORD=your_password \
  -v mysql_data:/var/lib/mysql \
  my-mysql-custom  # 鏡像名稱

場景 3:恢復通過 mysqldump 導出的 SQL 數(shù)據(jù)

如果數(shù)據(jù)通過 mysqldump 導出為 .sql 文件(如 backup.sql),需先啟動新容器,再導入數(shù)據(jù):

步驟:

# 1. 啟動一個全新的 MySQL 容器(掛載 Volume)
docker run -d \
  --name mysql-new \
  -e MYSQL_ROOT_PASSWORD=your_password \
  -v mysql_data:/var/lib/mysql \
  mysql:tag
# 2. 將 SQL 文件導入到容器
cat backup.sql | docker exec -i mysql-new \
  mysql -u root -p"your_password"
# 或手動進入容器執(zhí)行
docker exec -it mysql-new mysql -u root -p
# 進入 MySQL Shell 后運行 `source backup.sql`

場景 4:恢復 Volume 或綁定目錄的數(shù)據(jù)

如果數(shù)據(jù)已通過 Volume宿主機目錄 持久化,只需掛載原數(shù)據(jù)路徑即可:

方法 1:使用原有 Volume

# 直接掛載原有 Volume(假設 Volume 名稱為 `mysql_data`)
docker run -d \
  --name mysql-restored \
  -e MYSQL_ROOT_PASSWORD=your_password \
  -v mysql_data:/var/lib/mysql \
  mysql:tag  # 可使用原鏡像或新鏡像

方法 2:使用宿主機備份目錄

# 假設備份數(shù)據(jù)在宿主機的 `/backup/mysql-data` 目錄
docker run -d \
  --name mysql-restored \
  -e MYSQL_ROOT_PASSWORD=your_password \
  -v /backup/mysql-data:/var/lib/mysql \
  mysql:tag

總結:根據(jù)需求選擇恢復方式

場景推薦方法
保存鏡像配置docker commit + docker save
持久化動態(tài)數(shù)據(jù)VolumeBind Mount
遷移或備份數(shù)據(jù)庫mysqldump 導出 SQL

注意事項:

  • 鏡像僅保存靜態(tài)配置:數(shù)據(jù)庫動態(tài)數(shù)據(jù)(如表、用戶)依賴 Volume 或 SQL 備份恢復。
  • 權限問題:如果使用宿主機目錄掛載,確保目錄權限允許 MySQL 容器寫入(可能需要 chmod -R 777 /host/path 或調(diào)整 SELinux/AppArmor 配置)。

到此這篇關于Docker中mysql鏡像保存與導入的文章就介紹到這了,更多相關docker mysql鏡像內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Docker鏡像構建速度優(yōu)化實現(xiàn)

    Docker鏡像構建速度優(yōu)化實現(xiàn)

    本文主要介紹了Docker鏡像構建速度優(yōu)化實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-12-12
  • centos6使用docker部署zookeeper操作示例

    centos6使用docker部署zookeeper操作示例

    這篇文章主要介紹了centos6使用docker部署zookeeper操作,結合實例形式分析了centos6平臺使用docker部署zookeeper相關命令與使用技巧,需要的朋友可以參考下
    2020-02-02
  • docker安裝Adminer并支持mysql和mongodb的詳細步驟

    docker安裝Adminer并支持mysql和mongodb的詳細步驟

    這篇文章主要介紹了docker安裝Adminer并支持mysql和mongodb,通過查找并拉取Adminer鏡像,啟動docker,支持mysq,本文分步驟給大家詳細講解,需要的朋友可以參考下
    2022-10-10
  • Windows下Docker安裝各種軟件的詳細過程

    Windows下Docker安裝各種軟件的詳細過程

    這篇文章主要介紹了Windows下Docker安裝各種軟件的詳細過程,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-07-07
  • 關于docker清理Overlay2占用磁盤空間的問題(親測有效)

    關于docker清理Overlay2占用磁盤空間的問題(親測有效)

    使用Docker過程中,長時間運行服務容器,導致不能進行上傳文件等操作,今天通過本文給大家詳細介紹下docker清理Overlay2占用磁盤空間的相關知識,感興趣的朋友一起看看吧
    2022-03-03
  • Docker快速部署SpringBoot項目介紹

    Docker快速部署SpringBoot項目介紹

    大家好,本篇文章主要講的是Docker快速部署SpringBoot項目介紹,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下哦,方便下次瀏覽
    2021-12-12
  • harbor可視化私有鏡像倉庫環(huán)境及服務部署示例

    harbor可視化私有鏡像倉庫環(huán)境及服務部署示例

    這篇文章主要為大家介紹了harbor可視化私有鏡像倉庫環(huán)境及服務部署示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪
    2022-04-04
  • docker和docker-compose一鍵安裝教程(支持在線和離線)

    docker和docker-compose一鍵安裝教程(支持在線和離線)

    這篇文章主要介紹了docker和docker-compose一鍵安裝(支持在線和離線),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12
  • Docker部署MySQL8集群(一主二從)的實現(xiàn)步驟

    Docker部署MySQL8集群(一主二從)的實現(xiàn)步驟

    本文主要介紹了Docker部署MySQL8集群,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • Docker 端口映射與容器互聯(lián)的實現(xiàn)

    Docker 端口映射與容器互聯(lián)的實現(xiàn)

    Docker的端口映射和容器互聯(lián)是構建和管理微服務架構時重要的概念,本文主要介紹了Docker 端口映射與容器互聯(lián)的實現(xiàn),文中通過示例代碼介紹的非常詳細,需要的朋友們下面隨著小編來一起學習學習吧
    2025-01-01

最新評論