首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >从Heroku上的Node.js连接到CloudSQL

从Heroku上的Node.js连接到CloudSQL
EN

Stack Overflow用户
提问于 2019-12-12 15:33:59
回答 1查看 474关注 0票数 1

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

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

我尝试使用与Heroku的Workbench相同的主机、端口、用户和pass,但它不起作用。为了简单起见,我暂时允许所有网络连接(0.0.0.0/0),并允许非SSL连接。

下面是错误:ER_ACCESS_DENIED_ERROR: Access denied for user 'usernamehere'@'xx.xxx.xxx.xx' (using password: YES)"

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

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

代码语言:javascript
运行
复制
import Knex = require('knex');
const envConfig = require('../config/environments').get(process.env.NODE_ENV);
module.exports = knex;
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-12-14 17:43:26

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

代码语言:javascript
运行
复制
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',
    },
});
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59299695

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档