docker实战(一)安装mysql(支持中文,挂载数据文件等)

下面是一个实战版的docker mysql,实现了如下需求

  • 指定映射端口3306
  • 映射日志文件到本地磁盘
  • 硬盘数据文件到本地磁盘
  • 映射配置文件到本地磁盘
  • 能够插入中文字符
  • 大小写不明感
    具体的执行命令
docker run -d -p 3306:3306 --privileged=true  \
-v /data/mysql/log:/var/log/mysql \
-v /data/mysql/data:/var/lib/mysql \
-v /data/mysql/conf:/etc/mysql/conf.d \
-e MYSQL_ROOT_PASSWORD=123456 \
--name mysql mysql:5.7

命令解释

#使得容器内的root拥有真正的root权限
--privileged=true
#日志文件,挂载到本地磁盘/data/mysql/log,可自行定义路径
-v /data/mysql/log:/var/log/mysql  
#数据文件,挂载到本地磁盘/data/mysql/data,可自行定义路径
-v /data/mysql/data:/var/lib/mysql
#配置文件,挂载到本地磁盘/data/mysql/conf,可自行定义路径
-v /data/mysql/conf:/etc/mysql/conf.d
#定义mysql的root密码为123456
-e MYSQL_ROOT_PASSWORD=123456
#设置容器名字为mysql
--name mysql

下面开始修改配置文件

#修改mysql配置文件,打开本地对应的文件
vim /data/mysql/conf/my.cnf

贴入下面的代码,使得可以支持中文数据插入

[client]
default_character_set=utf8
[mysqld]
collation_server = utf8_general_ci
character_set_server = utf8
#表名大小写不明感,敏感为0
lower_case_table_names=1

重启mysql,使配置文件生效

docker restart mysql

现在数据库已经可以访问和使用了
如果是远程访问的话,别忘记开防火墙哦

下面是直接进入docker连接,并执行一些修改命令

#进入容器
docker exec -it mysql /bin/bash
#进入mysql
mysql -uroot -p123456
#修改mysql,支持远程访问,docker一般用不上
use mysql;
update user set user.Host='%' where user.User='root';
flush privileges;
#修改连接超时时间,一般用不上
show global variables like 'wait_timeout';
set global wait_timeout=800000;
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

atadmin

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值