Linux安装NodeJs并配合Nginx实现反向代理_Linux

本文介绍了Linux安装NodeJs并配合Nginx实现反向代理 ,具体如下:

NodeJs是什么?

Node.js是一个JavaScript运行环境(runtime)。实际上它是对Google V8引擎进行了封装。V8引 擎执行Javascript的速度非常快,性能非常好。

Node.js对一些特殊用例进行了优化,提供了替代的API,使得V8在非浏览器环境下运行得更好。

本地安装(OS X)

版本选择

  • V4.4.4,长期支持版本,成熟可靠
  • V6.2.0 稳定版本,最新特性

这里我还是倾向于使用最新的版本~

下载安装包

https://nodejs.org/dist/v6.2.0/node-v6.2.0.pkg

双击安装安装包

下一步下一步,就安装完成了。

简单执行

node -v

v6.2.0

本地运行(OS X)

创建demo文件

const http = require('http');
const hostname = '127.0.0.1';
const port = 3000;

const server = http.createServer((req, res) => {
 res.statusCode = 200;
 res.setHeader('Content-Type', 'text/plain');
 res.end('Hello World\n');
});

server.listen(port, hostname, () => {
 console.log(`Server running at http://${hostname}:${port}/`);
});

写入到文件example.js

执行文件

node example.js

这时命令行输出Server running at http://127.0.0.1:3000/

同时在浏览器输入http://127.0.0.1:3000/,页面输出Hello World

关闭终端,页面不再可用。

Express框架

我们这里采用Express框架进行网站项目demo的搭建。

npm install express

node_modules1

创建demo.js文件

var express = require('express');
app = express();
app.use(express.static(__dirname + '/public'));
app.listen(8081)

在同级文件夹创建public文件夹,里面放入静态文件1.jpg

在浏览器输入yun_qi_img/1.jpg

查看Response Headers,X-Powered-By:Express

服务器安装(CentOS 7)

安装node

curl --silent --location https://rpm.nodesource.com/setup | bash -
yum -y install nodejs
yum install npm

关于Node的版本

我上一步通过node安装的版本号是v0.10.42,一开始以为错了,经过查资料发现,目前node共维护了4个版本

  • v0.10.42 (LTS)
  • v0.12.10 (LTS)
  • 4.4.5 LTS
  • 6.2

呵呵哒,真乱。

编写demo实例

这部分的流程跟上面的一致。

安装forever 并运行

npm install forever -g

forever start app.js

配置Nginx

cd /usr/local/nginx/conf/vhost/

vi demonode.coderfix.cn.conf
server {
listen 80;
server_name demonode.coderfix.cn;
  location / {
  proxy_pass http://127.0.0.1:8899;
  }
}

Nginx解析域名,转发给本地的nodejs的8899端口~

配置域名解析并访问

http://demonode.coderfix.cn/

这样就完成了nodejs和nginx的部署。

可能出现的问题

Nodejs服务多开导致报错

events.js:72
  throw er; // Unhandled 'error' event
     ^
Error: listen EADDRINUSE
  at errnoException (net.js:884:11)
  at Server._listen2 (net.js:1022:14)
  at listen (net.js:1044:10)
  at Server.listen (net.js:1110:5)
  at Object.<anonymous> (folderName/app.js:33:24)
  at Module._compile (module.js:456:26)
  at Object.Module._extensions..js (module.js:474:10)
  at Module.load (module.js:356:32)
  at Function.Module._load (module.js:312:12)
  at Function.Module.runMain (module.js:497:10)1

关掉之前启动的进程,再开就好了。

ps aux | grep node

kill -9 ****

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索nodejs
, nginx反向代理nodejs
, 实现反向代理
nginx代理nodejs
nginx反向代理nodejs、nodejs 实现反向代理、nginx实现反向代理、nginx nodejs、nodejs nginx 部署,以便于您获取更多的相关知识。

时间: 2024-10-27 22:37:36

Linux安装NodeJs并配合Nginx实现反向代理_Linux的相关文章

【NodeJs】Linux安装NodeJs并配合Nginx实现反向代理

Linux安装NodeJs并配合Nginx实现反向代理 NodeJs 是什么 Node.js是一个Javascript运行环境(runtime).实际上它是对Google V8引擎进行了封装.V8引 擎执行Javascript的速度非常快,性能非常好. Node.js对一些特殊用例进行了优化,提供了替代的API,使得V8在非浏览器环境下运行得更好. 本地安装(OS X) 版本选择 V4.4.4,长期支持版本,成熟可靠 V6.2.0 稳定版本,最新特性 这里我还是倾向于使用最新的版本~ 下载安装包

