访问被拒绝为竹子中的mysql docker图像

时间:2016-05-02 10:46:21

标签: mysql docker docker-compose bamboo

我已经为MySQL Docker镜像配置了这个配置:

mysqldata:
    image: busybox
    volumes:
      - /var/lib/mysql

mysql:
    image: mysql:5.6
    ports:
      - "8203:3306"
    volumes_from:
      - mysqldata
    environment:
      - "MYSQL_ALLOW_EMPTY_PASSWORD=yes"
      - "MYSQL_USER=root"

我用docker-compose up -d mysql解除了它,我可以在图像中对数据库运行命令,无问题地访问它等等。

然后我在Bamboo中设置了一个码头图像:

enter image description here

但是在针对该图像中的DB运行命令时失败了,错误:

ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)

从测试运行的构建日志中我可以看到应用了env变量:

/usr/bin/docker run --workdir /data --detach --name mysql-user-service -p 8203:3306 -e MYSQL_ALLOW_EMPTY_PASSWORD=yes -e MYSQL_USER=root mysql:5.6

但仍然没有成功。

任何人都知道如何克服这个问题?

1 个答案:

答案 0 :(得分:0)

你从哪里连接?主持人,另一个容器?

您是否授予用户@ localhost MySQL用户权限,以便它可以访问数据库?该错误通常意味着您正在连接的用户无权访问数据库,您需要授予权限。

如果您执行docker ps,您将看到为MySQL启动的容器的名称和ID。拿这个名字或ID然后运行

docker exec -it <name or id> sh

这会让你进入容器,你可以运行MySQL命令来授予这样的访问权限。

GRANT ALL ON *.* TO 'root'@'localhost

由于你正在使用compose,你也可以做这样的事情

docker-compose run mysql GRANT ALL ON *.* TO 'root'@'localhost

您可能还必须创建已经没有的数据库,并且您将使用相同的步骤只更改运行的SQL