单线程异步回调机制的缺陷与node的解决方案

一、node单线程异步的缺陷:

  单线程异步的优点自然不必多说,node之所以能够如此快的兴起,其单线程异步回调机制相比于传统同步执行编程语言的优势便是原因之一。然而,开发一个node程序,其缺陷也是不可忽视的:

二、node解决方案:

1、node实现访问和错误日志:

  morgan是一个http请求处理的中间件

  

  

  

2、node cluster模块支持开启多个工作进程充分调用cpu资源,也能防止bug使node进程奔溃:

  app.js修改:

  

  新建cluster.js:

  

命令行执行:

  

  注:supervisor是一个node第三方包,用于监听node程序,当node程序发生修改supervisor会监听到并重启服务器,方便修改调试。安装可用:npm install -g supervisor;

  进程管理器会根据你的cpu核数量创建相应的工作进程。

3、nginx做反向代理进行转发:

  如果电脑上有apache服务器,修改监听端口号为8080,node进程也不要监听80端口,留给nginx。

  下载nginx,修改nginx配置文件nginx.conf,php文件转发到apache,node访问转发到node服务器(例如3000端口)

  

  更多关于nginx的配置可自行百度nginx+apache,nginx+node了解学习

  

  

时间: 2024-11-06 14:56:44

单线程异步回调机制的缺陷与node的解决方案的相关文章

Guava Futures异步回调机制源码解析

本文是在学习中的总结,欢迎转载但请注明出处:http://blog.csdn.net/pistolove/article/details/51758194 1.前言 在前两篇文章中简单阐述了Java Future 和Guava ListenableFuture及其相关的应用.我们发现Guava ListenableFuture提供了比Java Future更加强大的功能,而在Google Guava并发包中,某些情况下,Futures这个类起到了不可或缺的作用,而ListenableFuture

nodejs中的异步回调机制

1.再次clear Timer定时器的作用 setTimeOut绝非是传统意义上的"sleep"功能,它做不到让主线程"熄火"指定时间,它是用来指定:某个回调在固定时间后插入执行栈!(实际执行时间略长于这个固定时间) 2.js或nodejs想"sleep"主线程怎么做? 可以自定义sleep休眠函数,原理就是 目标时间 >= 当前时间+sleepTime; 然后不断在while中tick时间.比较.直接看代码吧. function slee

异步回调/我们为什么要使用NodeJS

1.原文转载自:http://limu.iteye.com/blog/1013223 原文转载自:http://blog.csdn.net/zhangliangzi/article/details/52066560 2.说到"调用",模块之间总是存在这一定的接口,模块之间通过这些接口调用以通信联系,从调用方式上看,可以分为三类:同步调用.回调和异步调用. 同步调用是一种阻塞式调用,也是我们在写程序中经常使用的: 回调是一种双向的调用模式: 异步调用是一种类似消息或事件的机制,解决了同步

node 单线程异步非阻塞

链接:http://www.runoob.com/nodejs/nodejs-callback.html 首先什么是单线程异步非阻塞? 单线程的意思整个程序从头到尾但是运用一个线程,程序是从上往下执行的.异步操作就是程序虽然是从上到下执行的,但是某个函数执行时间过长时并不会阻塞在那里等待它执行完,然后在执行下面的代码.非阻塞也就是这个意思. 为什么node是异步非阻塞的呢,得力于回调函数,还有js中的定时器也是经典的异步操作. ###4.1 Node.js异步机制 由于异步的高效性,node.j

【译】深入理解python3.4中Asyncio库与Node.js的异步IO机制

转载自http://xidui.github.io/2015/10/29/%E6%B7%B1%E5%85%A5%E7%90%86%E8%A7%A3python3-4-Asyncio%E5%BA%93%E4%B8%8ENode-js%E7%9A%84%E5%BC%82%E6%AD%A5IO%E6%9C%BA%E5%88%B6/ 译者:xidui原文: http://sahandsaba.com/understanding-asyncio-node-js-python-3-4.html 译者前言 如

异步调用与回调机制,协程

1.异步调用与回调机制 上一篇我们已经了解到了两组比较容易混淆的概念问题,1.同步与异步调用 2.阻塞与非阻塞状态.在说到异步调用的时候,说到提交任务后,就直接执行下一行代码,而不去拿结果,这样明显存在缺陷,结果是肯定要拿的,这辈子都肯定是要拿到这个结果的,没有这个结果后面的活又不会干,没办法,只能去拿结果的,那么问题是异步调用提交任务后,如何实现既要拿到结果又不需要原地等的理想状态呢?专门为异步调用配备了一个方法--回调机制 先来想想我们之前是怎么拿到一个函数的结果,就传给另外一个函数取执行,

深入浅出: Java回调机制(异步)

Writer      :BYSocket(泥沙砖瓦浆木匠) 什么是回调?今天傻傻地截了张图问了下,然后被陈大牛回答道"就一个回调-".此时千万个草泥马飞奔而过(逃 哈哈,看着源码,享受着这种回调在代码上的作用,真是美哉.不妨总结总结. 一.什么是回调 回调,回调.要先有调用,才有调用者和被调用者之间的回调.所以在百度百科中是这样的: 软件模块之间总是存在着一定的接口,从调用方式上,可以把他们分为三类:同步调用.回调和异步调用. 回调是一种特殊的调用,至于三种方式也有点不同. 1.同步

node 异步回调解决方法之yield

先看如何使用 使用的npm包为genny,npm 安装genny,使用 node -harmony 文件(-harmony 为使用es6属性启动参数) 启动项目 var genny= require('genny'); genny.run(function* (resume) { console.log("Hello"); yield setTimeout(resume(), 1000); console.log("World"); }); 输出Hello 暂停1秒

异步消息的传递-回调机制

简介: 软件模块之间总是存在着一定的接口,从调用方式上,可以把他们分为三类:同步调用.回调和异步调用.同步调用是一种阻塞式调用,调用方要等待对方执行完毕才返回,它是一种单向调用:回调是一种双向调用模式,也就是说,被调用方在接口被调用时也会调用对方的接口:异步调用是一种类似消息或事件的机制,不过它的调用方向刚好相反,接口的服务在收到某种讯息或发生某种事件时,会主动通知客户方(即调用客户方的接口).回调和异步调用的关系非常紧密,通常我们使用回调来实现异步消息的注册,通过异步调用来实现消息的通知.同步