NodeJs项目中的一些要点记录

前言

学习NodeJs也有一段时间了,踩过许多坑,在这里打算记录一下自己觉得有用的点,以备以后所需。

代码调试#

一般我们调试Js项目都是通过Alert()(前端)或者 Console.log()(后端),这总是显得不够灵活。即使是NodeJs内置的debugger也不够友好。这里推荐一款调试工具Node Inspector。这个工具结合Chrome就能达到Eclipse的debug模式的强大效果。

首先 npm install -g node-inspector 全局安装
然后 node-inspector 启动工具
编写一段测试代码 server.js :

var http = require("http");
debugger;
function onRequest(request, response) {
  response.writeHead(200, {"Content-Type": "text/plain"});
  debugger;
  response.write("Hello World");
  debugger;
  response.end("end of hello world");
}

http.createServer(onRequest).listen(8888);

另开控制台窗口 node --debug-brk server.js
在chrome中打开http://127.0.0.1:8080/debug?port=5858就可以看到程序在断点处暂停,我们就可以在chrome控制台访问程序断点前的变量了,还可以查看调用栈,也可以单步执行等等。

另外如果你喜欢IDE的话不妨用webstorm,这是目前号称JavaScript最友好的IDE了,当然少不了代码调试功能。

文件变化后重启服务?

每当我们修改代码源文件的时候,都要关掉进程重启,这是相当麻烦的事,辛运的是已经有些工具来帮我们监听文件,并在文件变化之时自动重启服务。
比如node-dev,安装:npm install -g node-dev 然后 node-dev server.js。这样修改文件时服务就会自动重启了。如图:(对了,这个GIF录制工具叫做 GIFcam,很好用的)

动态

如果使用的是express4.X 就使用node-dev bin/www,如果是express3.X 就使用node-dev app.js

那么部署到服务器上怎么办?,这里强推pm2。
npm install -g pm2
然后
pm2 bin/www --name 'express' --watch
这样就可以稳定运行了,监听文件变化了。
当然不要忘了设置为生产环境,所以这样
pm2 start bin/www --env production
甚至,可以直接写一个start.json文件,把你想要的配置都写进去,
{
"apps" : [{
"name" : "express",
"script" : "bin/www",
"log_date_format" : "YYYY-MM-DD HH:mm:SS",
"env": {
"NODE_ENV": "production"
},
"watch" : true
}]
}
然后执行如下命令即可
pm2 start start.json
最后设为开机启动
pm2 startup

还有一种解决方案就是screen + node-dev,用node-dev 来监听文件变化,用screen来使得服务后台一直运行。

异步编程

异步的一大难点就是原来顺序执行的思路不通了,比如对于一个登录请求过来,你得先在数据库查看有没有这个用户,其次再获得他的权限,然后检查模板文件,最后渲染页面给他。用PHP写的话,我们只需要顺着写就行了,因为所写顺序即是所执行的顺序,没什么问题。但是Node由于是异步的,这一步所依赖的由上一步产生的数据可能还没来得及产生,就会出错,所以我们为了保证程序运行,通常会使用嵌套
query(sql1,function(error, results){
if (error) next();
query(sql2,function(error, results){
if (error) next();
check(file,function(error, results){
if (error) next();
render(results);
});
});

});

这只是一个个例,如果更复杂的逻辑按照这种思想就会产生深层次的嵌套,显然不是我们想看到的。这个时候就是event模块派上用场的时候了

var events = require( 'events' );

query(sql1,function(error, results){  
    if (error) next(); 
    emiter.emit('user',results);//触发信号,传递数据             
});

emiter.on('user',function (user) {//绑定监听器
    query(sql2,function(error, results){  
        if (error) next(); 
        emiter.emit('authority',results);//触发信号,传递数据            
    });
});

emiter.on('authority',function (authority) {//绑定监听器
    check(file,function(error, results){  
        if (error) next();
        render(results);
    }); 
});

这样子整个流程就清晰许多了。

用Nginx来提供静态资源

Nginx一直以其高性能著称,我们设计一个应用的时候,最好就是让nginx来提供静态资源,让node只负责处理数据以及逻辑上的动态资源,这样能降低node负载,提高效率。

apt-get install nginx
service nginx start

修改配置
vim /etc/nginx/sites-enabled/default

server {
    listen 80 default_server;
   
    location / {
            proxy_pass http://localhost:3000;

    }
    location /public/ {
            root /var/www/public/ ;#亲测不能放在root文件夹下面,即使修改权限777也会被拒绝访问
    }
}

重启
service nginx restart

需要注意的是,如果你有获取客户端ip的需求的话要这样配置

location / {
        proxy_pass   http://localhost:3000;
        proxy_redirect off;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $http_host;
        proxy_set_header X-NginX-Proxy true;
}

然后node代码:
function getClientIp(req) {
return req.headers['x-forwarded-for'] ||
req.connection.remoteAddress ||
req.socket.remoteAddress ||
req.connection.socket.remoteAddress;
}

var ip = getClientIp(req);

如果不按照上面的配置,这段代码得到的结果始终是127.0.0.1。

欢迎访问我的主页http://mageek.cn

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,425评论 4 361
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,058评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,186评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,848评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,249评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,554评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,830评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,536评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,239评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,505评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,004评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,346评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,999评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,060评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,821评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,574评论 2 271
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,480评论 2 267

推荐阅读更多精彩内容