docker安装mysql8.0

本文详细介绍了如何使用Docker来安装和配置MySQL,包括拉取镜像、启动容器、配置my.cnf文件以及使用docker-compose进行安装。此外,还提到了防火墙端口的开放方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、使用docker命名直接安装

1、拉取镜像

# 拉取最新版本的镜像命令
docker pull mysql

# 拉取指定版本的镜像命令
docker pull mysql:8.0

2、拉起镜像

# 不挂载路径拉起镜像命令
docker run -id --name mysql  -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 --restart=always mysql:8.0

# 挂载路径拉起镜像

docker run -p 3307:3306 --name mysql8 \
-v /home/docker-mysql/log:/var/log/mysql \
-v /home/docker-mysql/data:/var/lib/mysql \
-v /home/docker-mysql/conf/my.cnf:/etc/my.cnf \
-v /home/docker-mysql/mysql-files:/var/lib/mysql-files \
-e MYSQL_ROOT_PASSWORD=123456 \
--restart=always \
-d mysql:8.0

3、my.cnf 文件配置样例

[mysqld]
user=mysql
character-set-server=utf8mb4
# 库名和表名大小写不铭感设置
lower_case_table_names=1
default_authentication_plugin=mysql_native_password
secure_file_priv=/var/lib/mysql
expire_logs_days=7
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
max_connections=1000
 
[client]
default-character-set=utf8mb4
 
[mysql]
default-character-set=utf8mb4

二、使用docker-compose命令安装

1、docker-compose文件内容

# docker-compose.yml文件的版本
version: "3"
# 管理的服务
services:
  mysql:
    image: mysql:8.0.30
    container_name: mysql8
    environment:
      - TZ="Asia/Shanghai"
      - LANG=en_US.UTF-8
      - LANGUAGE=en_US:en
      - MYSQL_ROOT_PASSWORD=123456
    healthcheck:
      test: ["CMD", "mysqladmin" ,"ping", "-h", "localhost", "-uroot", "-p123456"]
      interval: 5s
      timeout: 3s
      retries: 10
    # 初始化环境  
    # env_file:
      # - /home/docker-mysql/conf/mysql.env
    ports:
      - 3307:3306
    volumes:
      - "/home/docker-mysql/conf/my.cnf:/etc/my.cnf"
      - "/home/docker-mysql/log:/var/log/mysql"
      - "/home/docker-mysql/data:/var/lib/mysql"
      - "/home/docker-mysql/mysql-files:/var/lib/mysql-files"
      # 初始化脚本运行路径
      # - “/home/docker-mysql/bin/mysql:/docker-entrypoint-initdb.d”
    restart: always

2、运行docker-compose文件

# 保存步骤1中的文件,并命名为docker-compose-mysql8.yml
# 进入yml文件所在目录,并运行下列命令
docker-compose -f ./docker-compose-mysql8.yml up -d

三、开放防火墙端口

  • 查看防火墙某个端口是否开放
    firewall-cmd --query-port=80/tcp

  • 开放防火墙端口80
    firewall-cmd --zone=public --add-port=80/tcp --permanent

  • 关闭80端口

    firewall-cmd --zone=public --remove-port=80/tcp --permanent

  • 配置立即生效

    firewall-cmd --reload

  • 开放一段端口
    firewall-cmd --zone=public --add-port=8121-8124/tcp --permanent

  • 查看开放的端口列表
    firewall-cmd --zone=public --list-ports

### 使用 Docker 安装 MySQL 8.0 的教程 #### 准备工作 确保已经成功安装 Docker。如果尚未完成此操作,在某些操作系统上可能还需要更新 WSL,可以通过 `wsl --update` 命令来实现[^3]。 #### 拉取 MySQL 镜像 为了获取特定版本的 MySQL 8.0 镜像,可以使用如下命令: ```bash docker pull mysql:8.0.20 ``` 这会从官方仓库中下载指定版本的 MySQL 镜像文件到本地环境之中。 对于希望使用华为云容器镜像服务中的 Bitnami 版本,则应采用以下指令集: ```bash docker pull swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/bitnami/mysql:8.0.33 docker tag swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/bitnami/mysql:8.0.33 mysql:8.0.33 ``` 上述命令不仅能够拉取所需镜像,还会创建一个新的标签以便于后续管理与调用[^2]。 #### 启动 MySQL 容器实例 启动新创建的 MySQL 数据库服务器实例时,建议设置必要的环境变量以及挂载卷用于持久化存储数据。下面是一个简单的例子说明如何运行带有自定义配置选项的服务端口映射至主机上的方式: ```bash docker run -d \ --name=mysql-server \ -e MYSQL_ROOT_PASSWORD=your_password_here \ -p 3306:3306 \ -v /path/to/data:/var/lib/mysql \ mysql:8.0.20 ``` 这里 `-d` 参数表示以后台模式启动;`--name` 给定容器名称方便识别;`-e` 设置根用户密码;而 `-p` 则指定了外部访问端口号;最后通过 `-v` 将宿主机路径绑定到容器内部位置以保存数据库资料。 #### 自定义配置文件应用 如果有特殊需求想要修改默认参数或者优化性能表现的话,还可以准备一份 `.cnf` 文件并通过下述方法将其复制进入正在运行着的目标容器里边覆盖原有设定: ```bash docker cp /tmp/my.cnf <container_id_or_name>:/etc/mysql/my.cnf ``` 请注意替换 `<container_id_or_name>` 成实际存在的 ID 或者名字即可生效[^4]。 停止已有的 MySQL 实例可利用这条语句达成目的: ```bash docker stop mysql8.0 ``` 该命令将会终止名为 `mysql8.0` 的进程运作状态[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

杉叔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值