nginx基础知识
原文链接:https://juejin.cn/post/6844904129987526663
nginxg常用命令
# 启动ningx
service nginx start
# 停止nginx
service nginx stop
# 热重载nginx
sudo nginx -s reload
# 强制停止nginx
sudo pkill -9 nginx
默认配置文件存放处:/etc/nginx
默认根目录:/var/www
nginx配置文件简介
# 首尾配置暂时忽略
server {
# 当nginx接到请求后,会匹配其配置中的server模块
# 匹配方法就是将请求携带的host和port去跟配置中的server_name和listen相匹配
listen 8080;
# 定义当前虚拟主机(站点)匹配请求的主机名
server_name localhost;
location / {
# Nginx默认路径
root html;
# 设定Nginx服务器返回的文档名
# 先找根目录下的index.html,如果没有再找index.htm
index index.html index.htm;
}
}
server块包含在http块内部,每一个server都是一个站点
上面代码块的意思是:当一个请求叫做localhost:8080请求nginx服务器时,该请求就会被匹配进该代码块的server块中。
nginx中文文档www.nginx.cn/doc/
主要应用
动静分离
server {
listen 8883;
server_name 192.168.2.139;
location / {
root /devProject/test_project;
index index.html index.htm;
}
# 动静分离配置
# 静态配置 所有静态请求都转发给nginx处理 存放目录为test_project
location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|js|css)$ {
root /devProject/test_project;
}
# 动态请求匹配到path为/api的就转发到8884端口处理
location /api/ {
proxy_pass http://192.168.2.139:8884;
}
}
反向代理
反向代理的作用:
- 保障应用服务器的安全(增加一层代理,可以屏蔽危险攻击,更方便的控制权限)
- 实现负载均衡(稍等~下面会讲)
- 实现跨域(号称是最简单的跨域方式)
server {
listen 8080;
server_name localhost;
location / {
root html; # Nginx默认值
index index.html index.htm;
}
# 反向代理配置,请求会被转发到8000端口
proxy_pass http://localhost:8000;
}。
反向代理的表现很简单。那上面的代码块来说,其实就是向nginx请求localhost:8080跟请求 http://localhost:8000 是一样的效果。(跟代购的原理一样)
这是一个反向代理最简单的模型,只是为了说明反向代理的配置。但是现实中反向代理多数是用在负载均衡中。
反向代理应用十分广泛,CDN 服务就是反向代理经典的应用场景之一。除此之外,反向代理也是实现负载均衡的基础,很多大公司的架构都应用到了反向代理。
负载均衡
在服务器集群中,Nginx 可以将接收到的客户端请求“均匀地”(严格讲并不一定均匀,可以通过设置权重)分配到这个集群中所有的服务器上。这个就叫做负载均衡。
负载均衡可以解决分摊服务器集群压力的问题。除此之外,Nginx还带有健康检查(服务器心跳检查)功能,会定期轮询向集群里的所有服务器发送健康检查请求,来检查集群中是否有服务器处于异常状态。
一旦发现某台服务器异常,那么在这以后代理进来的客户端请求都不会被发送到该服务器上(直健康检查发现该服务器已恢复正常),从而保证客户端访问的稳定性。
# 负载均衡:设置domain
upstream domain {
server localhost:8000;
server localhost:8001;
}
server {
listen 8080;
server_name localhost;
location / {
# root html; # Nginx默认值
# index index.html index.htm;
proxy_pass http://domain; # 负载均衡配置,请求会被平均分配到8000和8001端口
proxy_set_header Host $host:$server_port;
}
}
正向代理
正向代理跟反向道理正好相反。拿上文中的那个代购例子来讲,多个人找代购购买同一个商品,代购找到买这个的店后一次性给买了。这个过程中,该店主是不知道代购是帮别代买买东西的。那么代购对于多个想买商品的顾客来讲,他就充当了正向代理。
nginx 就是充当图中的 proxy。左边的3个 client 在请求时向 nginx 获取内容,server 是感受不到3台 client 存在的。
此时,proxy 就充当了3个 client 的正向代理。
正向代理,意思是一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。客户端才能使用正向代理。当你需要把你的服务器作为代理服务器的时候,可以用Nginx来实现正向代理。
科学 vpn(俗称FQ)其实就是一个正向代理工具。
本文作者:sy0313
本文链接:https://www.cnblogs.com/sunyan97/p/17097759.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步