mysql的docker镜像数据库初始化踩坑记

2023-11-14

 一.制作docker镜像

 在当前目录新建子目录script, 将数据库初始化脚本拷贝进去,后缀名为 *.sql,脚本执行顺序是按字母大小排序,建议可以按 1_xxx.sql, 2_xxx.sql这样命令。

Dockerfile如下

FROM mysql:5.7 AS base

WORKDIR /docker-entrypoint-initdb.d
COPY script/ ./

 运行构建命令: docker build -t mysql:test .

  二. 制作docker-compose.yml文件

version: "3.8"


services:
  db_test:
    image: mysql:test
    volumes:
     - /etc/localtime:/etc/localtime:ro
     - /mydata:/var/lib/mysql
    command: --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci --log-timestamps=SYSTEM
    environment:
     - MYSQL_ROOT_PASSWORD=111111
     - MYSQL_USER=test
     - MYSQL_PASSWORD=123456
    container_name: mysql_test
~

   运行docker-compose up -d 启动容器,当/mydata目录为空时,会执行数据库初始化脚本。

  坑一:因文件格式导致的 sql 语法错误

     我在本地写sql脚本时保存的是UTF8 BOM格式的文件,如果使用linux shell的脚本合并到别的文件时,会把BOM前缀也写进去,这会导致初始化提示SQL syntax错误,这个问题当时一直没弄明白,后来用vi编辑器一看才发现。

   重现步骤如下

echo '#hello' > test.sql
cat init.sql >> test.sql

  然后用vi编辑一看,就发现一些奇怪的字符(蓝色标记的)

解决办法如下:用sed去掉特殊字符

sed $'1s/^\xEF\xBB\xBF//' < ./init.sql >> test.sql

 参考: command line - How can I remove the BOM from a UTF-8 file? - Unix & Linux Stack Exchangeicon-default.png?t=L892https://unix.stackexchange.com/questions/381230/how-can-i-remove-the-bom-from-a-utf-8-file

坑二: 初始化后中文数据在数据表里变成了乱码

在每个数据库脚本文件的第一行加上:

SET NAMES 'utf8mb4' COLLATE 'utf8mb4_unicode_ci';

注意:笔者是使用的utf8mb4_unicode_ci,  如果你使用的是别的编码,可以换成你的。

可用如下命令查询编码:

附加到mysql容器上
docker exec -it mysql_test sh

登录mysql命令行交互模式
mysql -u root -p 

查询编码

show variables like '%char%';

show variables like '%collation%';

 

如果要在mysql命令行交互模式下查看中文数据,需要加参数,如下

mysql -u root --default-character-set=utf8mb4 -p

参考: utf8-garbled-when-importing-into-mysqlicon-default.png?t=L892https://stackoverflow.com/questions/13234433/utf8-garbled-when-importing-into-mysql

 坑三: 脚本里的存储过程创建报错,提示语法错误

默认delimiter是分号, 存储过程内容里肯定包含了分号,所以在创建存储过程时,需要先切换delimiter,  创建完了之后再还原,示例如下:

delimiter $$
DROP PROCEDURE IF EXISTS TestProc;
CREATE PROCEDURE TestProc()
Begin

...
...

End; $$
delimiter ;

 

 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

mysql的docker镜像数据库初始化踩坑记 的相关文章

