NodeJsプロジェクトの中のいくつかの要点記録


前言
NodeJsを勉強しています.たくさんの穴を踏みました.ここで自分の役に立つ点を記録して、これから必要なものを準備したいです.
コードデバッグ
一般的にJsプロジェクトのデバッグはAlert(先端)またはConsolie.log(バックエンド)によって行われます.これはいつも柔軟ではありません.NodeJs内蔵のデバッグガーでも友好的ではありません.ここではデバッグツール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といいます.とても使いやすいです.
使用するものがexpress 4.Xであればnode-dev bin/wwwを使用し、express 3.Xであればnode-dev app.jsを使用する.
サーバーに展開するにはどうすればいいですか?ここはpm 2を押します
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でファイルの変化を監督して、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);
        });
    });
    
});
これはただ一つの例です.もっと複雑な論理はこの思想によって深層的な入れ子を生みます.明らかに私達が見たいのではありません.この時はイベントモジュールが役に立ちます.

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);
    });    
});
このように全体の流れははっきりしています.
NFgixを用いて静的リソースを提供する.
Nginnxはずっとその高性能で有名です.応用を設計する時に、inxに静的な資源を提供させて、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.1.0.1です.
私のホームページへようこそ.http://mageek.cn)