当前位置: 首页 > news >正文

校园网站建设促进教学谷歌的网站打不开

校园网站建设促进教学,谷歌的网站打不开,网络运维工程师证书怎么考,wordpress加入视频播放器1、A/B 测试 在文件或应用的两个或多个版本之间分割客户端流量#xff0c;以测试接受度或参与度。 使 用 split_clients 模块将一定比例的客户端流量定向到一个不同的上游#xff08;upstream#xff09;池#xff1a; split_clients ${remote_addr}AAA $var…1、A/B 测试 在文件或应用的两个或多个版本之间分割客户端流量以测试接受度或参与度。 使 用 split_clients 模块将一定比例的客户端流量定向到一个不同的上游upstream池 split_clients ${remote_addr}AAA $variant {20.0% backendv2;* backendv1; }split_clients 指令对作为第一个参数提供的字符串进行哈希处理并用该哈希值除以提供的百分比以映射作为第二个参数提供的变量的值。在第一个参数中添加“AAA”是为了证明这是一个可以包含多个变量的串联字符串如通用哈希负载均衡算法中所述。第三个参数是一个包含键值key-value对的对象其中键是百分比权重值是要分配的值。键可以是百分比或星号。星号表示取完所有百分比后的剩余部分。对于 $variant 变量的值backendv2 为客户端 IP 地址流量的 20%backendv1 为其余80%。 在此示例中backendv1 和 backendv2 表示上游服务器池可以与 proxy_pass 指令一起使用如下所示 location / {proxy_pass http://$variant }使用变量 $variant 时我们的流量将会分配给两个不同的应用服务器池。 为了理解 split_clients 的广泛用途我们通过一个例子来看看两个静态站点版本之间的流量分割 http {split_clients ${remote_addr} $site_root_folder {33.3% /var/www/sitev2/;* /var/www/sitev1/;}server {listen 80 _;root $site_root_folder;location / {index index.html;}} }详解 在测试电子商务网站上不同类型的营销和前端功能的转化率时这种类型的 A/B 测试非常有用。应用通常通过“灰度发布”进行部署。在这种类型的部署中用户可以逐步增加路由到新版本的用户百分比进而将流量慢慢切换到新版本。在推出新版本的代码时在不同的应用版本之间分割客户端流量非常实用这可以降低发生错误后带来的影响。更常见的部署模式是蓝绿部署也就说在将用户切换到新版本的同时仍然保持旧版本在验证部署期间的可用性。无论出于何种原因在两组不同的应用之间分割客户端流量NGINX 的 split_client 模块都可以帮您轻松搞定。 参考资料 split_clients 模块文档 2、使用 GeoIP 模块和数据库 您需要安装 GeoIP 数据库并启用它在 NGINX 中的嵌入式变量以利用 NGINX 日志、被代理请求或请求路由中客户端的物理位置。 安装 NGINX 时官方 NGINX 开源版软件包仓库配置方式见第 2 章提供了一个名为 nginx-module-geoip 的软件包。当使用 NGINX Plus 软件包仓库时该软件包被命名为 nginx-plus-module-geoip。以下示例展示了如何安装动态 NGINX GeoIP 模块软件包以及如何下载 GeoIP 国家/地区和城市数据库 RHEL/CentOS NGINX 开源版 # yum install nginx-module-geoip Debian/Ubuntu NGINX 开源版 # apt-get install nginx-module-geoip RHEL/CentOS NGINX Plus # yum install nginx-plus-module-geoip Debian/Ubuntu NGINX Plus # apt-get install nginx-plus-module-geoip 下载 GeoIP 国家/地区和城市数据库并解压 # mkdir /etc/nginx/geoip # cd /etc/nginx/geoip # wget http://geolite.maxmind.com/\ download/geoip/database/GeoLiteCountry/GeoIP.dat.gz # gunzip GeoIP.dat.gz # wget http://geolite.maxmind.com/\ download/geoip/database/GeoLiteCity.dat.gz # gunzip GeoLiteCity.dat.gz这组命令在 /etc/nginx 目录下创建了一个 geoip 目录请移动到这个新目录下载并解压软件包。 将 GeoIP 国家/地区和城市数据库保存到本地磁盘后就可以指示 NGINX GeoIP 模块使用它们根据客户端 IP 地址公开嵌入式变量了 load_module /usr/lib64/nginx/modules/ngx_http_geoip_module.so; http {geoip_country /etc/nginx/geoip/GeoIP.dat; geoip_city /etc/nginx/geoip/GeoLiteCity.dat;# ... }load_module 指令从它在文件系统中的路径动态加载模块。load_module 指令仅在main 上下文中有效。geoip_country 指令获取了 GeoIP.dat 文件的路径该文件包含将IP 地址映射到国家/地区代码的数据库并且仅在 http 上下文中有效。 详解 要使用此功能您必须先安装 NGINX GeoIP 模块以及本地 GeoIP 国家/地区和城市数据库本节演示了相关安装和检索教程。 geoip_country 和 geoip_city 指令暴露了该模块中可用的多个嵌入式变量。geoip_country 指令允许使用一些变量来区分客户端的来源地/国。这些变量包括 $ geoip_country_code、$geoip_country_code3 和 $geoip_country_name。country code 变量返回由两个字母组成的国家/地区代码以 3 结尾的变量返回由三个字母组成的国家/地区代码。country name 变量返回国家/地区的全名。 geoip_city 指令启用了相当一部分变量。geoip_city 指令启用了与 geoip_country 指令相同的所有变量只不过名称不一样例如 $ geoip_city_country_code、$ geoip_city_country_code3 和 $ geoip_city_country_name。其他变量包括 $ geoip_city、$ geoip_lati tude、$ geoip_longitude、$ geoip_city_continent_code 和 $ geoip_postal_code所有这些都是它们返回的值的描述性变量。$geoip_region 和 $geoip_region_name 描 述了地区、领地、州、省、联邦土地等。Region 是由两个字母组成的代码而 region name 是全名。$geoip_area_code仅在美国有效返回三位电话区号。您可以利用这些变量记录您的客户端信息。您可以选择性地将此信息作为请求头或变量传输给应用也可以使用 NGINX 以特定的方式路由流量。 参考资料 geoip 模块文档 GeoIP Update GitHub 3、基于国家/地区的访问限制 根据合同或应用要求限制来自特定国家/地区的访问。 将您要阻止或允许的国家代码映射到变量 load_module /usr/lib64/nginx/modules/ngx_http_geoip_module.so; http {map $geoip_country_code $country_access { US 0;default 1;}# ... }此映射会将新变量 $country_access 设置为 1 或 0。如果客户端 IP 地址来自美国该变量将设置为 0如果客户端 IP 地址来自其他国家/地区该变量将设置为 1。 现在在我们的 server 代码块中我们将使用 if 语句来拒绝来自美国以外的任何人的访问 server {if($country_access 1) { return 403;}# ... }如果 $country_access 变量设置为 1则这个 if 语句的计算结果为 True。如果为 True服务器将返回 403 unauthorized否则服务器就正常运行。因此这个 if 代码块只是用来拒绝非美国地区的用户。 详解 这个例子简明扼要地说明了如何仅允许几个国家/地区的访问您可以根据自己的需求在此基础之上进行延伸。您可以借鉴这一做法根据 GeoIP 模块提供的任何嵌入式变量允许或阻止访问。 4、查找原始客户端 NGINX 服务器前面设置了代理您需要查找原始客户端 IP 地址。 使用 geoip_proxy 指令定义代理 IP 地址范围并使用 geoip_proxy_recursive 指令查找原始 IP load_module /usr/lib64/nginx/modules/ngx_http_geoip_module.so; http {geoip_country /etc/nginx/geoip/GeoIP.dat; geoip_city /etc/nginx/geoip/GeoLiteCity.dat; geoip_proxy 10.0.16.0/26; geoip_proxy_recursive on;# ... }geoip_proxy 指令定义了一个无类域间路由CIDR范围我们的代理服务器就在这个范围内并指示 NGINX 利用 X-Forwarded-For 请求头查找客户端 IP 地址。geoip_proxy_recursive 指令指示 NGINX 递归性地从 X-Forwarded-For 请求头中查找已知的最后一个客户端 IP。 Forwarded 请求头已经成为为被代理请求添加代理信息的标准请求头。NGINX GeoIP 模块使用的请求头是 X-Forwarded-For否则就无法在写入时进行配置。虽然 X-Forwarded-For 不是官方标准但仍然是被大多数代理广为使用、接受和设置的请求头。 详解 您可能会发现如果您在 NGINX 前面使用代理NGINX 将获取代理而非客户端的 IP 地址。对此当在给定范围内打开连接时您可以使用 geoip_proxy 指令指示NGINX 使用 X-Forwarded-For 请求头。geoip_proxy 指令使用一个地址或 CIDR 范围。当 NGINX 前面有多个传输流量的代理时您可以使用 geoip_proxy_recursive 指令递归性地从 X-Forwarded-For 地址中搜索和查找源客户端。当在 NGINX 前面使用Amazon Web Services Elastic Load BalancingAWS ELB、谷歌负载均衡器或Microsoft Azure 负载均衡器等负载均衡器时这种方法比较有用。 5、限制连接数 根据预定义的键例如客户端的 IP 地址限制连接数。 构造一个共享内存区来保存连接指标并使用 limit_conn 指令限制打开的连接数 http {limit_conn_zone $binary_remote_addr zonelimitbyaddr:10m; limit_conn_status 429; # ...server {# ...limit_conn limitbyaddr 40;# ...} }此配置创建了一个名为 limitbyaddr 的共享内存区。使用的预定义键是二进制形式的客户端 IP 地址。共享内存区的大小设置为 10 MB。limit_conn 指令使用两个参数limit_conn_zone 名称和允许的连接数量。limit_conn_status 定义了连接状态被限制为 429 时的响应此时表示响应过多。limit_conn 和 limit_conn_status 指令在 http、server 和 location 上下文中有效。 详解 通过使用键来限制连接数量您不仅能够防止滥用而且还能在所有客户端之间公平共享资源。请务必谨慎使用预定义键。正如我们在前面的示例中所示如果许多用户位于源自同一 IP 地址的同一网络上例如当在网络地址转换NAT后面时使用 IP 地址是不合理的这会使整个客户端组受到限制。limit_conn_zone 指令仅在 http 上下文中有效。您可以利用 NGINX 在 http 上下文中任意数量的可用变量来构建一个限制字符串。有一种更简洁的方法是根据具体的用例利用一个变量例如会话 cookie识别应用层的用户。limit_conn_status 默认值为 503 时代表服务不可用。由于服务可用我们最好使用 429而 500 级的响应码表示服务器错误400 级的响应码表示客户端错误。 测试限制可能是个很棘手的问题测试方案通常很难在替代环境中模拟实时流量。在这种情况下您可以将 limit_req_dry_run 指令设置为 on然后使用访问日志中的变量 $ limit_req_status。$limit_req_sta tus 变量将计算为 PASSED、DELAYED、REJECTED、DELAYED_DRY_RUN 或 REJECTED_DRY_RUN。启用 dry run 后您将能够分析实时流量日志并在真正实施限制前根据需要调整限制从而确保您的限制配置正确。 6、限制速率 通过预定义的键例如客户端的 IP 地址来限制请求的速率。 利用限速模块限制请求速率 http {limit_req_zone $binary_remote_addrzonelimitbyaddr:10m rate3r/s;limit_req_status 429;# ...server {# ...limit_req zonelimitbyaddr;# ...} }此示例配置创建了一个名为 limitbyaddr 的共享内存区。使用的预定义键是二进制形式的客户端 IP 地址。共享内存区的大小设置为 10 MB。该区域使用关键字参数设置速率。limit_req 指令使用了一个必不可少的关键字参数zone。zone 指示了要使用哪个共享内存请求限制区的指令。根据 limit_req_status 指令的定义超过明示速率的请求将返回 429 HTTP 代码。建议设置一个 400 级范围的状态码因为默认值是 503这代表服务器有问题而实际问题是出在客户端方面。 使用 limit_req 指令的可选关键字参数来启用两级速率限制 server {location / {limit_req zonelimitbyaddr burst12 delay9;} }在某些情况下客户端需要同时发出许多请求此后先在一段时间内降低速率然后再发出更多请求。您可以使用关键字参数 burst 允许客户端超过其速率限制但不拒绝其请求。超出速率的请求将延迟处理以将速率限制匹配到配置的值。有一组关键字参数可以改变这种行为即 delay 和 nodelay。nodelay 参数不带值只允许客户端一次性消耗所有流量突发值但是必须要先等待足够的时间直到满足速率限制要求为止否则所有请求都会被拒绝。在此示例中如果我们使用 nodelay客户端可以在第一秒消耗 12 个请求但是必须要在初始请求之后等待 4 秒才能发出另一个请求。delay 关键字参数定义了在不限流的情况下可以预先发出多少请求。在这种情况下客户端可以毫无延迟地预先发出 9 个请求接下来的 3 个将受到限制此后 4 秒内的任何请求都将被拒绝。 详解 限速模块非常强大可以防止滥用快速请求同时仍然为每个人提供优质服务。限制请求速率的原因有很多安全性就是其中之一。您可以通过严格限制登录页面的速率来防御暴力破解攻击。您可以对所有请求设置合理的限制从而防止恶意用户试图对您的应用拒绝服务或浪费资源的不轨行为。限速模块的配置很像实操指南 3.5 中描述的连接限制模块并且存在许多相同的问题。您可以按照每秒限速也可以按照每分钟限速。当达到速率限制时日志就会记录事件。此外还有一条指令没有在示例中给出limit_req_log_level它的默认值为 error您也可以把它设置为 info、notice 或warn。 测试限制可能是个很棘手的问题测试方案通常很难在替代环境中模拟实时流量。在这种情况下您可以将 limit_req_dry_run 指令设置为 on然后使用访问日志中的变量 $ limit_req_status。$limit_req_status 变量将计算为 PASSED、REJECTED 或REJECTED_DRY_RUN。启用 dry run 后您将能够分析实时流量日志并在真正实施限制前根据需要调整限制从而确保您的限制配置正确。 7、限制带宽 按客户端限制资产的下载带宽。 使用 NGINX 的 limit_rate 和 limit_rate_after 指令限制响应客户端的带宽 location /download/ { limit_rate_after 10m; limit_rate 1m; }这个 location 代码块的配置指定对于前缀为 download 的 URI向客户端提供响应的速率将在 10 MB 之后被限制为每秒 1 MB。带宽限制是针对每个连接的因此您可能希望在适用的情况下配合使用连接限制和带宽限制。 详解 通过限制特定连接的带宽NGINX 能够以您指定的方式在所有客户端上共享其上传带宽并且只需 limit_rate_after 和 limit_rate 这两个指令就可以做到这一点。limit_rate_after 指令几乎可以在任何上下文中进行设置包括 http、server、location 以及location 代码块内的 if。limit_rate 指令的适用上下文与 limit_rate_after 相同但是它还可以通过一个名为 $limit_rate 的变量进行设置。 limit_rate_after 指令规定在传输指定数量的数据之前不得限制连接的速率。limit_rate 指令指定了给定上下文中的速率限制默认单位是每秒字节数但是您也可以设置为 m兆字节或 g千兆字节。这两条指令的默认值都是 0表示不对下载速率进行任何限制。此模块允许您以编程方式更改客户端的速率限制。
http://www.zqtcl.cn/news/582366/

