Я не могу подключиться к снежинке через разъем node js - PullRequest
0 голосов
/ 09 апреля 2020

Я пытаюсь подключиться к базе данных снежинок, используя snowflake-sdk разъем.

Сначала я установил snowflake-sdk, используя командную строку:

npm install snowflake-sdk

После того, как я следовал все сообщенные инструкции здесь .

я создал файл index.js, содержащий:

    var snowflake = require('snowflake-sdk');
    var connection = snowflake.createConnection( {
        account : 'xxxx.east-us-2'
        username: 'MYUSERNAME'
        password: 'MYPASSWORD'
        }
        );
    connection.connect( 
        function(err, conn) {
            if (err) {
                console.error('Unable to connect: ' + err.message);
                } 
            else {
                console.log('Successfully connected to Snowflake.');            
                }
            }
        );

и после того, как я запустил команду node index.js

и произошла ошибка подключения:

Невозможно подключиться: ошибка сети. Не удалось добраться до Снежинки.

Я снова попытался изменить значение учетной записи в xxxx.east-us-2.azure.snowflakecomputing.com, но ничего не изменилось.

Ответы [ 3 ]

0 голосов
/ 09 апреля 2020

Проблема связана с именем вашей учетной записи. Пожалуйста, передайте имя вашей учетной записи как xxxx.east-us-2.azure

0 голосов
/ 10 апреля 2020

Вот код, который я использовал при воспроизведении крошечной проблемы, которую я отправил сотрудникам службы поддержки Snowflake.

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const snowflake = require("snowflake-sdk");
const Q = require("q");
const SNOWFLAKE_HOST_SUFFIX = 'snowflakecomputing.com';    
const SNOWFLAKE_ACCOUNT = 'companyname';
function getSFConnection(connParams) {
    var d = Q.defer();
    let connection = snowflake.createConnection({
        account: connParams.account || SNOWFLAKE_ACCOUNT,
        username: connParams.user,
        password: connParams.password || '',
        database: connParams.name,
        warehouse: connParams.warehouse
    });
    connection.connect(function (err, conn) {
        if (err) {
            console.error('Unable to connect: ' + err.message);
            d.reject(err);
        }
        else {
            console.info('Successfully connected as id: ' + connection.getId());
            connection.close = function () {
                return disconnectSF(connection);
            };
            d.resolve(connection);
        }
    });
    return d.promise;
}

и я использовал это как:

getSFConnection({ 
    user: 'username',
    account: 'companyname',
    password: 'password',
    name: '',
    warehouse: 'warehouse_name'
}).then...

после размышления. Мне интересно, почему у меня установлен суффикс хоста, но я его не использую ... но он есть.

0 голосов
/ 09 апреля 2020

Имя вашей учетной записи также должно включать облачного провайдера. Измените имя учетной записи следующим образом:

var connection = snowflake.createConnection( {
    account : 'xxxx.east-us-2.azure'
    username: 'MYUSERNAME'
    password: 'MYPASSWORD'
    }

Полные имена учетных записей см. docs

.
...