欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Docker制作MySQL鏡像并使用`/docker-entrypoint-initdb.d/`問題

 更新時(shí)間:2024年05月22日 08:50:21   作者:小子寶丁  
這篇文章主要介紹了Docker制作MySQL鏡像并使用`/docker-entrypoint-initdb.d/`問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

需求

制作一個(gè) MySQL Docker 鏡像并初始化數(shù)據(jù)庫信息

環(huán)境

  • win 11
  • Docker-Desktop 4.14.0 (91374)

分析

啟動一個(gè)MySQL容器很容易。如何初始化數(shù)據(jù)呢?

大概我們會嘗試很多操作,比如百度常見到 使用 CMD 命令調(diào)用shell腳本,通過shell腳本處理初始化數(shù)據(jù)等等,經(jīng)過實(shí)踐,這些都不太方便。

其實(shí),MySQL 官方提供了很簡單的方案,用戶只需要準(zhǔn)備好 初始化腳本,并把這些初始化腳本在制作鏡像時(shí)拷貝到 MySQL 鏡像內(nèi)的 /docker-entrypoint-initdb.d 文件夾中即可。

MySQL 數(shù)據(jù)初始化機(jī)制

在 Docker hub 官網(wǎng)中,MySQL鏡像首頁提供了很多初始化數(shù)據(jù)的方式,包括數(shù)據(jù)的導(dǎo)入、導(dǎo)出等。

下面是官方對使用 /docker-entrypoint-initdb.d 初始化數(shù)據(jù)的描述:

原文

When a container is started for the first time, a new database with the specified name will be created and initialized with the provided configuration variables. Furthermore, it will execute files with extensions .sh, .sql and .sql.gz that are found in /docker-entrypoint-initdb.d. Files will be executed in alphabetical order. You can easily populate your mysql services by mounting a SQL dump into that directory and provide custom images with contributed data. SQL files will be imported by default to the database specified by the MYSQL_DATABASE variable.

譯文

首次啟動容器時(shí),將創(chuàng)建具有指定名稱的新數(shù)據(jù)庫,并使用提供的配置變量進(jìn)行初始化。此外,它將執(zhí)行擴(kuò)展名為 /docker-entrypoint-initdb.d 中的擴(kuò)展名 .sh、.sql 和 .sql.gz 的文件。文件將按字母順序執(zhí)行。您可以通過將 SQL 轉(zhuǎn)儲掛載到該目錄中來輕松填充 mysql 服務(wù),并為包含貢獻(xiàn)數(shù)據(jù)的自定義映像提供。默認(rèn)情況下,SQL 文件將導(dǎo)入到 MYSQL_DATABASE 變量指定的數(shù)據(jù)庫中。

實(shí)例

本例將通過 Dockerfile 構(gòu)建一個(gè)docker 鏡像,并在該容器中初始化數(shù)據(jù)。

1、編寫 Dockerfile

創(chuàng)建Dockerfile文件,并輸入如下內(nèi)容

FROM mysql:5.7

# 將 xzbd.sql 放到 docker 初始化文件家中
COPY xzbd.sql /docker-entrypoint-initdb.d/xzbd.sql

該鏡像基于 MySQL 5.7 制作,命名 COPY xzbd.sql /docker-entrypoint-initdb.d/xzbd.sql 是把初始化 SQL 添加到 MySQL 鏡像的 /docker-entrypoint-initdb.d 目錄中

2、xzbd.sql 文件

該文件為自定義的數(shù)據(jù)庫文件,內(nèi)容如下:

create database if not exists xzbd;
use xzbd;

SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------
-- Table structure for x_item
-- ----------------------------
DROP TABLE IF EXISTS `x_item`;
CREATE TABLE `x_item`
(
    `id`     INT AUTO_INCREMENT PRIMARY KEY,
    `name`   VARCHAR(10) NOT NULL COMMENT '元素名稱',
    `status` VARCHAR(10) NOT NULL COMMENT '元素狀態(tài)',
    `icon`   VARCHAR(50) NOT NULL COMMENT 'ICON',
    `type`   VARCHAR(50) NOT NULL COMMENT '類型',
    CONSTRAINT x_item_name_uindex UNIQUE (name)
) ENGINE = InnoDB
  CHARACTER SET = utf8mb4 COMMENT 'X子項(xiàng)'
  ROW_FORMAT = Dynamic;

-- 初始化 X子項(xiàng)
INSERT INTO `x_item`(`id`, `name`, `status`, `icon`, `type`) VALUES (27, 'XItem02', 'ENABLE', 'ITEM_9', 'ITEM_9');
INSERT INTO `x_item`(`id`, `name`, `status`, `icon`, `type`) VALUES (28, 'XItem03', 'ENABLE', 'ITEM_10', 'ITEM_10');
INSERT INTO `x_item`(`id`, `name`, `status`, `icon`, `type`) VALUES (29, 'XItem04', 'ENABLE', 'ITEM_11', 'ITEM_11');
INSERT INTO `x_item`(`id`, `name`, `status`, `icon`, `type`) VALUES (30, 'XItem05', 'ENABLE', 'ITEM_12', 'ITEM_12');
INSERT INTO `x_item`(`id`, `name`, `status`, `icon`, `type`) VALUES (31, 'XItem06', 'ENABLE', 'ITEM_13', 'ITEM_13');
INSERT INTO `x_item`(`id`, `name`, `status`, `icon`, `type`) VALUES (32, 'XItem07', 'ENABLE', 'ITEM_14', 'ITEM_14');
INSERT INTO `x_item`(`id`, `name`, `status`, `icon`, `type`) VALUES (33, 'XItem08', 'ENABLE', 'ITEM_15', 'ITEM_15');
INSERT INTO `x_item`(`id`, `name`, `status`, `icon`, `type`) VALUES (34, 'XItem08', 'ENABLE', 'ITEM_16', 'ITEM_16');

