编译安装
源码编译安装详细步骤此处不在赘述,一般步骤为:
- 确保系统安装了编译工具,如gcc、make。及一些库文件,如PCRE、openSSL。
- 下载nginx源代码。
- 配置编译选择,运行 ./configure 指定安装路径以及需要的模块和选项。
- 编译
- 安装
反向代理
使用 Nginx 作为反向代理是将客户端请求转发给一个或多个后端服务器的过程。反向代理隐藏了后端服务器的实际地址和细节,使得客户端无法直接访问后端服务器。nginx在做反向代理服务器的前提下,可以使用负载均衡来缓解单个服务器的压力,避免宕机的情况。
nginx反向代理的写法 在nginx.conf文件中 http中的server下 ,使用location。
下面的配置就是反向代理 ,只要我们访问http://a 就会指向http://192.168.84.135/a 的
访问http://t 则会指向http://192.168.84.135/
http {
include mime.types;
default_type application/octet-stream;
server {
listen 443 ssl;
server_name localhost;
location /a {
#将请求转到了 192.168.84.135 ,80端口,是一个vms中的apache服务
proxy_pass http://192.168.84.135:80;
}
location /t {
#将请求转到了 192.168.84.135 ,81端口,是一个vms中的tomcat服务
proxy_pass http://192.168.84.135:81;
}
}
负载均衡
写负载均衡,使用upstream,还是在nginx.conf文件中的http下,与serve平级
http {
include mime.types;
default_type application/octet-stream;
upstream loadbalancing{
#访问load balancing的请求会被随机分配到下面的服务器的IP weight表权重
sever 192.168.84.135:80 weight= 1;
server 192.168.84.135:81 weight= ;
}
server {
listen 443 ssl;
server_name localhost;
location /a {
#将请求转到了 192.168.84.135 ,80端口,是一个vms中的apache服务
proxy_pass http://loadbalancing;
}
}
常见的负载均衡算法
补充一下nginx常用的一些负载均衡的算法
-
轮询(Round Robin):
- 这是最简单的算法,将请求依次分配给每个后端服务器,循环进行。每个请求都会被发送到下一个服务器,直到所有服务器都收到了相同数量的请求。
-
IP Hash:
- 根据客户端的 IP 地址计算一个 hash 值,然后使用该值来确定将请求发送到哪个后端服务器。这确保了相同的客户端 IP 总是被分配到同一台后端服务器,有助于维护会话状态。
-
Least Connections:
- 请求将被发送到当前连接数最少的服务器。这有助于避免将请求发送到负载较高的服务器,以确保更平均地分配负载。
-
权重轮询(Weighted Round Robin):
- 每个服务器被分配一个权重值,根据权重来决定分配请求的频率。具有更高权重的服务器将收到更多的请求,实现更灵活的负载均衡。
-
权重最小连接数(Weighted Least Connections):
- 类似于Least Connections,但是每个服务器的连接数会乘以一个权重值,从而影响负载均衡的决策。
-
基于响应时间的负载均衡:
- 根据后端服务器的响应时间动态地调整权重,以确保响应时间较短的服务器获得更多的请求。