一文读懂Nginx
扫描二维码
随时随地手机看文章
Nginx知识网结构图
客户端无法感知代理,因为客户端访问网络不需要配置,只要把请求发送到反向代理服务器,由反向代理服务器去选择目标服务器获取数据,然后再返回到客户端,此时反向代理服务器和目标服务器对外就是一个服务器,暴露的是代理服务器地址,隐藏了真实服务器IP地址。
[root@localhost pcre-8.37] # pcre-config --version
[root@localhost pcre-8.37]# yum -y make zlib zlib-devel gcc-c++ libtool openssl openssl-devel
cd /usr/local/nginx/sbin
[root@localhost sbin]# ps -ef|grep nginx
Linux系统
[root@localhost ~]yum install gcc-c++
[root@localhost ~]yum install -y pcre pcre-devel
[root@localhost ~]yum install -y zlib zlib-devel
[root@localhost ~]yum install -y openssl openssl-devel
[root@localhost ~]tar zxf nginx-1.8.0.tar.gz
./configure
–prefix=/usr/local/nginx
–pid-path=/var/run/nginx/nginx.pid
–lock-path=/var/lock/nginx.lock
–error-log-path=/var/log/nginx/error.log
–http-log-path=/var/log/nginx/access.log
–with-http_gzip_static_module
–http-client-body-temp-path=/var/temp/nginx/client
–http-proxy-temp-path=/var/temp/nginx/proxy
–http-fastcgi-temp-path=/var/temp/nginx/fastcgi
–http-uwsgi-temp-path=/var/temp/nginx/uwsgi
–http-scgi-temp-path=/var/temp/nginx/scgi
[root@localhost sbin]# mkdir /var/temp/nginx/client -p
[root@localhost sbin]# ./nginx
[root@localhost sbin]# ./nginx -s stop
[root@localhost sbin]# ./nginx -s quit
./nginx -v
./nginx
./nginx -s stop
./nginx -s quit
./nginx -s reload
location[ = | ~ | ~* | ^~] url{
}
=:用于不含正则表达式的url前,要求字符串与url严格匹配,匹配成功就停止向下搜索并处理请求
~:用于表示url包含正则表达式,并且区分大小写
~*:用于表示url包含正则表达式,并且不区分大小写
^~:用于不含正则表达式的url前,要求Ngin服务器找到表示url和字符串匹配度最高的location后,立即使用此location处理请求,而不再匹配
如果有url包含正则表达式,不需要有~开头标识
访问http://192.168.25.132:9001/edu/直接跳转到192.168.25.132:8080
访问http://192.168.25.132:9001/vod/直接跳转到192.168.25.132:8081
./nginx -s reload
./nginx -s reload
两台Nginx服务器
安装Keepalived
虚拟IP
[root@192 usr] # rpm -q -a keepalived
keepalived-1.3.5-16.el7.x86_64
[root@192 keepalived]# cd /etc/keepalived
[root@192 keepalived]# vi keepalived.conf
global_defs {
notification_email {
acassen@firewall.loc
failover@firewall.loc
sysadmin@firewall.loc
}
notification_email_from Alexandre.Cassen@firewall.loc
smtp_server 192.168.25.147
smtp_connect_timeout 30
router_id LVS_DEVEL # 访问的主机地址
}
vrrp_script chk_nginx {
script "/usr/local/src/nginx_check.sh" # 检测文件的地址
interval 2 # 检测脚本执行的间隔
weight 2 # 权重
}
vrrp_instance VI_1 {
state BACKUP # 主机MASTER、备机BACKUP
interface ens33 # 网卡
virtual_router_id 51 # 同一组需一致
priority 90 # 访问优先级,主机值较大,备机较小
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.25.50 # 虚拟ip
}
}
[root@192 sbin]# systemctl start keepalived.service
Worker数应该和CPU数相等
一个Master多个Worker可以使用热部署,同时Worker是独立的,一个挂了不会影响其他的。
特别推荐一个分享架构+算法的优质内容,还没关注的小伙伴,可以长按关注一下:
长按订阅更多精彩▼
如有收获,点个在看,诚挚感谢
免责声明:本文内容由21ic获得授权后发布,版权归原作者所有,本平台仅提供信息存储服务。文章仅代表作者个人观点,不代表本平台立场,如有问题,请联系我们,谢谢!