开发者社区> 胶囊仔> 正文

【四】Docker中安装MySql

简介: Docker中安装MySql
+关注继续查看
下载mysql镜像
【docker pull mysql/mysql-server:5.7.21】
持久数据和配置更改和初始化脚本

#################################################

Docker容器如果被删除或者损坏了,那么数据和配置就没拉。
查看官方说明https://dev.mysql.com/doc/refman/5.7/en/docker-mysql-more-topics.html官网文章说有两种方法保存数据和配置。
其中一种方法是在运行容器时绑定容器之外的主机目录和配置文件路径。
这样即时容器被删除但容器之外的文件还在。
以下这些文字直接引用的官方的:
下面命令将创建一个MySQL社区服务器容器并绑定数据目录和服务器配置文件和初始化脚本:
docker run --name=mysql1 \
--mount type=bind,src=/path-on-host-machine/my.cnf,dst=/etc/my.cnf \
--mount type=bind,src=/path-on-host-machine/datadir,dst=/var/lib/mysql \
--mount type=bind,src=/path-on-host-machine/scripts,dst=/docker-entrypoint-initdb.d \
-d mysql/mysql-server:tag
该命令使:
B1.主机的 path-on-host-machine/my.cnf文件绑定到/etc/my.cnf(容器内的服务器配置文件)
B2主机的path-on-host-machine/datadir目录 绑定到/var/lib/mysql(容器内的数据目录)。
B3.主机的path-on-host-machine/script目录绑定到/docker-entrypoint-initdb.d目录下。
(在数据库创建后将立即执行script目录下的脚本)
绑定安装必须满足以下条件:
数据目录 path-on-host-machine/datadir 必须已经存在。
要进行服务器初始化,目录必须为空。
配置文件 path-on-host-machine/my.cnf 必须已经存在,并且必须包含使用用户启动服务器的规范:
[mysqld]
user=mysql

#################################################
进入根目录
【cd /】 
一次性在根目录下面创建好mydocker和子目录mysql两个文件夹。(mkdir -p或者--parents 若路径中的某些目录尚不存在,将自动创建不存在的目录,即一次可以建立多个目录)
【mkdir -p /mydocker/mysql】
进入mysql目录。
【cd /mydocker/mysql】
创建config目录
【mkdir config】
创建data目录
【mkdir data】
进入config 目录。
【cd config】
创建my.cnf文件。
【vi my.cnf】
输入i进入编辑模式,输入如下内容:
[mysqld]
user=mysql
也还可以接着输入如下内容设置字符编码(可防止中文乱码问题等)
character-set-server=utf8mb4
[client]
default-character-set=utf8mb4
[mysql]
default-character-set=utf8mb4
(--引用自百度知道:MySQL在5.5.3之后增加了这个utf8mb4的编码,mb4就是most bytes 4的意思。专门用来兼容四字节的unicode。utf8mb4是utf8的超集。utf8应付日常使用完全没有问题,那为什么还要使用utf8mb4呢?Emoji 表情(Emoji 是一种特殊的 Unicode 编码,常见于 ios 和 android 手机上)和一些不常用的汉字,以及任何新增的 Unicode 字符等等,无法使用MySQL原有的 utf8字符集存储)按Esc键退出编辑模式,然后输入:wq保存并退出。

输入cat my.cnf再检查下这个文件。

进入mysql目录。
【cd /mydocker/mysql 】
在mysq目录下面创建好scripts文件夹。
【mkdir scripts 】
进入script目录。
【cd scripts】
输入vi abc.sql创建abc.sql脚本。
输入i进入编辑模式,
输入如下内容让root用户可以mysql_native访问(最后有个分号):
CREATE USER 'root'@'%' IDENTIFIED BY '密码';
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '密码';
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '密码';
grant all privileges on *.* to '用户名'@'%' with grant option;

按Esc键退出编辑模式,然后输入:wq保存并退出。

在docker中启动mysql镜像的实例时可使用 –e或—env来设置环境变量。
部分环境变量的说明如下:
MYSQL_RANDOM_ROOT_PASSWORD 默认为true,表示启动容器时会生成随机root帐户的密码
MYSQL_ONETIME_PASSWORD 默认为true,表示root帐户密码被设置为可过期。
MYSQL_USER 初始化一个新用户。
MYSQL_PASSWORD 初始化新用户的密码。
MYSQL_ROOT_PASSWORD 初始化root帐户的密码。
MYSQL_ROOT_HOST 默认localhost 表示 root帐户只允许本地登录。  %则表明不限ip

输入如下命令来启动mysql镜像实例   --restart=always 开机重启
【 docker run -d -p 3306:3306 --name mysql01   --restart=always -e MYSQL_PASSWORD=密码 -e MYSQL_ROOT_PASSWORD=密码 --mount type=bind,source=/mydocker/mysql/config/my.cnf,target=/etc/my.cnf --mount type=bind,source=/mydocker/mysql/data,target=/var/lib/mysql --mount type=bind,source=/mydocker/mysql/scripts,target=/docker-entrypoint-initdb.d  mysql/mysql-server:5.7.21】

【docker exec -it 容器名 /bin/bash】
【mysql -uroot -p】
输入密码
【use mysql】
加入防火墙
【firewall-cmd --zone=public --add-port=3306/tcp --permanent】

执行 报了个错--Error response from daemon: driver failed programming external connectivity on endpoint mysql01
【docker restart mysql01】
【pkill docker】
【iptables -t nat -F】
【ifconfig docker0 down】
【systemctl start docker.service】
莫名其妙就好了

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
如何设置阿里云服务器安全组?阿里云安全组规则详细解说
阿里云安全组设置详细图文教程(收藏起来) 阿里云服务器安全组设置规则分享,阿里云服务器安全组如何放行端口设置教程。阿里云会要求客户设置安全组,如果不设置,阿里云会指定默认的安全组。那么,这个安全组是什么呢?顾名思义,就是为了服务器安全设置的。安全组其实就是一个虚拟的防火墙,可以让用户从端口、IP的维度来筛选对应服务器的访问者,从而形成一个云上的安全域。
18586 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
27734 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,大概有三种登录方式:
12973 0
阿里云服务器安全组设置内网互通的方法
虽然0.0.0.0/0使用非常方便,但是发现很多同学使用它来做内网互通,这是有安全风险的,实例有可能会在经典网络被内网IP访问到。下面介绍一下四种安全的内网互联设置方法。 购买前请先:领取阿里云幸运券,有很多优惠,可到下文中领取。
21936 0
阿里云服务器ECS登录用户名是什么?系统不同默认账号也不同
阿里云服务器Windows系统默认用户名administrator,Linux镜像服务器用户名root
15295 0
阿里云服务器端口号设置
阿里云服务器初级使用者可能面临的问题之一. 使用tomcat或者其他服务器软件设置端口号后,比如 一些不是默认的, mysql的 3306, mssql的1433,有时候打不开网页, 原因是没有在ecs安全组去设置这个端口号. 解决: 点击ecs下网络和安全下的安全组 在弹出的安全组中,如果没有就新建安全组,然后点击配置规则 最后如上图点击添加...或快速创建.   have fun!  将编程看作是一门艺术,而不单单是个技术。
19982 0
+关注
6
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载