2

我在 appfog 中发布了一个 node.js 应用程序,但是当我尝试使用(https://github.com/felixge/node-mysql)通过 javascript 访问 mysql 数据库时,似乎没有安装“node-mysql”,这样做的方法是什么?appfog 网站上没有文档。谢谢。

服务器app.js的代码:

if(process.env.VCAP_SERVICES){
var env = JSON.parse(process.env.VCAP_SERVICES);
var cre = env['mysql-5.1'][0]['credentials'];
}
var Client = require('mysql').Client,
client = new Client();
client.user = cre.user;
client.password = cre.password;
client.host=cre.host;
client.port=cre.port;
client.database=cre.name;
client.connect();

client.query(
    'SELECT * FROM scores ',
    function selectPlayers(err, results, fields) {
        if (err) {
            console.log("Error: " + err.message);
            throw err;
        }
        console.log("Number of rows: "+results.length);
        console.log(results);
        client.end();
    });

和错误:

module.js:340
throw err;
      ^
Error: Cannot find module 'mysql'
at Function.Module._resolveFilename (module.js:338:15)
4

3 回答 3

1

你应该添加

"mysql": "2.0.x || 2.1.x",

到 package.json 文件中的依赖项,然后执行

npm install

您可以在此处查看 Appfog 的文档。有一个关于依赖管理的部分

于 2013-01-04T22:58:07.293 回答
1

Appfog 支持 NPM,这是在 node.js 中安装依赖项的标准方式。

您可以通过控制台执行此操作,也可以npm install mysql将 mysql 添加到您的package.json文件中并执行npm install.

第二种方式将自动为您的应用安装所有依赖项。

来源:https ://docs.appfog.com/languages/node#node-dep-mgmt

于 2013-01-04T23:02:52.067 回答
1

嗨,您只需要在本地下载并安装 node.js,这将在您的机器上启用 npm 命令,然后转到 AppFog 面板上的“服务”部分为您创建 mySQL 服务(VCAP_SERVICES)

当您配置服务并将其绑定到您的应用程序时,AppFog 会创建一个名为 VCAP_SERVICES 的环境变量。

此变量包含一个 JSON 文档,其中包含绑定服务的所有凭据和连接信息的列表。

下面是一个应用程序的环境变量示例,该应用程序绑定了两个 MySQL 数据库服务:

{"mysql-5.1":[
{
    "name":"mysql-4f700",
    "label":"mysql-5.1",
    "plan":"free",
    "tags":["mysql","mysql-5.1","relational"],
    "credentials":{
        "name":"d6d665aa69817406d8901cd145e05e3c6",
        "hostname":"mysql-node01.us-east-1.aws.af.cm",
        "host":"mysql-node01.us-east-1.aws.af.cm",
        "port":3306,
        "user":"uB7CoL4Hxv9Ny",
        "username":"uB7CoL4Hxv9Ny",
        "password":"pzAx0iaOp2yKB"
    }
},
{
    "name":"mysql-f1a13",
    "label":"mysql-5.1",
    "plan":"free",
    "tags":["mysql","mysql-5.1","relational"],
    "credentials":{
        "name":"db777ab9da32047d99dd6cdae3aafebda",
        "hostname":"mysql-node01.us-east-1.aws.af.cm",
        "host":"mysql-node01.us-east-1.aws.af.cm",
        "port":3306,
        "user":"uJHApvZF6JBqT",
        "username":"uJHApvZF6JBqT",
        "password":"p146KmfkqGYmi"
    }
}
]}

您可以使用应用程序的特定语言工具来调用环境变量。

在 Java 中:

 java.lang.System.getenv("VCAP_SERVICES")

在红宝石中:

  ENV['VCAP_SERVICES']

在 Javascript 中:

 process.env.VCAP_SERVICES

在 Python 中:

 os.getenv("VCAP_SERVICES")

在 PHP 中:

 getenv("VCAP_SERVICES")
于 2013-01-07T19:59:00.197 回答