提问者:小点点

从Heroku上的Node. js连接到CloudSQL


我有一个Node. js应用程序(在AppEngine上运行)连接到一个GCPCloudSQL(MySQL)实例。现在我想从运行在Heroku上的Node.js(Kney)连接到同一个数据库。

从AppEngine,Node. js通过用户/密码和socket Path连接。我还通过主机IP(SSL)从MySQL工作台连接到相同的MySQLDB。

我正在尝试使用与Heroku工作台相同的主机、端口、用户和通行证,但它不起作用。为了简化,我暂时允许所有网络连接(0.0.0.0/0),并允许非SSL连接。

以下是错误:ER_ACCESS_DENIED_ERROR:用户'usernamehere'@'xx.xxx.xxx. xx'的访问被拒绝(使用密码:是)"

环境变量存储在Heroku应用程序中,它们必须正常工作,因为用户名是正确的。

这不是很有帮助,但这是代码:

import Knex = require('knex');
const envConfig = require('../config/environments').get(process.env.NODE_ENV);
module.exports = knex;

共1个答案

匿名用户

我发现解决此问题的唯一方法是通过SSL连接到CloudSQL。

const mysql = require("mysql");
const fs = require('fs');
const knex = require('knex')({
    client: 'mysql',
    version: '5.7',
    connection: {
      host : 'xx.xx.xx.xx',
      ssl: {
        ca: fs.readFileSync('ca.pem'),
        key: fs.readFileSync('client-key.pem'),
        cert: fs.readFileSync('client-cert.pem'),
      },
      user : 'root',
      password : 'xxxxxxxxx',
      database : 'mydbname',
    },
});