1. 首页
  2. 技术知识

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

目录

    开始安装vim

最近碰到程序员大离职,我并接下了别人的烂摊子。

修改docker中mysql的root账户的账号密码

所以记录一下

开始

登陆CentOs linux服务器后

  1. docker ps        //查看docker镜像

复制代码

进入镜像mysql镜像内部

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

复制代码


安装vim

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

  1. apt-get update
  2. apt-get install vim

复制代码 编辑配置文件

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

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

保存退出

  1. exit    # 退出容器

复制代码 重启mysql容器

  1. docker restart mysql

复制代码 再次进入容器

  1. docker exec -it mysql bash

复制代码 登录 mysql(无需密码)

  1. mysql -uroot

复制代码 更新权限

  1. flush privileges;

复制代码 修改密码

  1. alter user ‘root’@’localhost’ identified by ‘123456’;

复制代码 退出mysql

  1. exit

复制代码 注释“skip-grant-tables”

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

退出容器

  1. exit

复制代码 重启容器

  1. docker restart mysql

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

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

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

进入mysql镜像

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

复制代码 登陆mysql

  1. mysql -u root -p     输入刚刚修改的密码

复制代码

  1. mysql>use mysql;
  2. mysql>select ‘host’ from user where user=’root’;
  3. mysql>update user set host = ‘%’ where user =’root’;
  4. mysql>flush privileges;
  5. mysql>select ‘host’   from user where user=’root’;

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

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

那就删除掉localhost

到此这篇关于docker mysql修改root账号密码并赋予权限的文章就介绍到这了,更多相关docker mysql修改root 内容请搜索软件技术网以前的文章或继续浏览下面的相关文章希望大家以后多多支持软件技术网!

原创文章,作者:starterknow,如若转载,请注明出处:https://www.starterknow.com/109066.html

联系我们