【四】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】
莫名其妙就好了
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
2月前
|
Ubuntu 关系型数据库 MySQL
MySQL源码编译安装
本文详细介绍了MySQL 8.0及8.4版本的源码编译安装全过程,涵盖用户创建、依赖安装、cmake配置、编译优化等步骤,并提供支持多Linux发行版的一键安装脚本,适用于定制化数据库部署需求。
327 4
MySQL源码编译安装
|
2月前
|
Ubuntu 关系型数据库 MySQL
MySQL二进制包安装
本文详细介绍了在多种Linux系统上通过二进制包安装MySQL 8.0和8.4版本的完整过程,涵盖用户创建、glibc版本匹配、程序解压、环境变量配置、初始化数据库及服务启动等步骤,并提供支持多发行版的一键安装脚本,助力高效部署MySQL环境。
322 4
MySQL二进制包安装
|
2月前
|
安全 关系型数据库 MySQL
MySQL包安装 -- SUSE系列(离线RPM包安装MySQL)
本文详细介绍在openSUSE系统上通过离线RPM包安装MySQL 8.0和8.4版本的完整步骤,包括下载地址、RPM包解压、GPG密钥导入、使用rpm或zypper命令安装及服务启动验证,涵盖初始密码获取与安全修改方法,适用于无网络环境下的MySQL部署。
409 3
MySQL包安装 -- SUSE系列(离线RPM包安装MySQL)
|
2月前
|
关系型数据库 MySQL Linux
MySQL包安装 -- SUSE系列(SUSE资源库安装MySQL)
本文介绍了在openSUSE系统上通过SUSE资源库安装MySQL 8.0和8.4版本的完整步骤,包括配置国内镜像源、安装MySQL服务、启动并验证运行状态,以及修改初始密码等操作,适用于希望在SUSE系列系统中快速部署MySQL的用户。
227 3
MySQL包安装 -- SUSE系列(SUSE资源库安装MySQL)
|
2月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
505 5
|
2月前
|
Java Linux 虚拟化
【Docker】(1)Docker的概述与架构,手把手带你安装Docker,云原生路上不可缺少的一门技术!
1. Docker简介 1.1 Docker是什么 为什么docker会出现? 假定您在开发一款平台项目,您的开发环境具有特定的配置。其他开发人员身处的环境配置也各有不同。 您正在开发的应用依赖于您当前的配置且还要依赖于某些配置文件。 您的企业还拥有标准化的测试和生产环境,且具有自身的配置和一系列支持文件。 **要求:**希望尽可能多在本地模拟这些环境而不产生重新创建服务器环境的开销 问题: 要如何确保应用能够在这些环境中运行和通过质量检测? 在部署过程中不出现令人头疼的版本、配置问题 无需重新编写代码和进行故障修复
385 2
|
Ubuntu 网络安全 数据安全/隐私保护
百度搜索:蓝易云【docker通过dockerfile安装sftp教程。】
现在,你已经通过 Dockerfile 成功安装了 SFTP,并且可以使用指定的用户名和公钥进行远程访问。请确保替换示例中的用户名、密码和公钥为自己的实际值。
343 1
|
消息中间件 Shell RocketMQ
百度搜索:蓝易云 ,常用环境部署—Docker安装RocketMQ教程!
通过按照上述步骤,您可以在Docker中成功安装和部署RocketMQ。请注意,上述命令仅提供了一个基本的安装和配置过程,具体配置和使用可以根据您的需求进行进一步调整。确保在执行命令之前,您已经安装并配置好Docker环境。
346 0
|
缓存 Linux Docker
【最新版正确姿势】Docker安装教程(简单几步即可完成)
之前的老版本Docker安装教程已经发生了变化,本文分享了Docker最新版安装教程,其他操作系统版本也可以参考官 方的其他安装版本文档。
11452 3
【最新版正确姿势】Docker安装教程(简单几步即可完成)