随机推荐

  • SAE:如何使用phpExcel

    1 把phpExcel的工具类上传到Sae的云服务器 2 然后你要在Storage 上创建一个Bucket 名字你可以自己起 3 上代码 use sinacloud sae Storage as Storage s new SaeStora
  • JavaScript,将rgb颜色字符串转化为16进制

    颜色字符串转换 rgb字符串 gt 16进制 描述 输入 rgb 255 255 255 输出 ffffff 思路 1 rgb中 每个逗号后面空格数不固定 正则表达式中需要考虑匹配空格 2 当输入不符合rgb格式 返回原始输入 3 当输入符
  • apache配置指令速查

    AcceptFilter AcceptFilter 指令 说明 根据协议类型对监听Socket进行优化 语法 AcceptFilter protocol accept filter 作用域 server config 状态 核心 C 模块
  • 全局配置_中兴天机配置公布:智汇屏+全局黑暗模式

    宅男科技12月16日消息 中兴今日正式在其官方社交账号上公布了即将发售的中兴天机Axon 10s Pro 5G的配置参数 并表示新机将于2020年年初正式对外发布 据悉 即将面世的中兴天机Axon 10s Pro 5G将会搭载最新的骁龙86
  • 『Newsletter 丨第二期』PieCloudDB Database 新增控制台、LDAP 支持、虚拟数仓日志等多项功能

    PieCloudDB Database 最新动态 云上云版 控制台 功能上线 PieCloudDB 云上云版 控制台 功能全新上线 控制台集成了组织 数仓 用户 费用 权限等多方位管理功能 支持在一个组织下创建和管理多个数仓 并支持独立的一
  • 【华为OD统一考试B卷

    在线OJ 已购买本专栏用户 请私信博主开通账号 在线刷题 运行出现 Runtime Error 0Aborted 请忽略 华为OD统一考试A卷 B卷 新题库说明 2023年5月份 华为官方已经将的 2022 0223Q 1 2 3 4 统一
  • arduino黑线循迹小车程序_基于arduino的循迹小车(含有PID算法)

    循迹小车一般分为两方面 一方面是简单的闭环赛道只有直道和弯道 另一方面是毕设类型的包括一些元素 90度弯道 十字道路 S形弯道等 本篇博客试根据下图来进行书写的 如果大家有什么新的元素 也可以在下方评论 我进行更新 作者 sumjess 注
  • linux字符串转数字

    转载 https www cnblogs com baofengc p 9042128 html 方法一 echo 96 56 awk print int 0 输出结果 96 方法二 A 2 B 51 let C A B echo C 方法
  • static在c语言中的作用_C语言关键字 static 的用法

    接上文 C语言的32个关键字 C语言 static 关键字的常见用法有三种 用于局部变量的修饰符 用于全局变量的修饰符 用于函数的修饰符 1 用于局部变量的修饰符 当 static 用于修饰局部变量时 通常是在某个函数体内 只能在该函数内被
  • zabbix如何监控linux磁盘性能IO

    前提环境 perl和python 以及zabbix agent已是可用状态 需要主要监控的指标 1 每秒IO数 即iops或tps 2 吞吐率 3 平均IO尺寸 avgrq sz 4 IO等待队列长度 avgqu sz 5 磁盘活动时间百分
  • 阅人有术

    第一部分 阅人 人生的必修课 没有人能隐于世外 无论你走到哪里 都会碰到人 你必须与之相处 因为人无所不在 你必须了解人 因为你永远无法独自成功 不同的人每天都不得不重复着同一个古老而新鲜的游戏 与人打交道 这个游戏的古老在于 人类就是这样
  • Odoo Wizard界面显示带有复选框列表及勾选数据获取 Python

    Odoo Wizard界面显示带有复选框列表及勾选数据获取 Python 在Odoo应用程序中 Wizard 向导 是一种常用的界面元素 用于引导用户完成特定任务 在这篇文章中 我们将学习如何在Odoo的Wizard界面中显示带有复选框列表
  • GoFrame带你从0-1快速入门

    文章目录 GoFrame 带你从 0 1 快速入门 一 GoFrame介绍 1 1GF基本介绍 1 2GF特点 1 3GF地址 1 4GF框架 二 GoFrame基础环境搭建 2 1环境搭建 1 安装golang 2 安装goland 3
  • Java源码分析(二)Double

    本篇是源码分析的第二篇 上篇我们一起分析了Integer类的源码 本篇一起学习下Double类的源码 看下其实现 一 Double类图 首先 相比Integer Double类的源码只有1000 行代码 如下是Integer及其关联类 接口
  • Ubuntu 安装、卸载JDK

    JDK 介绍 Open JDK 和 Oracle JDK区别 OpenJDK是Java开发工具包的开源实现 Oracle JDK是Java开发工具包的官方Oracle版本 尽管OpenJDK已经足够满足大多数的案例 但是许多程序比如Andr
  • 【Java预科】CH01 MarkDown语法

    1 标题 空格 标题名字 空格 二级标题 越多字体越小 最多只到六级 一级标题 二级标题 三级标题 四级标题 五级标题 六级标题 七级标题不存在 2 文字 加粗 在目标文字前后加 斜体 在目标文字前后加 斜体 加粗 在目标文字前后加 删除线
  • IOException parsing XML document from ServletContext resource [/<NONE>]; closed - call ‘refresh‘

    问题描述 SpringMVC项目添加ContextLoaderListener后无法启动
  • Qt事件(Event)

    事件Event 1 事件的概述 2 通过QLabel了解事件的操作 3 重写事件 4 重写鼠标按下事件 5 获取鼠标按下或移动的坐标 6 查看的QMouseEvent的信息 7 判断button的返回值 8 判断鼠标的哪个按键按下 9 判断
  • java中的throwable异常和错误

    Java中有个java lang Throwable类 这个类是Java中所有异常和错误的基类 Throwable下有两个大类那就是异常 Exception 和错误 Error Throwable 有两个重要的子类 Exception 异常
  • mysql的docker镜像数据库初始化踩坑记

    一 制作docker镜像 在当前目录新建子目录script 将数据库初始化脚本拷贝进去 后缀名为 sql 脚本执行顺序是按字母大小排序 建议可以按 1 xxx sql 2 xxx sql这样命令 Dockerfile如下 FROM mysq