Ошибка доступа к удаленной БД с помощью sequelize через tunnel-ssh - PullRequest
0 голосов
/ 20 февраля 2019

У меня есть экземпляр EC2 Ubuntu на AWS с MySQL DB, к которому я могу получить доступ со следующей конфигурацией через HeidiSQL, и все работает отлично.Моя главная цель - подключиться к этой БД через sequelize.Я пытался сделать это с пакетом npm tunnel-ssh, но постоянно получаю ошибки.

Настройки

settings

Настройки туннеля SSH

ssh tunnel settings

Настройки группы безопасности экземпляра AWS EC2:

enter image description here

enter image description here

Сообщение об ошибке:

{ SequelizeConnectionRefusedError: connect ECONNREFUSED 127.0.0.1:3306
    at Utils.Promise.tap.then.catch.err (G:\study\ssh-tunnel\sqlize-ssh\node_modules\sequelize\lib\dialects\mysql\connection-manager.js:139:19)
    at tryCatcher (G:\study\ssh-tunnel\sqlize-ssh\node_modules\bluebird\js\release\util.js:16:23)
    at Promise._settlePromiseFromHandler (G:\study\ssh-tunnel\sqlize-ssh\node_modules\bluebird\js\release\promise.js:512:31)
    at Promise._settlePromise (G:\study\ssh-tunnel\sqlize-ssh\node_modules\bluebird\js\release\promise.js:569:18)
    at Promise._settlePromise0 (G:\study\ssh-tunnel\sqlize-ssh\node_modules\bluebird\js\release\promise.js:614:10)
    at Promise._settlePromises (G:\study\ssh-tunnel\sqlize-ssh\node_modules\bluebird\js\release\promise.js:690:18)
    at _drainQueueStep (G:\study\ssh-tunnel\sqlize-ssh\node_modules\bluebird\js\release\async.js:138:12)
    at _drainQueue (G:\study\ssh-tunnel\sqlize-ssh\node_modules\bluebird\js\release\async.js:131:9)
    at Async._drainQueues (G:\study\ssh-tunnel\sqlize-ssh\node_modules\bluebird\js\release\async.js:147:5)
    at Immediate.Async.drainQueues [as _onImmediate] (G:\study\ssh-tunnel\sqlize-ssh\node_modules\bluebird\js\release\async.js:17:14)
    at runCallback (timers.js:705:18)
    at tryOnImmediate (timers.js:676:5)
    at processImmediate (timers.js:658:5)
  name: 'SequelizeConnectionRefusedError',
  parent:
   { Error: connect ECONNREFUSED 127.0.0.1:3306
       at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1117:14)
     errno: 'ECONNREFUSED',
     code: 'ECONNREFUSED',
     syscall: 'connect',
     address: '127.0.0.1',
     port: 3306,
     fatal: true },
  original:
   { Error: connect ECONNREFUSED 127.0.0.1:3306
       at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1117:14)
     errno: 'ECONNREFUSED',
     code: 'ECONNREFUSED',
     syscall: 'connect',
     address: '127.0.0.1',
     port: 3306,
     fatal: true } }

пакетов, которые я использую: mysql2, sequelize, tunnel-ssh

Я думаю, что до сих пор мне удалось открыть ssh-туннельи запустить sequelize но с ошибками.Это код, который я написал:

const fs = require('fs');
const Sequelize = require("sequelize");
const tunnel = require('tunnel-ssh');
const ppk = fs.readFileSync('./sample.ppk', 'utf-8');

const sequelize = new Sequelize('test', 'login', 'password', {
  host: 'localhost',
  port: 3306,
  dialect: "mysql",
  pool: {
      max: 5,
      min: 0,
      acquire: 30000,
      idle: 10000
  }
}); 

const sshConfig = {
  user: 'ubuntu',
  host: 'sshServer',
  port: 22,
  dstHost: 'localhost',
  dstPort: 3306,
  localHost: 'localhost',
  localPort: 3307,
  privateKey: ppk
}

// initiate tunnel
tunnel(sshConfig, (error, server) => {
  if(error) {
    console.error(error);
  } else {
    console.log('server:', server);

    sequelize
        .authenticate()
        .then((db) => {
            console.log('CONNECTION ESTABLISHED! ', db);
        })
        .catch((err) => {
            console.error('UNABLE TO ESTABLISH CONNECTION: ', err);
        })
  }
})

Ответы [ 2 ]

0 голосов
/ 21 февраля 2019

Проблема была решена, вообще не используя соединение ssh-tunnel.Вместо этого я открыл порт mysql только для своего домашнего ip и создал нового пользователя со всеми предоставленными разрешениями.
Немного исправил мой код: добавил IP-адрес сервера вместо localhost.Это работает сейчас.

const sequelize = new Sequelize('DBname', 'userName', 'password', {
  host: 'ec2-xx-xxx-xx-x.ap-xxxxxxxxxxxx.compute.amazonaws.com',
  port: 3306,
  dialect: "mysql",
}); 
0 голосов
/ 20 февраля 2019

для mysql / aurora есть пользовательский IP-адрес, если ваш скрипт выполняется локально на этом EC @, тогда вы сможете установить соединение.

Добавьте одно правило с любым доступом и попробуйте его.для mysql

...