使用 docker-compose 运行 MySQL

使用 docker-compose 运行 MySQL

目录结构

.
│  .env
│  docker-compose.yml
│
└─mysql
    ├─config
    │      my.cnf
    │
    └─data

mysql 目录下的 data 为数据目录,mysql 的数据表、二进制日志文件就在这里。.env 文件包含了一些变量,这些变量能够在 docker-compose.yml 文件中经过 ${variable_name} 来引用。mysql

  • 固然也能够把 mysql 的目录放到其它地方,这里图个方便,直接放在 yml 文件同级目录了。

.env 文件

MYSQL_ROOT_PASSWORD=root
MYSQL_ROOT_HOST=%

MYSQL_DIR=./mysql
MySQL 配置文件 my.cnf
[mysqld]
character-set-server=utf8mb4
default-time-zone='+8:00'
innodb_rollback_on_timeout='ON'
max_connections=500
innodb_lock_wait_timeout=500
  • 若是使用默认配置,这个文件能够省略。

docker-compose.yml

version: '3'

services:

  mysql-db:
    container_name: mysql-docker        # 指定容器的名称
    image: mysql:8.0                   # 指定镜像和版本
    ports:
      - "3306:3306"
    environment:
      MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD}
      MYSQL_ROOT_HOST: ${MYSQL_ROOT_HOST}
    volumes:
      - "${MYSQL_DIR}/data:/var/lib/mysql"           # 挂载数据目录
      - "${MYSQL_DIR}/config:/etc/mysql/conf.d"      # 挂载配置文件目录

Environment 变量

MYSQL_ROOT_PASSWORD :这个不用解释,root 用户的密码。
MYSQL_USERMYSQL_PASSWORD :这两个变量为可选,建立一个新用户,这个用户在 MYSQL_DATABASE 变量指定的数据库上拥有超级用户权限。
MYSQL_DATABASE :指定一个数据库,在容器启动时建立。
MYSQL_ALLOW_EMPTY_PASSWORD :设置为 yes 容许 root 用户的密码为空。(不推荐)
MYSQL_RANDOM_ROOT_PASSWORD :设置为 yes 将在容器启动时为 root 用户生成一个随机的密码,密码会显示到标准输出流(GENERATED ROOT PASSWORD:......)。
MYSQL_ONETIME_PASSWORD :字面意思就是一次性密码,为 root 用户设置,第一次登陆后必须修改密码(仅支持 5.6 以上的版本)。sql

运行容器

在 docker-compose.yml 目录下执行:docker

docker-compose up数据库

若是要在后台运行,使用 docker-compose up -d命令行

中止容器:日志

docker-compose downcode

若是是前台运行的,使用:Ctrl + C 中止。这两种方式在中止后都会删除容器,下次启动必须使用 up 命令。server

中止但不删除容器:it

docker-compose stopio

使用 stop 中止后,再次启动使用 start 命令便可。

docker exec-it mysql-docker sh
经过命令行链接到 容器

  • i 保持容器打开
  • t 产生一个伪终端
相关文章
相关标签/搜索