我已经为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中设置了一个码头图像:
但是在针对该图像中的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
但仍然没有成功。
任何人都知道如何克服这个问题?
答案 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