我正在尝试配置一个nodejs容器以连接到mysql数据库。
我的代码如下所示:
var pool = mysql.createPool({
host : 'mysql',
port : '3306',
user : 'root',
password : '...',
database : 'general',
connectionLimit : 50,
queueLimit : 5000
});
我正在使用标准的 mysql 容器。
我正在使用无花果来启动容器。 fig.yml看起来像这样:
node:
build: node
ports:
- "9000:9000"
- "9001:9001"
links:
- mysql:mysql
command: node server/Main.js
mysql:
image: mysql
volumes:
- /data/test:/var/lib/mysql
environment:
MYSQL_ROOT_PASSWORD: ...
每次尝试连接时,都会收到以下错误:
failed to connect to database: Error: ER_HOST_NOT_PRIVILEGED: Host '172.17.0.142' is not allowed to connect to this MySQL server
知道我做错了什么吗?我已经玩过wordpress,它似乎可以毫无问题地连接到同一个mysql db。
感谢!
编辑所以,我最终找到了答案。问题确实是一个特权问题。我运行了以下命令:
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'password'
我能够访问数据库。
我使用drakedroid/mysql-with-data (https://registry.hub.docker.com/u/drakedroid/mysql-with-data/)图像。 它扩展了默认映像,但添加了更多功能。