0

我正在使用 Node.js(Express、Swaggerize、Sequelize 和 SQLlite)测试 Azure API App 服务。到目前为止,一切都在我的开发工作站中运行,但是在尝试部署应用程序时遇到了一些问题。

首先,我创建了 API 应用程序“容器”,并将我的 VSTS Git 存储库与 API 容器连接起来。将代码推送到 repo 时一切正常(容器会在几秒钟内自动获取所有更改)。

但是...(以下问题)

  1. 如何解决我的节点依赖关系?(到目前为止,我一直在通过容器控制台手动调用“npm install”。我不想将我的包推送到 GIT 存储库中
  2. 我不能在 sequelize 中使用 SQLite 方言,因为虽然包似乎在我的应用程序依赖项和 node_modules 目录中,但我的应用程序仍然抛出异常

    Wed Mar 02 2016 16:57:16 GMT+0000 (Coordinated Universal Time): Unaught exception: Error: Please install sqlite3 package manually
    at new ConnectionManager (D:\home\site\wwwroot\node_modules\sequelize\lib\dialects\sqlite\connection-manager.js:24:11)
    at new SqliteDialect (D:\home\site\wwwroot\node_modules\sequelize\lib\dialects\sqlite\index.js:12:28)
    at new Sequelize (D:\home\site\wwwroot\node_modules\sequelize\lib\sequelize.js:213:18)
    at Object.<anonymous> (D:\home\site\wwwroot\app\models\index.js:8:17)
    at Module._compile (module.js:413:34)
    at Object.Module._extensions..js (module.js:422:10)
    at Module.load (module.js:357:32)
    at Function.Module._load (module.js:314:12)
    at Module.require (module.js:367:17)
    at require (internal/module.js:16:19)
    at Object.<anonymous> (D:\home\site\wwwroot\app\app.js:11:14)
    at Module._compile (module.js:413:34)
    at Object.Module._extensions..js (module.js:422:10)
    at Module.load (module.js:357:32)
    at Function.Module._load (module.js:314:12)
    at Module.require (module.js:367:17)
    at require (internal/module.js:16:19)
    at Object.<anonymous> (D:\home\site\wwwroot\server.js:3:1)
    at Module._compile (module.js:413:34)
    at Object.Module._extensions..js (module.js:422:10)
    at Module.load (module.js:357:32)
    at Function.Module._load (module.js:314:12)
    

有什么我想念的吗?

4

1 回答 1

1

看来问题是由于缺少 npm 包引起的sqlite3。所以你需要手动安装包,但是安装会失败,因为安装包sqlite3需要gyp编译器(根据这里的包描述),Azure应用服务不支持。

您可以参考Native Modules文档将 Node.js 模块与 Azure 应用程序一起使用的部分,以了解原因和解决方法。

于 2016-03-03T08:45:48.150 回答