1

我正在尝试从多机工作区中的另一个 NodeJS 运行时连接到 MySQL 运行时中的数据库。

在测试中,我http://localhost:3000/target使用目标用户列表调用 API。此 API 中的代码在 db 上运行 SELECT:

...

exports.list = function(req, res) {

    req.getConnection(function(err, connection) {

        if (err) {
                console.log("MySQL " + err);
        } else {

              connection.query('SELECT id FROM target', function(err, rows) {

            if (err) {
                console.log("Error Selecting : %s ", err);
            } else {

                ...

我从终端得到的结果:

get target list from http://localhost:3000/target
MySQL Error: connect ECONNREFUSED 127.0.0.1:3306

这里我定义了到数据库的连接:

var express = require('express');
var connection = require('express-myconnection');
var mysql = require('mysql');
var config = require('config');
var connectionConfig = config.get('mysql');
var connectionInstance = connection(mysql, connectionConfig, 'request');

...

app.use(connectionInstance);

app.get('/', function(req, res) {
    res.send('Welcome');
});

app.get('/target', target.list);

....

配置:

{
    "mysql": {
        "host": "localhost",
        "user": "[user]",
        "password": "[password]",
        "database": "[database]"
    },
    "app": {
        "port": 3000,
        "server": "http://localhost"
    }
}

这是我在 Eclipse Che 中的 db 机器配置中所拥有的:

服务器配置快照

这是我的食谱:

services: db: image: eclipse/mysql environment: MYSQL_ROOT_PASSWORD: password MYSQL_DATABASE: petclinic MYSQL_USER: petclinic MYSQL_PASSWORD: password MYSQL_ROOT_USER: root mem_limit: 1073741824 dev-machine: image: eclipse/node mem_limit: 2147483648 depends_on: - db elasticsearch: image: florentbenoit/cdvy-ela-23 mem_limit: 2147483648

4

1 回答 1

0

你能分享你recipe的多机工作空间吗?这对调试它有很大帮助。

只是一个猜测:我认为您的设置问题在于localhost您的数据库连接的使用。如果您正在运行多机设置,则 db 在不同的 docker 容器中运行,并且需要通过其名称来寻址。

多机教程节选:

在配方中,“dev-machine”的 depends_on 参数允许它连接到“db”机器 MySQL 进程的端口 3306。“dev-machine”在项目源代码的 src/main/ 中配置其 MySQL 客户端连接资源/spring/data-access.properties。url 由 jdbc.url=jdbc:mysql://db:3306/petclinic 定义,它使用数据库机器的名称“db”和 MySQL 服务器默认端口 3306。

您需要在recipe.

免责声明:我不直接隶属于 Eclipse Che、Codenvy 或 Red Hat,但我们正在构建自己的云 IDE,用于在 Eclipse Che 之上进行 C/C++ 多核优化。

于 2017-07-26T08:31:26.120 回答