簡體   English   中英

ETIMEOUT 錯誤 | 谷歌雲 SQL 數據庫與 NodeJS

[英]ETIMEOUT error | Google Cloud SQL database with NodeJS

我在谷歌雲上創建了一個 mysql 數據庫,我想從一個單獨的節點 web 應用程序(也在谷歌雲上運行)訪問它。 我首先在我的計算機上本地測試連接,當我在本地運行以下代碼時,我可以成功建立與我的數據庫的連接並查看其中的數據。

'use strict';

// [START app]
const express = require('express');
const bodyParser = require('body-parser');
const path = require('path');
const app = express();
const mysql      = require('mysql');

var connection = mysql.createConnection({
  host     : 'Cloud SQL IP',
  user      : 'username',
  password  : 'password',
  database  : 'db_name'
});



// parse application/x-www-form-urlencoded
app.use(bodyParser.urlencoded({ extended: false }))

// parse application/json
app.use(bodyParser.json())

// Make globals.js accessible
app.use(express.static(__dirname + '/'));


app.get('/', (req, res) => {
    connection.connect();

    connection.query('SELECT * FROM Users', function (error, results, fields) {
        if (error) throw error;
        console.log(results);
    });

    connection.end();
    res.status(200).send('Hello World!');
});

app.get('/login', (req, res) => {
    res.status(200).send();
});

// [START server]
const PORT = process.env.PORT || 8080;
app.listen(PORT, () => {
  console.log(`App listening on port ${PORT}`);
  console.log('Press Ctrl+C to quit.');
});
// [END app]

但是,當在我的谷歌應用程序引擎中運行相同的代碼時(在端口 8080 上調試和完全部署在https://myapp.appspot.com上)我收到以下超時錯誤:

{ Error: connect ETIMEDOUT
    at Connection._handleConnectTimeout         (/home/megan_cooper2900/project/node_modules/mysql/lib/Connection.js:419:13)
at Socket.g (events.js:292:16)
at emitNone (events.js:86:13)
at Socket.emit (events.js:185:7)
at Socket._onTimeout (net.js:338:8)
at ontimeout (timers.js:386:14)
at tryOnTimeout (timers.js:250:5)
at Timer.listOnTimeout (timers.js:214:5)
--------------------
at Protocol._enqueue (/home/megan_cooper2900/project/node_modules/mysql/lib/protocol/Protocol.js:145:48)
at Protocol.handshake (/home/megan_cooper2900/project/node_modules/mysql/lib/protocol/Protocol.js:52:23)
at Connection.connect (/home/megan_cooper2900/project/node_modules/mysql/lib/Connection.js:130:18)
at app.get (/home/megan_cooper2900/journeyma/app.js:31:13)
at Layer.handle [as handle_request] (/home/megan_cooper2900/project/node_modules/express/lib/router/layer.js:95:5)
at next (/home/megan_cooper2900/project/node_modules/express/lib/router/route.js:137:13)
at Route.dispatch (/home/megan_cooper2900/project/node_modules/express/lib/router/route.js:112:3)
at Layer.handle [as handle_request] (/home/megan_cooper2900/project/node_modules/express/lib/router/layer.js:95:5)
at     /home/megan_cooper2900/project/node_modules/express/lib/router/index.js:281:22
    at Function.process_params         (/home/megan_cooper2900/project/node_modules/express/lib/router/index.js:335:12)
  errorno: 'ETIMEDOUT',
  code: 'ETIMEDOUT',
  syscall: 'connect',
  fatal: true }

為什么這不適用於 Google App Engine 應用程序?

在 mysql 的連接配置中, host在 App Engine 上不起作用。 您必須使用socketPath socketPath 是要連接到的 unix 域套接字的路徑。 使用時主機和端口被忽略。 (從在 App Engine flex 上使用 Loopback 轉移知識。這讓我頭疼了好幾天,哈哈)。 它的值是您的 Cloud SQL 實例連接名稱

所以在你的情況下,它應該是這樣的:/cloudsql/my-project-12345:us-central1:mydatabase

var connection = mysql.createConnection({
  socketPath     : '/cloudsql/my-project-12345:us-central1:mydatabase',
  user      : 'username',
  password  : 'password',
  database  : 'db_name'
});

如果您在 GCloud 上使用 Postgres,這是一個類似的過程, 這里有答案

我也確實遇到了同樣的問題,我正在使用 Kubernetes pod 來訪問我的 CloudSQL 實例。 我通過增加配置中的超時得到了修復。

cloudSqlConfig: {
    connectionLimit: 10,
    host: 'your-host-ip',
    user: process.env.DB_USERNAME,
    password: process.env.DB_PASSKEY,
    database: 'myDB',
    connectTimeout: 20000,
    waitForConnections: true,
    queueLimit: 0
},

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM