【四】Docker中安装MySql

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 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】
莫名其妙就好了
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
3天前
|
关系型数据库 MySQL Linux
Linux联网安装MySQL Server
Linux联网安装MySQL Server
13 0
|
3天前
|
关系型数据库 MySQL Linux
centos7安装mysql-带网盘安装包
centos7安装mysql-带网盘安装包
33 2
|
7天前
|
时序数据库 Docker 容器
Docker安装InfluxDB
Docker安装InfluxDB
10 0
|
7天前
|
关系型数据库 MySQL 数据库
Docker安装MySQL
Docker安装MySQL
14 1
|
7天前
|
关系型数据库 MySQL 数据安全/隐私保护
MySQL 安装及连接
MySQL 安装及连接
25 0
|
10天前
|
关系型数据库 MySQL 数据库
docker自定义安装mysql 5.7
docker自定义安装mysql 5.7
19 0
|
4月前
|
关系型数据库 MySQL 数据库
使用 Docker 安装 MySQL 8
使用 Docker 安装 MySQL 8
243 3
|
4月前
|
关系型数据库 MySQL 容器
docker-compose安装mysql并指定忽略表名大小写以及挂载配置文件
docker-compose安装mysql并指定忽略表名大小写以及挂载配置文件
122 0
docker-compose安装mysql并指定忽略表名大小写以及挂载配置文件
|
1月前
|
NoSQL 关系型数据库 MySQL
Docker安装详细步骤及相关环境安装配置(mysql、jdk、redis、自己的私有仓库Gitlab 、C和C++环境以及Nginx服务代理)
Docker安装详细步骤及相关环境安装配置(mysql、jdk、redis、自己的私有仓库Gitlab 、C和C++环境以及Nginx服务代理)
195 0
|
1月前
|
关系型数据库 MySQL Docker
Docker安装和使用MySQL
Docker安装和使用MySQL
60 0