怎么为Node.js程序配置使用Nginx服务器
发布时间 - 2023-05-13 00:00:00 点击率:次node.js是一个基于chrome javascript运行时建立的平台, 用于方便地搭建响应速度快、易于扩展的网络应用。node.js 使用事件驱动, 非阻塞i/o 模型而得以轻量和高效,非常适合在分布式设备上运行的数据密集型的实时应用,如实时聊天等等。然而对于gzip编码,静态文件,http缓存,ssl处理,负载平衡和反向代理等,都可以通过nginx来完成,从而减小node.js的负载,并通过nginx强大的缓存来节省网站的流量从而提高网站的加载速度。
流程图
nginx配置如下:
http {
proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=one:8m max_size=3000m inactive=600m;
proxy_temp_path /var/tmp;
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
gzip on;
gzip_comp_level 6;
gzip_vary on;
gzip_min_length 1000;
gzip_proxied any;
gzip_types text/plain text/html text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;
gzip_buffers 16 8k;
ssl_certificate /some/location/sillyfacesociety.com.bundle.crt;
ssl_certificate_key /some/location/sillyfacesociety.com.key;
ssl_protocols sslv3 tlsv1;
ssl_ciphers high:!anull:!md5;
upstream silly_face_society_upstream {
server 127.0.0.1:61337;
server 127.0.0.1:61338;
keepalive 64;
}
server {
listen 80;
listen 443 ssl;
server_name sillyfacesociety.com;
return 301 $scheme://www.sillyfacesociety.com$request_uri;
}
server {
listen 80;
listen 443 ssl;
server_name www.sillyfacesociety.com;
error_page 502 /errors/502.html;
location ~ ^/(images/|img/|javascript/|js/|css/|stylesheets/|flash/|media/|static/|robots.txt|humans.txt|favicon.ico) {
root /usr/local/silly_face_society/node/public;
access_log off;
expires max;
}
location /errors {
internal;
alias /usr/local/silly_face_society/node/public/errors;
}
location / {
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 x-forwarded-proto $scheme;
proxy_set_header host $http_host;
proxy_set_header x-nginx-proxy true;
proxy_set_header connection "";
proxy_http_version 1.1;
proxy_cache one;
proxy_cache_key sfs$request_uri$scheme;
proxy_pass http://silly_face_society_upstream;
}
}
}配置段说明
http {
...
upstream silly_face_society_upstream {
server 127.0.0.1:61337;
server 127.0.0.1:61338;
keepalive 64;
}
...
}nginx负载均衡多个nodo.js实例。keepalive 64 指示nginx在任何时候保持最少64个http/ 1.1连接到代理服务器。如果有更多的流量nginx将打开更多的连接。
http {
...
server {
...
location / {
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;
...
proxy_set_header connection "";
proxy_http_version 1.1;
proxy_pass http://silly_face_society_upstream;
}
...
}
}将符合哪些的请求发送到代理上。nginx的匹配规则可以取看看前面的文章。
nginx处理静态内容
http {
...
server {
...
location ~ ^/(images/
|img/|javascript/|js/|css/|stylesheets/|flash/|media/|static/|robots.txt|humans.txt|favicon.ico) {
root /usr/local/silly_face_society/node/public;
access_log off;
expires max;
}
...
}
}设置缓存
http {
...
proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=one:8m max_size=3000m inactive=600m;
proxy_temp_path /var/tmp;
...
}
http {
server {
...
location / {
...
proxy_cache one;
proxy_cache_key sfs$request_uri$scheme;
...
}
...
}
}缓存是通过http头部来控制的。
helloworld
试验一下,我们来写个helloworld.js
var http = require('http');
http.createserver(function (request, response) {
response.writehead(200, {'content-type': 'text/plain'});
response.end('hello world\n');
}).listen(61337);
console.log('server running at http://127.0.0.1:61337/');然后用node helloworld.js指令开启,这样跑在本地的机子的nodejs的程序就算开起来了,占用的是8000端口,可自己修改。
此时确定在nginx的vhost.conf里面的设置应有:
server {
listen 80;
server_name jb51.net.jb51.net;
location / {
proxy_pass http://127.0.0.1:61337;
}
}将网站域名设置好,然后端口设置为80,最后proxy_pass设置为http://127.0.0.1:61337,将所有从jb51.net:80的请求传递到nodejs程序去。
重启nginx、访问域名,就可以了看到helloworld了。
虽然node.js本身就可以做服务器是没错啦,比如welcome.js里面设置为80端口就可以了。
但是一个机子跑多个网站,其他网站又是用别的服务器,在80端口已经被占用的情况下,是可以用代理到别的端口来处理的。
# node.js
# nginx
# JavaScript
# 分布式
# chrome
# .net
# JS
# 事件
# http
# ssl
# 负载均衡
# 设置为
# 就可以
# 多个
# 的是
# 是一个
# 来了
# 又是
# 可以用
# 可以通过
# 发送到
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel中的withCount方法怎么高效统计关联模型数量
HTML5空格和nbsp有啥关系_nbsp的作用及使用场景【说明】
Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康
网页制作模板网站推荐,网页设计海报之类的素材哪里好?
网站制作壁纸教程视频,电脑壁纸网站?
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
Laravel如何升级到最新版本?(升级指南和步骤)
ChatGPT 4.0官网入口地址 ChatGPT在线体验官网
为什么要用作用域操作符_php中访问类常量与静态属性的优势【解答】
Laravel怎么发送邮件_Laravel Mail类SMTP配置教程
如何使用 jQuery 正确渲染 Instagram 风格的标签列表
Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程
linux top下的 minerd 木马清除方法
大连网站制作公司哪家好一点,大连买房网站哪个好?
如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?
详解Huffman编码算法之Java实现
Java解压缩zip - 解压缩多个文件或文件夹实例
Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】
高防服务器:AI智能防御DDoS攻击与数据安全保障
Laravel怎么进行数据库事务处理_Laravel DB Facade事务操作确保数据一致性
详解vue.js组件化开发实践
北京网站制作公司哪家好一点,北京租房网站有哪些?
Laravel怎么使用artisan命令缓存配置和视图
网站优化排名时,需要考虑哪些问题呢?
Chrome浏览器标签页分组怎么用_谷歌浏览器整理标签页技巧【效率】
微信小程序 scroll-view组件实现列表页实例代码
高端企业智能建站程序:SEO优化与响应式模板定制开发
Laravel如何实现API资源集合?(Resource Collection教程)
非常酷的网站设计制作软件,酷培ai教育官方网站?
厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?
如何有效防御Web建站篡改攻击?
PHP 实现电台节目表的智能时间匹配与今日/明日轮播逻辑
轻松掌握MySQL函数中的last_insert_id()
PHP正则匹配日期和时间(时间戳转换)的实例代码
为什么php本地部署后css不生效_静态资源加载失败修复技巧【技巧】
Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】
Laravel的HTTP客户端怎么用_Laravel HTTP Client发起API请求教程
Laravel如何实现邮箱地址验证功能_Laravel邮件验证流程与配置
装修招标网站设计制作流程,装修招标流程?
Laravel如何安装Breeze扩展包_Laravel用户注册登录功能快速实现【流程】
简单实现jsp分页
利用python获取某年中每个月的第一天和最后一天
手机网站制作与建设方案,手机网站如何建设?
制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?
Laravel怎么使用Blade模板引擎_Laravel模板继承与Component组件复用【手册】
使用豆包 AI 辅助进行简单网页 HTML 结构设计
如何在宝塔面板创建新站点?
JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)
Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程
Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】
上一篇:微信抽签怎么操作?
上一篇:微信抽签怎么操作?


|img/|javascript/|js/|css/|stylesheets/|flash/|media/|static/|robots.txt|humans.txt|favicon.ico) {
root /usr/local/silly_face_society/node/public;
access_log off;
expires max;
}
...
}
}