配置虚拟主机-部署nginx代理并验证缓存生效
http {
include /usr/local/nginx/conf/vhost/*;
}
mkdir -p /usr/local/nginx/conf/vhost/
touch /usr/local/nginx/conf/vhost/www.fdd{1..3}.com 三个虚拟主机均配置相同
cat >/usr/local/nginx/conf/vhost/www.fdd1.com<<EOF
server {
listen 80;
server_name www.fdd1.com;
location / {
root html/www.fdd1.com;
index index.html index.htm;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
EOF
mkdir -p /usr/local/nginx/html/www.fdd{1..3}.com
echo "this is www.fdd1.com">/usr/local/nginx/html/www.fdd1.com/index.html
echo "this is www.fdd2.com">/usr/local/nginx/html/www.fdd2.com/index.html
echo "this is www.fdd3.com">/usr/local/nginx/html/www.fdd3.com/index.html
echo "80">>/usr/local/nginx/html/index.html
echo "8080">>/usr/local/nginx/html/www.fdd1.com/index.html cat /usr/local/nginx/conf/nginx.conf
server {
listen 80;
server_name www.fdd1.com;
location / {
root html;
index index.html index.htm;
}
}
server {
listen 8080;
server_name www.fdd1.com;
location / {
root html/www.fdd1.com/;
index index.html index.htm;
}
}
curl www.fdd1.com curl www.fdd1.com:8080
复制网卡
cp /etc/sysconfig/network-scripts/ifcfg-ens33{,:1}
cat /etc/sysconfig/network-scripts/ifcfg-ens33
cd /etc/sysconfig/network-scripts/
修改ens33:1网卡中的IP为1.110, 网卡名称为ens33:1
sed -i 's/ens33/ens33:1/g;s/192.168.1.10/192.168.1.100/g' fcfg-ens33:1
重启网卡:
systemctl restart network
cat >/usr/local/nginx/conf/vhost/www.fdd100.com<<EOF
server {
listen 192.168.1.100:80;
server_name www.fdd100.com;
location / {
root html/www.fdd100.com;
index index.html index.htm;
}
}
mkdir -p /usr/local/nginx/html/www.fdd100.com
echo "this is www.fdd100.com 80" >/usr/local/nginx/html/www.fdd100.com/index.html
echo "192.168.1.100 www.fdd100.com" >>/etc/hosts
/usr/local/nginx/sbin/nginx -s reload
curl 192.168.1.100
location和proxy_pass都不带uri路径。
代理服务器: 192.168.1.10
后端服务器: 192.168.1.12
server {
listen 8080;
server_name 反代服务器IP;
location / {
proxy_pass web服务器IP;
proxy_redirect off;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
proxy_pass http://192.168.1.12;

echo $host; 主要是看下后端服务器的hosts是什么。


curl 192.168.1.10


location /data/www/ {
index index.html index.htm;
proxy_pass http://192.168.1.12;
}

cd /usr/local/nginx/html/
mkdir -p /data/www
echo "this is 192.168.1.12 后端服务器">/data/www/index.html
/usr/local/nginx/sbin/nginx -s reload

验证测试效果:当访问1.10代理服务器的/data/www/index.html资源时, 代理服务去将请求转发到了后端服务器,也就是访问到了后端服务去的资源:
curl 192.168.1.10/data/www/index.html

location / {
root html;
index index.html index.htm;
proxy_pass http://192.168.1.12/data/;
}

cd /usr/local/nginx/html/
echo "this is /usr/local/nginx/html/data test.">data/index.html
curl 192.168.1.10

proxy_pass http://192.168.1.12/data/;
proxy_set_header Host $hhost;
proxy_set_header X-Real-IP $remote_addr;

开启log_format日志访问收集功能模块 添加接受代理请求的IP $http_x_real_ip

curl 192.168.1.10

查看Nginx访问日志
tailf /usr/local/nginx/logs/access.log

缓存资源存放路径
/data/nginx/cache 设置缓存资源的递归级别,默认为levels=1:2,表示Nginx为将要缓存的资源
生成的key从后依次设置两级保存。
levels 在共享内存中设置一块存储区域来存放缓存的key和metadata,这样nginx可以快速
判断一个request是否命中或者未命中缓存,1m可以存储8000个key,10m可以存储80000个
key_zone 最大cache空间,如果不指定,会使用掉所有disk space,当达到配额后,
会删除不 活跃的cache文件
key max_size 未被访问文件在缓存中保留时间,本配置中如果60分钟未被访问则不论状态是否为 expired,
缓存控制程序会删掉文件。inactive默认是10分钟。需要注意的是,inactive和expired
配置项的含义是不同的,expired只是缓存过期,但不会被删除,inactive是删除指定时间内
未被访问的缓存文件
inactive 如果为off,则nginx会将缓存文件直接写入指定的cache文件中,而不是使用
temp_path存储,official建议为off,避免文件在不同文件系统中不必要的拷贝
use_temp_path 启用proxy cache,并指定key_zone。如果proxy_cache off表示关闭掉缓存。
proxy_cache
代理端服务器配置:
prxy_cache_path /data/nginx/cache max_size=10g levels=1:2 keys_zone=nginx_cache:10m inactive=60m use_temp_path=off;

proxy_cache nginx_cache;
proxy_cache_key $host$uri$is_args$args;
proxy_cache_valid 200 304 302 1d;

/usr/local/nginx/sbin/nginx -s reload
mkdir -p /data/nginx/cache



配置虚拟主机-部署nginx代理并验证缓存生效的更多相关文章
- Nginx安装、配置虚拟主机、反向代理、负载均衡
1. nginx安装 下载nginx: 官方网站: http://nginx.org/ 使用的版本是1.8.0版本. Nginx提供的源码. 1.1. 要求的安装环境 1.需要安装gcc的环境.y ...
- nginx配置虚拟主机、反向代理和负载均衡
为了实现这个功能,需要修改nginx的配置文件,将nginx.conf清理一下,使结构更清晰. worker_processes ; events { worker_connections ; } h ...
- wamp2.4.4 如何配置虚拟主机及反向代理(解决跨域问题)
一.找到安装目录下的httpd.conf文件 1. 删除Include conf/extra/httpd-vhosts.conf前面的#号(开启虚拟主机的配置) 2. 删除LoadModule pro ...
- 快速掌握Nginx(一) —— 安装Nginx和简单配置虚拟主机
Nginx安装和简单配置虚拟主机 1 Nginx简介 Nginx是近几年最火热的http.反向代理服务器,百度阿里等互联网公司也都在使用Nginx,它也可以用作邮件代理服务器.TCP/UDP代理服务器 ...
- nginx之安装、多虚拟主机、反向代理和负载均衡
一.web服务器与web框架 1.web服务器简介 Web 网络服务是一种被动访问的服务程序,即只有接收到互联网中其他主机发出的请求后才会响应,最终用于提供服务程序的Web服务器会通过 HTTP(超文 ...
- nginx的虚拟主机和反向代理和一些技巧应用
前言 nginx是什么,一般用来做反向代理,也可以用来放静态htnl等文件..当然代理tcp协议也没啥问题,但做好是别用哈.性能不咋样. 虚拟主机 什么是虚拟主机? 个人理解,比如一台主机装一个ngi ...
- Nginx安装及配置虚拟主机
nginx安装部分 依赖环境 yum -y install gcc zlib openssl-devel zlib-devel 1. 下载好下面两个包:nginx-1.8.1.tar.gz pcre- ...
- Nginx下配置虚拟主机的三种方法
Nginx下,一个server标签就是一个虚拟主机. 1.基于域名的虚拟主机,通过域名来区分虚拟主机——应用:外部网站 2.基于端口的虚拟主机,通过端口来区分虚拟主机——应用:公司内部网站,外部网站的 ...
- Nginx 配置实例-配置虚拟主机
Nginx 配置实例-配置虚拟主机 配置基于域名的虚拟主机 1. 配置域名为 aaa.domain.com 的虚拟主机 1.1 nginx 中虚拟主机的配置 1.2 相关目录及文件的创建 1.3 验证 ...
- nginx 配置虚拟主机
文章转载自:http://www.ttlsa.com/html/1571.html 上篇说道我们的nginx是安装在/usr/local/nginx/ cd conf 我们现在把所有的虚拟主机放在一个 ...
随机推荐
- Unity中的RegisterPlugins:深入解析与实用案例
Unity中的RegisterPlugins:深入解析与实用案例 在Unity游戏开发中,我们经常需要使用第三方插件来实现一些特定的功能.为了让这些插件能够在Unity中正常工作,我们需要对它们进行注 ...
- Socket 入坑
什么是Socket Socket(套接字)是在计算机网络中实现通信的一种机制.它提供了一种应用程序编程接口(API),允许应用程序通过网络进行数据传输和通信. 在网络通信中,Socket 可以被看作是 ...
- NativeBuferring,一种零分配的数据类型[下篇]
上文说到Unmanaged.BufferedBinary和BufferedString是NativeBuffering支持的三个基本数据类型,其实我们也可以说NativeBuffering只支持Unm ...
- JDV背后的技术-助力618
一.项目介绍 JDV(可视化大屏)是京东内部搭建可视化大屏的数据工具平台,内置10+种模版特效,40+种风格各异的图表.导航等组件.与集团其他数据工具打通,支持一站式.自助化.拖拽式搭建大屏,实现数据 ...
- jmeter对请求响应结果进行整段内容提取方法
通过正则表达式提取器,将上一个请求(A请求)响应数据中的整段内容提取,传给下一个需要该提取数据的请求(B请求). 1. 请求接口响应结果 2. 添加正则表达式提取器 设置变量名为"tt&qu ...
- N1nEmAn-2023集训wp
week1 2022-12-28 WP 0x00 T1 reverse3 前几天没注意到要发wp,现在补一下.最近在学汇编,pwn题没做新的了.想到之前了解到hws的pwn会考花指令,听hjx他们说那 ...
- SpringBoot3集成RocketMq
标签:RocketMq5.Dashboard: 一.简介 RocketMQ因其架构简单.业务功能丰富.具备极强可扩展性等特点被广泛应用,比如金融业务.互联网.大数据.物联网等领域的业务场景: 二.环境 ...
- CutLER:一种用于无监督目标检测和实例分割的方法
本文分享自华为云社区<CutLER:一种用于无监督目标检测和实例分割的方法>,作者:Hint. 目标检测是计算机视觉中的一种重要任务,使AI系统感知.推理.理解目标.训练定位模型需要特别的 ...
- vscode 中 Markdown 粘贴图片的位置
背景 自从 typora 开始收费后, 不少人开始寻找其他的 Markdown编辑器, 我觉得 vscode 就是一个很不错的选择 虽然不能像 typora 在Markdown预览中编辑, 但是左右布 ...
- WPF-实现屏幕截图(一)
源码路径:https://gitee.com/LiuShuiRuoBing/wpf_screen_cut 实现功能 实现基本的截屏窗体 鼠标随意选择截图区域 鼠标抬起时弹出按钮区 快捷键Ctrl+Al ...