Docker 安装 MySQL 并实现远程连接教程
拉取镜像
dockerpullmysql
查看拉取完成的镜像
dockerimages
通过镜像创建并启动一个MySQL容器
dockerrun--namemysql_dev-eMYSQL_ROOT_PASSWORD=123456-p3333:3306-dmysql
–name:给新创建的容器命名,此处命名为mysql_dev
-e:配置信息,此处配置mysql的root用户的登陆密码
-p:端口映射,此处映射主机3333端口到容器mysql_dev的3306端口
-d:成功启动容器后输出容器的完整ID\最后一个mysql指的是mysql镜像名字此时,用navicatformysql连接mysql发现报错:
Clientdoesnotsupportauthenticationprotocolrequestedbyserver。。。
解决再最下面^_^
查看安装的所有容器
dockerps-a
查看启动中的容器
dockerps
暂停/启动容器中的服务
dockerstopmysql_dev dockerstartmysql_dev
进入容器
dockerexec-itmysql_devbash
查看容器中服务的IP
dockerexec-itmysql_devcat/etc/hosts
新版MySQL授权用户时报错near'IDENTIFIEDBY'密码'withgrantoption'atline1
1问题:
当使用grant权限列表on数据库to'用户名'@'访问主机'identifiedby'密码';时会出现"......near'identifiedby'密码''atline1"这个错误
2原因:
因为新版的的mysql版本已经将创建账户和赋予权限的方式分开了
3解决办法:
创建账户:createuser'用户名'@'访问主机'identifiedby'密码';
赋予权限:grant权限列表on数据库to'用户名'@'访问主机';(修改权限时在后面加withgrantoption)
4具体操作:
#添加用户 CREATEUSER'mysql_dev'IDENTIFIEDBY'123456'; #赋予权限 GRANTALLPRIVILEGESON*.*TO'mysql_dev'@'%'; #修改加密规则 ALTERUSER'mysql_dev'@'%'IDENTIFIEDBY'123456'PASSWORDEXPIRENEVER; #更新一下用户的密码 ALTERUSER'mysql_dev'@'%'IDENTIFIEDWITHmysql_native_passwordBY'123456'; #更新配置信息 FLUSHPRIVILEGES;
以上就是Docker安装MySQL并实现远程连接教程的详细内容,更多关于Docker安装MySQL并远程连接的资料请关注毛票票其它相关文章!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。