注意点1:
左面是原始的微服务架构,你要自己linux中搭建mysql、redis繁琐费事,右面是使用docker搭建的服务,直接docker run xx启动即可。
docker常规安装总体步骤
1)搜索镜像
2)拉取镜像
3)查看镜像
4)启动镜像
5)停止容器
6)移除容器
注意点1:
命令出处,哪里来的?
使用步骤:
1)使用mysql镜像
2)建库建表插入数据
3)外部Win10也来连接运行在dokcer上的mysql容器实例服务
4)思考问题
注意点1:
使用mysql镜像
docker run -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7
docker ps
docker exec -it 容器ID /bin/bash
mysql -uroot -p
注意点2:
建库建表插入数据
注意点3:
外部Win10也来连接运行在dokcer上的mysql容器实例服务
注意点4:
问题总结:
问题1:插入中文数据报错,为什么报错如图1? docker上默认字符集编码隐患?
docker里面的mysql容器实例查看,内容如下:
SHOW VARIABLES LIKE 'character%';
解决方案
:修改默认编码,使其支持中文写入
问题2:删除容器后,里面的mysql数据如何办?
解决方案
:启动mysql容器的是否配置数据卷。
注意点5:
启动mysql之前,执行命令 pes -ef |grep mysql
查看是否docker内已经启动mysql了,因为mysql默认端口3306,如果用户在linux环境下已经安装并启动一个mysql,而再运行docker run msql就会报错,会报端口被占用。
使用步骤:
1)新建mysql容器实例
2)新建my.cnf
3)重新启动mysql容器实例再重新进入并查看字符编码
4)再新建库新建表再插入中文测试
5)结论
6)假如将当前容器实例删除,再重新来一次,之前建的db01实例还有吗?trytry
注意点1:
新建mysql容器实例
docker run -d -p 3306:3306 --privileged=true -v /zzyyuse/mysql/log:/var/log/mysql -v /zzyyuse/mysql/data:/var/lib/mysql -v /zzyyuse/mysql/conf:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=123456 --name mysql mysql:5.7
注意点2:
新建my.cnf,通过容器卷同步给mysql容器实例
[client]
default_character_set=utf8
[mysqld]
collation_server = utf8_general_ci
character_set_server = utf8
注意点3:
重新启动mysql容器实例再重新进入并查看字符编码
注意点4:
再新建库新建表再插入中文测试
注意点5:
结论
之前的DB 无效
修改字符集操作+重启mysql容器实例
之后的DB 有效,需要新建
结论:docker安装完MySQL并run出容器后,建议请先修改完字符集编码后再新建mysql库-表-插数据
注意点6:
问题:假如将当前容器实例删除,再重新来一次,之前建的db01实例还有吗?
答案
:还是依然存在的