`
bk_lin
  • 浏览: 320211 次
社区版块
存档分类
最新评论

在Windows Azure Web Site上为Node.js自动安装NPM包

 
阅读更多

在我以前的一个文章中,我描述和演示了如何在Node.jsWindowsAzure Web Site (WAWS)使用NPM包。在那篇文章中我使用NPM命令安装软件包,然后使用GitWindows提交我所做的更改,并且同步它们到WAWSgit 资源库。然后WAWS将触发新的部署托管我的WAWSgit 资源库应用程序。

有人可能会注意到,NPM包可能包含多个文件,而且可能有点大。例如,"azure"包,WindowsAzure SDKNode.js的包,大约6MB。另外一个常用的含有给Node.js使用的MVC框架包”express”,大约是1MB。当我首次将节点放到WindowsAzure时,所有的节点必须上载到云。

是否可能让Windows Azure为我们下载并安装这些包?在这篇文章中,我将演示在部署时如何使

WAWS 为我们安装所有需要的包。

让我们开始演示

演示是最直接的。让我们创建一个新的WAWS并把它复制到我的当地磁盘。为Windows拖动文件夹到Git,以至于我们可以提交和发送。

如果你不熟悉怎样使用Windows Windows Azure Web SiteGit部署、git副本和Git,请参考这篇文章

然后打开命令窗口,在我们的代码文件夹中安装一个包。我们说我想要安装“express”

然后创建一个新的Node.js文件,命名为“server.js”,并粘贴如下代码。

 var express = require("express");  
 var app = express();    
app.get("/", function(req, res) {      res.send("Hello Node.js and Express.");    }); 
 console.log("Web application opened.");  
 app.listen(process.env.PORT); 


假如现在我们切换到WindowsGit,我们将会发现他它检测到我们所做的更改,其中包括“server.js”“node_modules”文件夹下的所有文件。我们需要上传的只是我们的源代码,但是这个巨大的包文件也必须被上传。现在我将演示如何排除它,并且在云上让WindowsAzure安装包。

首先我们需要添加一个名为“.gitignore”的特殊文件。由于这个文件仅仅包含扩展名,它似乎不能直接从文件浏览器添加。因此我们需要从命令行添加。导航到本地资源库的文件夹,并执行下面的命令来创建一个名为“.gitignore”的空文件夹。假如命令窗口要求输入,只需要按下Enter键。

echo > .gitignore 

现在打开此文件,复制下面的内容并保存。

node_modules 


现在如果我们切换到Windows Git,我们将会发现在“node_modules”下的包没有在更改列表中。

所以现在我们提交和发送,“express”包将会被加载到Windows Azure

其次,在部署时让我们告诉Windows Azure哪个包需要安装。创建另一个名为“package.json”的文件,复制下面的内容到文件并保存。

{    
  "name": "npmdemo",    
 "version": "1.0.0",    
  "dependencies": {   
    "express": "*"    
                             }     
} 


现在返回到WindowsGit,提交我们的更改,并将它发送到WAWS

然后让我们在开发人员门户中打开WAWS,我们将看到一个新的部署被完成。单击部署右侧的箭头,我们能够发现WAWS如何处理此部署。特别是我们发现被NPM执行的WAWS

假如我们打开日志,我们可以看到安装包WAWS执行的指令和安装输出信息。正如您从云端看到WAWS为我安装的“express”,因此我们不需要将所有堆的包上传到Azure.

打开此网站,我们可以看到结果。这证明“express”已经被成功安装。

下面发生了什么?

现在让我们来解释“.gitignore” “package.json”的意思。

“.gitignore”git库的一个忽略配置文件。所有列在“.gitignore”中的文件和文件夹将从git发送中跳过。在下面的事例中,我复制“node_modules”到本地存储库中的文件。这意味着,不跟踪和上传“node_modules”文件夹下的所有文件。因此通过使用“.gitignore”,从上传到WindowsAzure我跳过了所有的包。

“.gitignore”可以包含文件和文件夹。它还可以包含我们不想忽略的文件和文件夹。在下一章中,我们将会看到如何使用不被忽略的语法使SQL包含在内。

“package.json”文件是Node.js应用程序的包定义文件。我们可以在“package.json”文件中以JSON格式定义应用程序名、版本、描述、作者等信息。我们也可以放置相互依赖的包,指示哪个包是Node.js需要的。

WAWS中,名称和版本是必要的。当部署发生时,WAWS将查找此文件,找到依赖包,并执行NPM命令逐个安装。因此在上面的演示中,我复制“express”到这个文件,以至于WAWS将会为我自动安装它。

我手动更新“package.json”文件的依赖项部分。但是这可以部分自动完成。假如在本地的存储库中我们有有效的“package.json”,当我们安装包时,我们可以在“npminstall”命令中指定“--save”参数。以至于NPM帮助我们更新依赖项部分。

例如,当我们想要安装“azure”,我们应该执行下面的命令。注意,我添加了“--save”命令。

npm install azure --save 

一旦它完成,我的“package.json”将会自动更新。

这里将介绍每个依赖的包。当值是版本范围时,JSON键值是包名。以下是版本范围格式的简明列表。有关“package.json”的详细信息,请参阅此处

格式

说明

示例

版本

版本必须完全匹配。

"azure""0.6.7"

> = 版本

必须等于或大于版本。

"azure""> 0.6.0"

1.2.x

版本号必须从提供的数字开始,任何数字可以代替 x

"azure":"0.6.x"

~ 版本

版本必须至少和系列一样,它必须小于以上范围的下一个重大修订。

"azure""~ 0.6.7"

*

匹配任何版本。

"azure"""

基于您在此处的定义WAWS将安装合适版本的包。WAWS git部署和NPM安装也是如此。

但是一些包...

我们知道,当我们在“package.json”中指定依赖项,WAWS将下载并安装它们到云上。对于大多数包,它运行正常。但有一些特殊的包可能不能运行。假如包安装需要一些特殊的环境约束它,这意味着它可能失败。

例如,当NPM安装期间,Node.js包的SQLServer驱动程序需要“node-gyp”Python C++2010被安装在目标机器上。假如我们仅仅把“msnodesql”放在“package.json”文件中,并将它发送到WAWS,由于在WAWS虚拟机中没有“node-gyp” Python C++2010,部署将会失败。

例如,“server.js”文件。

 var express = require("express");    
 var app = express();   
 app.get("/", function(req, res) {    
  res.send("Hello Node.js and Express.");   
 });    
 var sql = require("msnodesql"); 
var connectionString = "Driver={SQL Server Native Client 10.0};Server=tcp:tqy4c0isfr.database.windows.net,1433;Database=msteched2012;Uid=shaunxu@tqy4c0isfr;Pwd=P@ssw0rd123;Encrypt=yes;Connection Timeout=30;";   
 app.get("/sql", function (req, res) {   
 sql.open(connectionString, function (err, conn) {   
      if (err) {   
           console.log(err);  
         res.send(500, "Cannot open connection.");   
    }   
    else {   
           conn.queryRaw("SELECT * FROM [Resource]", function (err, results) {   
          if (err) {   
                    console.log(err);   
                res.send(500, "Cannot retrieve records.");   
          }   
        else {   
                 res.json(results);   
         }   
          });   
       }  
   });  
 });   
 console.log("Web application opened.");   
app.listen(process.env.PORT); 


“package.json”文件。

{  
   "name": "npmdemo",
  "version": "1.0.0",  
  "dependencies": {   
   "express": "*",    
  "msnodesql": "*"   
}  
} 


他部署到WAWS失败。

NPM日志中,我们可以看到因为“msnodesql”它不能被安装在WAWS上。

“.gitignore”文件中我们应该忽略所有的包,除了“msnodesql”,并且我们自己上传包,这就是解决方案。这个可以通过使用下面的内容做到。首先我们不要忽略“node_modules”文件夹。然后我们忽略所有的子文件夹,但是需要git检查每个子文件夹,然后我们不要忽略名为“msnodesql”子文件夹,这个就是SQLServer Node.js驱动程序。

 !node_modules/  
node_modules/* 
 !node_modules/msnodesql 


有关“.gitignore”语法的更多信息,请参阅这篇文章

现在假如我们转到WindowsGit,我们将会发现“msnodesql”被列入未提交集,然而“express”没有被列入。此外我也需要从“package.json”中删除“msnodesql”的依赖。

提交并发送到WAWS。现在我们可以看到部署被成功完成。

通过我们上传的 “msnodesql”包,我们可以使用来自Node.js应用程序的WindowsAzure SQL Database

总结

在这篇文章中,我演示在发布操作期间如何利用Windows Azure Web Site的部署进程进行安装NPM包。使用“.gitignore”文件和“package.json”文件我们可以忽视来自Node.js的依赖包,并让WindowsAzure Web Site在部署时下载和安装它们。

某些特殊的包不能被Windows Azure Web Site安装,例如“msnodesql”,我们也可以把它们放在发布有效载荷中。

Windows Azure Web SiteNode.js NPM的结合,它使我们更容易和快捷地开发和部署Node.js应用程序到云。

希望这个有所帮助,

Shaun

本文翻译自:

http://blogs.shaunxu.me/archive/2012/11/16/install-npm-packages-automatically-for-node.js-on-windows-azure-web.aspx

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics