Mac下docker安装MySQL8.0.34

学习并记录一下如何用docker部署MySQL

  1. 在Docker中搜索并下载MySQL8.0.x的最新版本

  2. 下载好后,在Images中就可以看到MySQL的镜像了

    通过下面的命令也可以查看

    bash 复制代码
    docker images
  3. 启动镜像,使用下面的命令就可以启动镜像了

    bash 复制代码
    docker run -itd --name mysql8.0.34 -p 3306:3306 --privileged=true -e MYSQL_ROOT_PASSWORD=root mysql:8.0.34

    解释:

    1. -i :即使没有连接,也要保持标准输入保持打开状态,一般与 -t 连用
    2. -t:分配一个伪tty,一般与 -i 连用
    3. -d:在后台运行容器,并且打印容器id
    4. --name:镜像名称
    5. -p:端口映射,容器内端口3306映射到容器外的3306上
    6. --privileged:为容器提供权限
    7. -e :设置镜像参数
      1. MYSQL_ROOT_PASSWORD:设置root用户的密码
  4. 此时,在容器内部已经初始化好了MySQL了,但是一般来说,我们需要把MySQL的配置文件和datadir挂在到docker外部,所以我们还需要后面的步骤

  5. 创建config和data目录

    bash 复制代码
    mkdir -p /Users/xxx/docker/data/mysql8.0.34/{config,data}
  6. 切换到config目录

    bash 复制代码
    cd /Users/xxx/docker/data/mysql8.0.34/config
  7. 把config文件从镜像内部复制出来

    bash 复制代码
    docker cp mysql8.0.34:/etc/my.cnf ./
  8. 确认config文件cat my.cnf

    复制代码
    # For advice on how to change settings please see
    # http://dev.mysql.com/doc/refman/8.0/en/server-configuration-defaults.html
    
    [mysqld]
    #
    # Remove leading # and set to the amount of RAM for the most important data
    # cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.
    # innodb_buffer_pool_size = 128M
    #
    # Remove leading # to turn on a very important data integrity option: logging
    # changes to the binary log between backups.
    # log_bin
    #
    # Remove leading # to set options mainly useful for reporting servers.
    # The server defaults are faster for transactions and fast SELECTs.
    # Adjust sizes as needed, experiment to find the optimal values.
    # join_buffer_size = 128M
    # sort_buffer_size = 2M
    # read_rnd_buffer_size = 2M
    
    # Remove leading # to revert to previous value for default_authentication_plugin,
    # this will increase compatibility with older clients. For background, see:
    # https://dev.mysql.com/doc/refman/8.0/en/server-system-variables.html#sysvar_default_authentication_plugin
    # default-authentication-plugin=mysql_native_password
    skip-host-cache
    skip-name-resolve
    datadir=/var/lib/mysql
    socket=/var/run/mysqld/mysqld.sock
    secure-file-priv=/var/lib/mysql-files
    user=mysql
    # 忽略表名大小写
    lower_case_table_names=1
    
    pid-file=/var/run/mysqld/mysqld.pid
    [client]
    socket=/var/run/mysqld/mysqld.sock
    
    !includedir /etc/mysql/conf.d/
  9. 停掉并删除之前启动的MySQL镜像

    bash 复制代码
    docker stop mysql8.0.34
    docker rm mysql8.0.34
  10. 重启MySQL

    bash 复制代码
    docker run -itd --name mysql8.0.34 -p 3306:3306 --privileged=true --restart=always -v /Users/xxx/docker/data/mysql8.0.34/data:/var/lib/mysql -v /Users/xxx/docker/data/mysql8.0.34/config/my.cnf:/etc/my.cnf -e MYSQL_ROOT_PASSWORD=root mysql:8.0.34
  11. 使用连接工具测试MySQL

相关推荐
爱宇阳8 分钟前
从容器化到自动化:Vue3 项目 Docker 部署与 GitLab CI/CD 集成 Harbor 全流程
docker·自动化·gitlab
高旭博14 分钟前
10. kubernetes资源——statefulset有状态负载
云原生·容器·kubernetes
_Walli_39 分钟前
k8s集群搭建(七)-------- 微服务间的调用
微服务·容器·kubernetes
马达加斯加D1 小时前
k8s --- resource: Pod, ReplicaSet and Deployment
云原生·容器·kubernetes
星光一影1 小时前
打车/网约车、代驾、顺风车/拼车、货运、租车等多种出行服务的一站式解决方案
mysql·微信小程序·php·uniapp·html5·web app
Jing_jing_X2 小时前
MySQL Server 启动后到底加载了什么,创建表插入数据到底怎么存的存在哪
mysql·adb
Java水解2 小时前
初识MYSQL —— 基本查询
后端·mysql
星光一影3 小时前
悬赏任务平台/拉新地推系统源码
redis·mysql·小程序·php·uniapp·html5
ejinxian4 小时前
Linux 虚拟化技术 KVM/ESXI/Docker
linux·运维·docker·qemu·openvz
LvLuffy4 小时前
mac Android Studio配置adb环境(使用adb报错 adb: command not found)
macos·adb·android studio