docker mysql怎么修改root账号密码并赋予权限

开始

登陆centos linux服务器后

docker ps        //查看docker镜像

docker mysql怎么修改root账号密码并赋予权限

进入镜像mysql镜像内部

 docker exec -it 镜像id或者镜像别名   /bin/bash   //进入docker内部镜像

docker mysql怎么修改root账号密码并赋予权限

安装vim

因为docker镜像内部没有带vim命令,所以需要手动安装,也可以利用docker cp命令从宿主机中复制过去 

apt-get updateapt-get install vim

编辑配置文件

vim /etc/mysql/mysql.conf.d/mysqld.cnf

需要加入“skip-grant-tables”  按i     cv加入”skip-grant-tables”     按esc   然后:wq!

docker mysql怎么修改root账号密码并赋予权限

 保存退出

exit    # 退出容器

重启mysql容器

docker restart mysql

再次进入容器

docker exec -it mysql bash

登录 mysql(无需密码)

mysql -uroot

更新权限

flush privileges;

修改密码

alter user 'root'@'localhost' identified by '123456';

退出mysql

exit

注释“skip-grant-tables” 

 需要注释“skip-grant-tables”  按i  按esc   然后:wq!

 退出容器

exit

重启容器

docker restart mysql

 如果内部能访问,Navicat等访问不了,那么执行把mysql权限开放

错误:ERROR 1130: Host ‘ip’ is not allowed to connect to thisMySQL serve

原因:被连接的数据不允许使用 ip 访问,只允许是用 localhost;

进入mysql镜像

 docker exec -it 镜像id或者镜像别名   /bin/bash   //进入docker内部镜像

登陆mysql 

mysql -u root -p     输入刚刚修改的密码
mysql>use mysql;mysql>select 'host' from user where user='root';mysql>update user set host = '%' where user ='root';mysql>flush privileges;mysql>select 'host'   from user where user='root';

如果还是不行那就是有多个root权限 更新权限

update user set password=password(“root”) where user=”root”; 如果报已有主键id

那就删除掉localhost

以上就是docker mysql怎么修改root账号密码并赋予权限的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/148698.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月2日 21:40:39
下一篇 2025年12月2日 21:45:58

相关推荐

发表回复

登录后才能评论
关注微信