从零开始学docker(四)-安装mysql及主从配置(一)

mysql

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。

MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。

mysql架构图

引擎

MySQL中的存储引擎层主要负责数据的写入和读取,与底层的文件进行交互。值得一提的是,MySQL中的存储引擎是插件式的,服务器中的查询执行引擎通过相关的接口与存储引擎进行通信,同时,接口屏蔽了不同存储引擎之间的差异。MySQL中,最常用的存储引擎就是InnoDBMyISAM

mysql支持的引擎

查询数据库使用引擎命令:

sql 复制代码
show ENGINES;

查询存储引擎

sql 复制代码
mysql> show variables like '%storage_engine';
+---------------------------------+-----------+
| Variable_name                   | Value     |
+---------------------------------+-----------+
| default_storage_engine          | InnoDB    |
| default_tmp_storage_engine      | InnoDB    |
| internal_tmp_mem_storage_engine | TempTable |
+---------------------------------+-----------+
InnoDB与MyISAM的区别
特性 InnoDB MyISAM
事务安全 支持
存储限制 64TB
空间使用
内存使用
插入数据的速度
对外键的支持 支持

mysql安装

在docker容器中安装mysql数据库。

mysql挂载文件夹

在/usr/local/先创建software文件夹,再在software下创建mysql文件夹,文件结构如下

创建配置目录

shell 复制代码
 mkdir -p /usr/local/software/mysql

切换文件夹到mysql,并创建三个子文件夹,子文件夹中创建 conf, data 子文件夹

shell 复制代码
[root@localhost ~]# cd /usr/local/software/mysql
[root@localhost mysql]# pwd
/usr/local/software/mysql
[root@localhost mysql]# mkdir -p 3306/conf 3306/data
[root@localhost mysql]# mkdir -p 3310/conf 3310/data
[root@localhost mysql]# mkdir -p 3311/conf 3311/data
[root@localhost mysql]# ll
总用量 0
drwxr-xr-x. 4 root root 30 7月   2 11:11 3306
drwxr-xr-x. 4 root root 30 7月   2 11:08 3310
drwxr-xr-x. 4 root root 30 7月   2 11:09 3311

拷贝my.cnf文件到conf文件夹下

查询拉取mysql镜像

查询镜像

docker search mysql

拉取mysql镜像到本地(linux)

docker pull 镜像名称:版本号

复制代码
docker pull mysql

查询镜像检查是否已下载到本地

docker image ls

创建运行mysql主(master)容器

创建容器并运行
序列 参数 解释
1 -i 以交互模式运行容器
2 -t 为容器重新分配一个伪输入终端
3 --name 容器名称
4 --privileged 设置容器公开权限(默认为true)
5 -p :映射端口 容器内置端口(mysql默认端口为3306)
6 --network 自定义的docker网络名称
7 --ip 自定义网络中的ip地址
8 -v linux挂载文件夹/文件和容器内路径的映射
9 -e 容器的环境变量(设置mysql默认用户名&密码)
10 -d 后台运行容器,并返回容器ID

tips: ff_docket_net是之前自定义的docker网络。

并定义当前容器的ip是172.18.0.2(ip地址可以安装自定义的网络自行分配)。

shell 复制代码
docker run -it \
--name mysql_3306 \
--privileged \
-p 3306:3306 \
--network ff_docket_net \
--ip 172.18.0.2 \
-v /usr/local/software/mysql/3306/conf/my.cnf:/etc/mysql/my.cnf \
-v /usr/local/software/mysql/3306/data:/var/lib/mysql \
-v /usr/local/software/mysql/3306/mysql-files:/var/lib/mysql-files \
-e MYSQL_ROOT_PASSWORD=123 \
-d mysql
进入容器

进入容器实质上也是进入了一个linux环境。

docker exec

  • -it:以交互模式运行容器 ,为容器重新分配一个伪输入终端。
  • bash: bash(GNU Bourne-Again Shell)是最常用的一种shell(运行在终端的互动程序)。
shell 复制代码
 docker exec -it mysql_3306 bash
容器中运行mysql客户端

登录mysql客户端: mysql -u 用户名 -p密码

如果登录成功,则docker安装mysql成功。

查看容器内部ip

shell 复制代码
[root@localhost conf]# docker inspect mysql_3306 |grep IPA
            "SecondaryIPAddresses": null,
            "IPAddress": "",
                    "IPAMConfig": {
                    "IPAddress": "172.18.12.2",
退出容器,防火墙开放端口
退出容器

容器内: exit

shell 复制代码
root@1b32ebb973d1:/# exit
开放指定端口

firewall-cmd --zone=public --add-port=端口号/tcp --permanent

--zone: public 公开端口

--add-port: 端口号/协议名称

--permanent: 永久开放

shell 复制代码
firewall-cmd --zone=public --add-port=3306/tcp --permanent
重新加载防火墙

firewall-cmd --reload

shell 复制代码
 firewall-cmd --reload 
查看开放的端口号

firewall-cmd --

shell 复制代码
[root@localhost conf]# firewall-cmd --zone=public --list-ports 
3306/tcp
相关推荐
技术liul7 分钟前
Docker Compose和 Kubernetes(k8s)区别
docker·容器·kubernetes
篱笆院的狗8 分钟前
MySQL 中 SQL 语句的详细执行过程
数据库·sql·mysql
CoderCodingNo9 分钟前
【GESP】C++二级真题 luogu-B4259 [GESP202503 二级] 等差矩阵
java·c++·矩阵
佳腾_22 分钟前
【Web应用服务器_Tomcat】二、Tomcat 核心配置与集群搭建
java·前端·中间件·tomcat·web应用服务器
聂 可 以22 分钟前
IntelliJ IDEA修改实体类成员变量的名称(引入了该实体类的全部文件也会自动更新变量的名称)
java·ide·intellij-idea
冰茶_25 分钟前
C#中常见的设计模式
java·开发语言·microsoft·设计模式·微软·c#·命令模式
.似水42 分钟前
2025.4.22_C_可变参数列表
java·c语言·算法
禅与Bug的修复艺术44 分钟前
JAVA后端开发常用的LINUX命令总结
java·linux·面试·java面试·后端开发·java后端·面试经验
佩奇的技术笔记1 小时前
Java学习手册:Java开发常用的内置工具类包
java
triticale1 小时前
【蓝桥杯】P12165 [蓝桥杯 2025 省 C/Java A] 最短距离
java·蓝桥杯