当前位置:   article > 正文

10分钟教你快速安装mysql_mysql_root_password=root

mysql_root_password=root

1. 前言

前提是已经安装docker,如果没安装请下载,几分钟即可安装完成,地址: www.docker.com/products/do…

2. 选择官方镜像

hub.docker.com/_/mysql/tag…

本文选择选择8.0版本

3.下载安装

  1. docker pull mysql:8.0
  2. 复制代码

  • 查看镜像

4. 启动

设置密码为root,容器名称为mysql

  1. docker run --name mysql -p 3306:3306 -v /data/mysql:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -d mysql:8.0
  2. 复制代码

4.1 参数说明

  • -p 3306:3306

    表示把容器端口映射到本地,如果不映射本地连接不上数据库,只能进入到容器里面连接

  • -v /data/mysql:/var/lib/mysql,

    数据文件目录,表示把容器/var/lib/mysql目录,映射到/data/mysql,这样不会因容器重新启动导致数据丢失

  • -e MYSQL_ROOT_PASSWORD=root

    表示mysql 密码为root

  • --name mysql

    表示容器名称为mysql

4.2 查看容器列表

5. 登录数据库

5.1 命令行方式

查看容器列表,容器ID为0a83ebe4baae

  1. docker exec -it 0a83ebe4baae /bin/bash
  2. 复制代码

5.2 本地navicat连接

本地通过navicat连接,会报如下错,原因是客户端不支持caching_sha2_password的密码加密方式。那么,我们修改用户密码加密方式为经典方式。

5.2.1 修改密码加密方式

  1. > mysql -u root -proot;
  2. > use mysql;
  3. > select user, host, plugin, authentication_string from user\G;
  4. > ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'root';
  5. 复制代码

5.2.2 再次登录

6.扩展篇

6.1 数据丢失测试

测试步骤

创建数据库,创建用户表,插入数据,关闭数据库,在次启动查看数据是否存在

6.1.1 创建测试数据

  1. create database test;
  2. use test;
  3. create table user(
  4. id int,
  5. age int,
  6. username varchar(20)
  7. )
  8. insert into user values(1,18,'张三');
  9. 复制代码

6.1.2 关闭数据库

0a83ebe4baae为容器id,通过docker ps查询

  1. docker stop 0a83ebe4baae
  2. 复制代码

查看容器是否启动

可以看到已经停止

6.1.3 再次启动

  1. docker restart mysql
  2. 复制代码

6.1.4 查看数据

执行如下命令可以看到数据依然存在,没有丢失

  1. docker exec -it 0a83ebe4baae /bin/bash
  2. mysql -uroot -proot;
  3. show databases;
  4. use test;
  5. select * from user
  6. 复制代码

6.2 图形化方式管理容器

下载链接:www.docker.com/products/do…

如果嫌命令行比较麻烦,可以通过docker desktop来管理,也是比较方便,可以看到提供了重启,删除,暂停等按钮

也可以点击容器,快速进入里面进行命令行

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/羊村懒王/article/detail/478000
推荐阅读
相关标签
  

闽ICP备14008679号