从零开始学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
相关推荐
小黄编程快乐屋1 小时前
各个排序算法基础速通万字介绍
java·算法·排序算法
材料苦逼不会梦到计算机白富美3 小时前
贪心算法-区间问题 C++
java·c++·贪心算法
kaiyuanheshang5 小时前
docker 中的entrypoint和cmd指令
运维·docker·容器·cmd·entrypoint
Python私教6 小时前
除了 Docker,还有哪些类似的容器技术?
运维·docker·容器
小小李程序员7 小时前
LRU缓存
java·spring·缓存
cnsxjean7 小时前
SpringBoot集成Minio实现上传凭证、分片上传、秒传和断点续传
java·前端·spring boot·分布式·后端·中间件·架构
hadage2337 小时前
--- stream 数据流 java ---
java·开发语言
xnuscd7 小时前
Milvus概念
数据库·学习·mysql
《源码好优多》7 小时前
基于Java Springboot汽配销售管理系统
java·开发语言·spring boot
杨浦老苏7 小时前
开源无代码网络数据提取平台Maxun
低代码·docker·群晖