我已经在asp.net核心EF中用MySql DB开发了一个应用程序。应用程序部署在上。我正在尝试将应用程序连接到同一个云项目下的云MySql。在本地,我能够连接这个数据库,但是当部署在google云上时,我会出错。
MySqlException:超时过期。操作完成前经过的超时时间或服务器没有响应。MySql.Data.Common.StreamCreator.GetTcpStream(MySqlConnectionStringBuilder设置)
MySqlException: Unable to connect to any of the specified MySQL hosts.**
我正在尝试使用云函数从GCP云MySQL数据库中获取数据。云函数是用Nodejs编写的。此函数正在进行查询,以便从数据库中获取数据。我已经创建了一个连接到函数和MySQL的无服务器VPC连接器。MYSQL启用了私有IP。但是,我得到以下错误:
错误:连接ETIMEDOUT在 at Object.onceWrapper (events.js:519:28) at Socket.emit (events.js:400:28) at Socket.emit (domain.js:537:15) at Socket._onTimeout (net.js:495:8) at listOnTimeout
代码是非常基本的。使用mysql的简单nodejs应用程序。当代码尝试连接到Google引擎上的google服务器(第二代)时,就会收到MySql。
但是,由于我的机器的MySql地址已被白化,应用程序可以从本地机器连接到IP服务器。
应用引擎应用程序和谷歌云服务器属于谷歌云控制台中的同一个项目。所以不需要额外的权限(?)
因此,我无法理解如何允许应用程序引擎访问MySql服务器。
var express = require('express'),
mysql = require('mysql'),
bodyParser = re