該腳本中主要做了如下內(nèi)容

  • 創(chuàng)建了一個(gè)數(shù)據(jù)庫 xzbd
  • 創(chuàng)建表 x_item
  • 給表 x_item 中插入8 條數(shù)據(jù)

文件準(zhǔn)備及目錄結(jié)構(gòu)如下圖所示:

3、構(gòu)建鏡像

構(gòu)建鏡像 mysql-xzbd:0.1.0 , 命令如下:

docker build -t mysql-xzbd:0.1.0 .

注意命令最后的那個(gè) . 。

構(gòu)建過程如下:

構(gòu)建成功后,使用 docker images 查看是否有 mysql-xzbd 鏡像,且版本為 0.1.0

結(jié)果如下:

上圖中使用了 findstr 過濾,在 linux 操作系統(tǒng)應(yīng)將其換為 grep

4、運(yùn)行

使用剛剛構(gòu)建的 mysql-xzbd:0.1.0 鏡像運(yùn)行一個(gè)容器。

# 運(yùn)行容器
docker run --name mysql-xzbd-servevr -it -d -e MYSQL_ROOT_PASSWORD=123456 -p 3306:3306 mysql-xzbd:0.1.0

# 查看是否啟動成功
docker ps

5、驗(yàn)證

驗(yàn)證容器 mysql-xzbd-servevr 中是否創(chuàng)建了數(shù)據(jù)庫 xzbd,并查看其內(nèi)部是否有 x_item 表,且內(nèi)部是否擁有初始化數(shù)據(jù)。

  • 進(jìn)入容器
docker exec -it mysql-xzbd-servevr sh
  • 登錄 MySQL
mysql -uroot -p

輸入密碼 123456 。登錄成功后效果如下:

  • 查看數(shù)據(jù)庫
show databases;
  • 查看數(shù)據(jù)表
use xzbd;
show tables;
  • 查看表 x_item 中的數(shù)據(jù)
select * from x_item;

總結(jié)

本文介紹了使用Dockerfile構(gòu)建有初始化數(shù)據(jù)MySQL鏡像包的詳細(xì)過程。

通過驗(yàn)證,使用 /docker-entrypoint-initdb.d 初始化數(shù)據(jù)是可行的。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Docker教程之Ubuntu 安裝 Docker詳細(xì)介紹

    Docker教程之Ubuntu 安裝 Docker詳細(xì)介紹

    這篇文章主要介紹了Docker教程之Ubuntu 安裝 Docker詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下
    2016-12-12
  • Centos7上安裝docker的方法

    Centos7上安裝docker的方法

    Docker從1.13版本之后采用時(shí)間線的方式作為版本號,分為社區(qū)版CE和企業(yè)版EE。這篇文章給大家介紹了Centos7上安裝docker的方法,感興趣的朋友一起看看吧
    2018-07-07
  • docker安裝、調(diào)試qsign簽名服務(wù)器的解決方案

    docker安裝、調(diào)試qsign簽名服務(wù)器的解決方案

    這篇文章主要介紹了docker安裝、調(diào)試qsign簽名服務(wù)器的解決方案,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2024-04-04
  • docker如何導(dǎo)出指定時(shí)間段內(nèi)日志

    docker如何導(dǎo)出指定時(shí)間段內(nèi)日志

    這篇文章主要介紹了docker如何導(dǎo)出指定時(shí)間段內(nèi)日志問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • Docker之實(shí)現(xiàn)掛載的三種方式匯總

    Docker之實(shí)現(xiàn)掛載的三種方式匯總

    這篇文章主要介紹了Docker之實(shí)現(xiàn)掛載的三種方式匯總,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • 如何在Docker環(huán)境下為Nginx配置HTTPS

    如何在Docker環(huán)境下為Nginx配置HTTPS

    如何在Docker環(huán)境下為Nginx配置HTTPS,使用自簽名證書實(shí)現(xiàn)加密通信,本文給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-11-11
  • docker容器化部署及使用方式

    docker容器化部署及使用方式

    這篇文章主要介紹了docker容器化部署及使用方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • Docker?Swarm?操作對容器端口影響記錄

    Docker?Swarm?操作對容器端口影響記錄

    在使用Docker Swarm 構(gòu)建集群環(huán)境過程中,于ts3節(jié)點(diǎn)出現(xiàn)了原有的容器端口全部失效,手動重啟后才恢復(fù)的情況,這篇文章主要介紹了Docker Swarm操作對容器端口影響,需要的朋友可以參考下
    2025-04-04
  • docker部署Prometheus+Cadvisor+Grafana實(shí)現(xiàn)服務(wù)器監(jiān)控

    docker部署Prometheus+Cadvisor+Grafana實(shí)現(xiàn)服務(wù)器監(jiān)控

    這篇文章主要為大家介紹了docker部署Prometheus+Cadvisor+Grafana實(shí)現(xiàn)服務(wù)器監(jiān)控,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11
  • 使用Docker多階段構(gòu)建來減小鏡像大小的方法

    使用Docker多階段構(gòu)建來減小鏡像大小的方法

    這篇文章主要介紹了使用Docker多階段構(gòu)建來減小鏡像大小的方法,適用于需要在 Dockerfile 中構(gòu)建程式,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-12-12

最新評論