在实际的应用中,你的nodejs项目可能需要部署到多台服务器上,nginx为我们提供了服务器解决方案,它可以将请求转发到不同的服务器上。
我们先巩固下几个概念:
什么是分布式?什么是集群?什么是负载均衡?
- 什么是分布式?
分布式是指将不同的业务分布在不同的地方。 - 什么是集群?
集群指的是将几台服务器集中在一起,实现同一业务。 - 什么是负载均衡?
负载均衡是由多台服务器以对称的方式组成一个服务器集合,每台服务器都具有等价的地位,都可以单独对外供应效力而无须其他服务器的辅助。经过某种负载分管技术,将外部发送来的央求均匀分配到对称结构中的某一台服务器上。
下面来开始使用nginx:
- 安装nginx,进入下载页面http://nginx.org/en/download.html: windows系统直接下载稳定版解压
Linux系统需要以下几个:
安装PCRE库,wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.39.tar.gz 安装zlib库,wget http://zlib.net/zlib-1.2.11.tar.gz 安装openssl,wget https://www.openssl.org/source/openssl-1.1.1a.tar.gz 安装nginx,wget http://nginx.org/download/nginx-1.14.2.tar.gz
- 配置nginx,在nginx的安装目录下找到nginx.conf(windows和linux配置基本相同),假设有两台服务器,一台8核,一台16核,怎么配置了?
首先在http节点下配置两台服务器的ip和权重
upstream server1 {
server xxx.xxx.xxx.xxx:3000 weight=1;
}
upstream server2{
server xxx.xxx.xxx.xxx:3001 weight=2;
}
然后添加两个server
server {
listen 3000;
server_name xxx.xxx.xxx.xxx;//IP地址
#charset koi8-r;
#access_log logs/host.access.log main;
location /api {
proxy_pass http://server1;
proxy_set_header Host $host:3000;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
server {
listen 3001;
server_name xxx.xxx.xxx.xxx;
#charset koi8-r;
#access_log logs/host.access.log main;
location /api {
proxy_pass http://server2;
proxy_set_header Host $host:3001;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
- location匹配规则
Location语法语法:location [=||*|^~] /uri/ { … }
= 表示精确匹配
^~ 表示uri以某个常规字符串开头,理解为匹配url路径即可。
nginx不对url做编码,因此请求为/static/20%/aa,可以被规则^~ /static/ /aa匹配到(注意是空格)。~ 表示区分大小写的正则匹配
~* 表示不区分大小写的正则匹配
!和!* 分别为区分大小写不匹配及不区分大小写不匹配的正则
/ 通用匹配,任何请求都会匹配到。
多个location配置的情况下匹配顺序为:
首先匹配=,其次匹配^~, 其次是按文件中顺序的正则匹配,最后是交给 / 通用匹配。当有匹配成功时候,停止匹配,按当前匹配规则处理请求。
nginx文档地址:http://nginx.org/en/docs/