相关文章:

  • 微云影视自助建站系统大理州建设局网站门户网
  • 构建网站需要会什么意思辽宁省朝阳网站建设
  • 网站建设捌金手指专业1公司域名邮箱注册
  • 建设工程协会网站建设工程合同属于专属管辖吗
  • 网站建设费可分摊几年电子商务网站建设基础
  • wordpress api 发贴北京网站优化seo
  • 青岛网站制作服务商wordpress红包
  • 网站响应式设计如何提高网站文章收录
  • 网站 橙色如何做自己网站的seo
  • 网上商城网站建设公司兰州网站制作公司怎么样
  • 网站的动态图怎么做的获取网站访客qq
  • 黑龙江网站建站建设知名品牌形象设计公司
  • 网站建设去哪可接单怎么做微信小程序平台
  • 做外贸重新设计网站兰州网站建设慕枫
  • 服装销售 网站建设论文搭建企业网站需要什么
  • cnnic网站备案html网站建设代码
  • 金华网站建设明细报价表c苏宁网站开发
  • 在手机上怎么做微电影网站湖南人工智能建站系统软件
  • 网站做的一样算侵权吗站群建站系统
  • 骨干专业建设验收网站xueui wordpress
  • 宁波高质量品牌网站设计厂家世界上有php应用的网站
  • 网站平台建设的重要性响应式网站切图
  • 近期做网站需要什么软件网站制作常见的问题
  • vs做的本地网站甘肃省建设厅门户网站
  • 网站建设合同义务wordpress m1
  • 青海省建设局网站首页wordpress模板建站教程视频
  • 演示 又一个wordpress站点静态页面加wordpress
  • 企业做淘宝客网站有哪些有网站吗给一个
  • 深圳网站制作公司信息之梦与wordpress哪个好用
  • 免费搭建商城网站山西制作网站公司排名