反向代理:一般是指服务器被代理。
正向代理:自己的客户端被代理,例如,vpn。
1、http服务器有:
1)、iis
2)、apache
3)、tomcat 动态接口,实现业务从数据库抓取资源,动态资源,给java开发的
4)、lighttpd
5)、nginx
网关:网络层数据出入口
网关服务器:应用层数据的出入口,代理服务器,数据先转发到代理服务器,再转发到其他服务器。
nginx为什么引用广泛:
1)、开源用c写的,优势代码容易读。
2)、非常完善的文档。
3)、持续的更新。
4)、在开源之前,已经在高并发的应用。
哪些场景下可以用nginx:
1)、用到网络相关的,tcp以上,nginx可以使用
2)、游戏,实时游戏过程不适用,购买商品时可以用到
3)、桌面,qt、mfc、中间去请求的信息,
4)、嵌入式,车载服务器,nginx支持mqtt协议
运用nginx的大部分需求都可以通过修改conf文件满足。
nginx运行方式:1主进程(master)+n个工作进程(work)。
master进程listen端口,不响应链接,不进行accpet,recv,send。
worker进程不响应具体事件,操作被继承到fd,进行accpet,recv,send。
惊群现象:多个工作进程同时处理1个fd
解决方案:在某一个时刻只有一个fd在epoll里,加全局锁(一个变量而已),循环判断fd,某进程中判断如果fd中的锁标志为1,则将该fd加入该epoll,并将锁标志置为0,其他进程中,判断该锁标志为0,则不会将该fd加入到自己进程中的epoll。
惊群锁:如何实现?共享内存,文件锁,ipc。
一个进程如何监听多个端口?每个端口对应一个listenfd,将listenfd加入到epoll中就可以了。
config配置文件:
worker_processes 4; #启动进程个数
http { server { location ~ \.cgi { #对应cgi upstream backend {#被代理的服务器集合,默认轮转方法 server {
location / { #对外提供服务资源所在的位置 } |
2、用nginx代理服务器:
代理和重定向区别:重定向有重新建链过程,而代理没有。