zoukankan      html  css  js  c++  java
  • Docker 安装 MySQL 并实现远程连接

    拉取镜像

    docker pull mysql
    

    查看拉取完成的镜像

    docker images
    

    通过镜像创建并启动一个MySQL容器

    docker run --name mysql_dev -e MYSQL_ROOT_PASSWORD=123456 -p 3333:3306 -d mysql
    

    –name:给新创建的容器命名,此处命名为 mysql_dev
    -e:配置信息,此处配置mysql的root用户的登陆密码
    -p:端口映射,此处映射主机3333端口到容器mysql_dev的3306端口
    -d:成功启动容器后输出容器的完整ID最后一个mysql指的是mysql镜像名字

    此时,用navicat for mysql连接mysql发现报错:
    Client does not support authentication protocol requested by server。。。
    解决再最下面 ^ _ ^

    查看安装的所有容器

    docker ps -a
    

    查看启动中的容器

    docker ps
    

    暂停/启动容器中的服务

    docker stop mysql_dev
    docker start mysql_dev
    

    进入容器

    docker exec -it mysql_dev bash
    

    查看容器中服务的IP

    docker exec -it mysql_dev cat /etc/hosts
    

    新版 MySQL 授权用户时报错 near 'IDENTIFIED BY '密码' with grant option' at line 1

    1 问题:
    当使用 grant 权限列表 on 数据库 to '用户名'@'访问主机' identified by '密码'; 时会出现"......near 'identified by '密码'' at line 1"这个错误
    2 原因:
    因为新版的的mysql版本已经将创建账户和赋予权限的方式分开了
    3 解决办法:
    创建账户:create user '用户名'@'访问主机' identified by '密码';
    赋予权限:grant 权限列表 on 数据库 to '用户名'@'访问主机' ;(修改权限时在后面加with grant option)
    4 具体操作:
    # 添加用户
    CREATE USER 'mysql_dev' IDENTIFIED BY '123456';
    # 赋予权限
    GRANT ALL PRIVILEGES ON *.* TO 'mysql_dev'@'%';
    # 修改加密规则 
    ALTER USER 'mysql_dev'@'%' IDENTIFIED BY '123456' PASSWORD EXPIRE NEVER;
    # 更新一下用户的密码
    ALTER USER 'mysql_dev'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
    # 更新配置信息
    FLUSH PRIVILEGES;
    
  • 相关阅读:
    翻转链表——链表
    Hadoop 2.2.0和HBase-0.98 安装snappy
    【POJ 1850】 Code
    Google翻译PDF文档
    leetcode第一刷_Reverse Linked List II
    linux之SQL语句简明教程---AND OR
    spring实战三装配bean之Bean的作用域以及初始化和销毁Bean
    spring实战一:装配bean之注入Bean属性
    系统启动时,spring配置文件解析失败,报”cvc-elt.1: 找不到元素 'beans' 的声明“异常
    阿里云ECS(云服务器)之产品简介
  • 原文地址:https://www.cnblogs.com/laowenBlog/p/13579665.html
Copyright © 2011-2022 走看看