详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南_nginx

Nginx是一种服务器软件,也是一种高性能的http和反向代理服务器,同时还是一个代理邮件服务器.也就是说,我们在Nginx上可以发布网站,可以实现负载均衡(提高应答效率,避免服务器崩溃),还可以作为邮件服务器实现收发邮件等功能.而最常见的就是使用Nginx实现负载均衡. Nginx与其他服务器的性能比较: Tomcat服务器面向Java语言,是重量级的服务器,而Nginx是轻量级的服务器.Apache服务器稳定.开源.跨平台,但是Apache服务器不支持高并发,Nginx能支持处理百万级的TC

详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点_nginx

上一篇分享了 Nginx + Tomcat 反向代理 负载均衡 集群 部署指南,感觉还是相当实用型的,但是一般集群部署是基于大访问量的,可能有的企业用不到,类似一些企业官网,访问量并不是很大,基于这个新需求,今天专门为大家分享一下 Nginx + Tomcat 反向代理 如何在一台服务器部署多个站点,节省服务器开支,就在这篇文章了. 首先我们需要安装好Nginx.jdk.Tomcat,安装方法已经在 上一篇 说过了,本篇不再赘述. 下来看一下我们的需求,我这里有三个网站项目工程需要部署(依次对应

Node.js站点使用Nginx作反向代理时配置GZip压缩的教程_nginx

node.js 开发的站点,如果你也是用了nginx实现反向代理. 那么在服务端可以轻松实现 gzip 压缩,让站点浏览更顺畅. 前提条件: node.js + nginx 反向代理. node.js 需要做的工作: express 4.0以下版本: app.use(express.compress()); //主要是这句 app.use(express.json()); app.use(express.urlencoded()); app.use(express.bodyParser());

Nginx 作为反向代理优化要点proxy_buffering

当nginx用于反向代理时,每个客户端将使用两个连接:一个用于响应客户端的请求,另一个用于到后端的访问: 那么,可以从如下配置起步: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 # One worker per CPU-core. worker_processes  2; events {     worker_connections  8096;     multi_accept        on;     use                 epoll; } wo

如何在阿里云上部署Nginx实现反向代理?

如何在阿里云上部署Nginx实现反向代理? 云中沙箱实验"在阿里云上部署Nginx实现反向代理",教您如何在阿里云上部署Nginx实现反向代理? 云中沙箱,阿里云官方实验平台.网址:http://lab.aliyunedu.net   一.基本概念 业务背景     在很多情况下,可能只有一个公网IP地址,但是内部有多个服务需要映射出去,如:www.domain.com,oa.domain.com,并且,相关的服务不在同一台服务器上面的时候,那直接做端口映射就无法达到要求了.这时设置反

linux安装nodejs脚本的教程

安装nodeJS之前,如果没有安装g++及 libssl-dev,则先要安装好,安装方法如下: $ sudo apt-get install g++ $ sudo apt-get install libssl-dev 接下来,就可以下载安装nodeJS了,目前稳定版本为 Node.js 0.6.18,下面是安装步骤: $ wget http://nodejs.org/dist/v0.8.16/node-v0.8.16.tar.gz $ tar zxvf node-v0.8.16.tar.gz $

Nginx的反向代理与负载均衡

1.1 集群是什么 简单地说,集群就是指一组(若干个)相互独立的计算机,利用高速通信网络组成的一个较大的计算机服务系统,每个集群节点(即集群中的每台计算机)都是运行各自服务的独立服器.这些服务器之间可以彼此通信,协同向用户提供应用程序.系统资源和数据,并以单一系统的模式加以管理.当用户客户机请求集群系统时,集群给用户的感觉就是一个单一独立的服务器,而实际上用户请求的是一组集群服务器. 打开谷歌.百度的页面,看起来好简单,也许你觉得用几分钟就可以制作出相似的网页,而实际上,这个页面的背后是由成千上

PHP使用Nginx实现反向代理

一.代理服务器 1.什么是代理服务器 代理服务器,客户机在发送请求时,不会直接发送给目的主机,而是先发送给代理服务器,代理服务接受客户机请求之后,再向主机发出,并接收目的主机返回的数据,存放在代理服务器的硬盘中,再发送给客户机. 2.为什么要使用代理服务器 1)提高访问速度 由于目标主机返回的数据会存放在代理服务器的硬盘中,因此下一次客户再访问相同的站点数据时,会直接从代理服务器的硬盘中读取,起到了缓存的作用,尤其对于热门站点能明显提高请求速度. 2)防火墙作用 由于所有的客户机请求都必须通过代