Docker Compose--安装MySQL8的方法(实例)

原文网址:Docker Compose--安装MySQL8的方法(实例)_IT利刃出鞘的博客-CSDN博客

简介

本文介绍使用Docker compose安装MySQL8的方法。

Java技术星球:way2j.com

脚本及配置

目录结构

bash 复制代码
├── docker-compose.yml # docker-compose.yml文件
├── conf
│   └── my.cnf  # MySQL配置文件
├── data # 数据库数据文件目录
├── log # 日志存放目录
└── bak # 手动备份数据的目录

data、log不需要手动创建,在docker compose运行时会自动创建。

docker-compose.yml

bash 复制代码
version: '3.1'
services:
    mysqldb:
        # 启动方式
        #restart: unless-stopped
        
        # 镜像
        image: mysql:8.0
        # 容器名字
        container_name: mysql8
        privileged: true
        environment:
          # 时区
          TZ: Asia/Shanghai
          # root用户的密码
          MYSQL_ROOT_PASSWORD: 123456
          # 用户(不能是root, 后续需要给新用户赋予权限)
          MYSQL_USER: adminUser
          # 用户密码
          MYSQL_PASSWORD: 222333
        command:
          --character-set-server=utf8mb4
          --collation-server=utf8mb4_general_ci
          --explicit_defaults_for_timestamp=true
        ports:
          - 3306:3306
        volumes:
          - ./log/:/var/log/mysql/
          - ./data/:/var/lib/mysql/
          - ./conf/:/etc/mysql/conf.d/
          - ./bak/:/bak/

my.cnf(mysql配置文件)

bash 复制代码
[client]
default-character-set=utf8mb4
 
[mysql]
default-character-set=utf8mb4
 
[mysqld]
#服务端口号 默认3306
port=3306

# 数据路径,默认是/var/lib/mysql/
#datadir = /app/data/
 
init_connect='SET NAMES utf8mb4'
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci
 
# 最大连接数
max_connections=200
 
# 连接失败的最大次数。防止有人从该主机试图攻击数据库系统
max_connect_errors=20
 
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB

skip-name-resolve

# binlog过期天数。默认是0(永远存在)
expire_logs_days=2

运行docker compose

法1:到配置文件目录下运行

bash 复制代码
docker compose up

会打印详细启动日志,而且会占用控制台。

后台运行的方法:

bash 复制代码
docker compose up -d

-d:在后台运行。

法2:指定配置文件

bash 复制代码
docker compose -f /work/docker/docker-compose/mysql/docker-compose.yml up

docker compose的启动、停止等命令,全都是这样的,要么在配置文件目录下执行,要么指定配置文件。

查看运行结果

compose查看

bash 复制代码
docker compose ls

docker查看

bash 复制代码
docker ps

给用户赋予权限

进到MySQL这个docker中

bash 复制代码
docker exec -it mysql8 bash

连接到MySQL服务

bash 复制代码
mysql -uroot -p

回车后输入密码:123456,然后再回车即可。

授予所有权限

bash 复制代码
GRANT ALL ON *.* TO 'adminUser'@'%';

刷新权限

bash 复制代码
FLUSH PRIVILEGES;

停止容器

bash 复制代码
docker compose stop

停止容器,但不删除容器。

启动容器

bash 复制代码
docker compose start 

删除容器

法1:rm

bash 复制代码
docker compose rm

只删除容器

法2:down

bash 复制代码
docker compose down

停止容器,然后删除容器。

相关推荐
蘼子4 分钟前
Windows装Docker至D盘/其他盘(最新,最准确,直接装)
windows·docker·容器
一只鹿鹿鹿18 分钟前
数据治理文档(word原件)
java·运维·spring boot·后端
暴力求解28 分钟前
Linux--进程(七)环境变量
linux·运维·服务器
tod11333 分钟前
Redis Sentinel 高可用架构:从原理到 Docker 部署全解析
数据库·redis·docker·架构·sentinel
Doro再努力40 分钟前
【Linux操作系统14】操作系统概念与管理思想深度解析
linux·运维·服务器
Trouvaille ~41 分钟前
【Linux】poll 多路转接:select 的改良版,以及它留下的遗憾
linux·运维·服务器·操作系统·select·poll·多路复用
没有bug.的程序员44 分钟前
本地开发环境优化深度实战:Docker Compose 编排内核、依赖服务治理与极速环境搭建指南
运维·docker·容器·compose·本地开发·编排内核·依赖服务治理
Doro再努力1 小时前
【Linux操作系统13】GDB调试进阶技巧与冯诺依曼体系结构深度解析
linux·运维·服务器
予枫的编程笔记1 小时前
【Docker高级篇】吃透容器编排:Swarm vs K8s 核心差异,为后续K8s学习打牢基础
docker·云原生·kubernetes·linux内核·容器编排·容器技术·运维技术
袁袁袁袁满1 小时前
Linux如何保留当前目录本身并清空删除目录内的所有内容(文件+文件夹)?
linux·运维·服务器·清空删除目录内的所有内容