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

【开端】 进行页面升级或维护时不影响用户体验NGINX配置

一、绪论
  在网站管理中,经常需要进行页面升级或维护,而为了不影响用户体验,我们可以设置一个访问页面,在页面升级期间,用户访问网站时会直接跳转到该页面。本文将介绍如何设置访问页面进行升级,以确保用户的顺畅访问和良好体验。

二、NGINX配置

首先,创建一个包含维护信息的 HTML 文件,比如 maintenance.html

<!-- maintenance.html -->
<!DOCTYPE html>
<html>
<head><title>维护通知</title>
</head>
<body><h1>系统维护中</h1><p>系统正在维护,敬请期待。</p>
</body>
</html>

接下来,配置 NGINX 使得所有请求都重定向到这个维护页面

# /etc/nginx/nginx.conf 或相应的 NGINX 配置文件
 
server {
    listen 80;
    server_name yourdomain.com;
 
    location / {
        # 重定向所有请求到维护页面
        return 503;
        rewrite ^(.*)$ /maintenance.html break;
    }
 
    location = /maintenance.html {
        # 维护页面的位置
        root /path/to/your/html/files;
        internal;
    }
}

# /etc/nginx/nginx.conf 或相应的 NGINX 配置文件server {listen 80;server_name yourdomain.com;location / {# 重定向所有请求到维护页面return 503;rewrite ^(.*)$ /maintenance.html break;}location = /maintenance.html {# 维护页面的位置root /path/to/your/html/files;internal;}
}

三、nginx的其他配置

nginx.conf

#user  nobody;
worker_processes  1;#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;#pid        logs/nginx.pid;events {worker_connections  1024;
}http {include       mime.types;default_type  application/octet-stream;#log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '#                  '$status $body_bytes_sent "$http_referer" '#                  '"$http_user_agent" "$http_x_forwarded_for"';#access_log  logs/access.log  main;sendfile        on;#tcp_nopush     on;#keepalive_timeout  0;keepalive_timeout  65;#gzip  on;server {listen       80;server_name  localhost;#charset koi8-r;#access_log  logs/host.access.log  main;location / {# root   html;#index  index.html index.htm;xproxy_pass   http://127.0.0.1:9090;	#代理地址proxy_set_header  Host $host;proxy_set_header   X-real-ip $remote_addr;proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;}#error_page  404              /404.html;# redirect server error pages to the static page /50x.html#error_page   500 502 503 504  /50x.html;location = /50x.html {root   html;}# proxy the PHP scripts to Apache listening on 127.0.0.1:80##location ~ \.php$ {#    proxy_pass   http://127.0.0.1;#}# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000##location ~ \.php$ {#    root           html;#    fastcgi_pass   127.0.0.1:9000;#    fastcgi_index  index.php;#    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;#    include        fastcgi_params;#}# deny access to .htaccess files, if Apache's document root# concurs with nginx's one##location ~ /\.ht {#    deny  all;#}}# another virtual host using mix of IP-, name-, and port-based configuration##server {#    listen       8000;#    listen       somename:8080;#    server_name  somename  alias  another.alias;#    location / {#        root   html;#        index  index.html index.htm;#    }#}#  HTTPS server配置server {listen       443 ssl;server_name  localhost;ssl			 on;	#开启SSLclient_max_body_size   0; #设置 不限制 文件上传大小,默认为1M charset utf-8;ssl_certificate      /usr/local/ca/local.crt;	#证书绝对路径ssl_certificate_key  /usr/local/ca/local.key;	#密钥绝对路径ssl_session_cache    shared:SSL:10m;	#设置会话缓存大小ssl_session_timeout  10m;	# 连接超时时间# ssl_ciphers  HIGH:!aNULL:!MD5;	#支持的算法,默认为OpenSSL的全部算法ssl_prefer_server_ciphers  on; #优先使用服务端的SSL密钥证书,默认为off location / {proxy_pass   http://127.0.0.1:8080;proxy_set_header  Host $host;proxy_set_header   X-real-ip $remote_addr;proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;}}    }

限制IP的频繁访问

http {

limit_req_zone $binary_remote_addr zone=mylimit:10m rate=20r/s;//同一个IP每秒20次请求

}

http
{limit_req_zone $binary_remote_addr zone=mylimit:10m rate=20r/s;//同一个IP每秒20次请求
}

配置只能通过域名访问

server {

listen 80 default_server; server_name _; # _ 表示无效域名 location / {

return 403;

}

}

server {listen 80 default_server;	server_name _;	# _ 表示无效域名location / {return 403;}
}

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 影像设备国产替代究竟有多重要?这家企业提前布局8K时代
  • object.defineProperty用法
  • 开放式耳机的优缺点有什么?本文为你讲解推荐一下!
  • encodeURI 确保特殊字符能够正确传输
  • 告别手动记录,音频转文字软件助力会议记录新高度
  • 【Android 设备上的所有相关 WiFi 命令和使用方法】
  • 【架构设计】安全架构设计
  • SpringBoot优雅的封装不同研发环境下(环境隔离)RocketMq自动ack和手动ack
  • Python爬虫—常用的网络爬虫工具推荐
  • 3.服务注册_服务发现
  • 口语笔记——非谓语动词
  • 【代码随想录训练营第42期 Day38打卡 - 动态规划Part6 - LeetCode 322. 零钱兑换 279.完全平方数 139.单词拆分
  • MyBatis-Plus联表查询(mybatis-plus-join)
  • 1.ftp简介
  • C++程序调用SetWindowsHookEx全局拦截键盘按键消息和窗口消息的Hook实例分享
  • [ JavaScript ] 数据结构与算法 —— 链表
  • 「面试题」如何实现一个圣杯布局?
  • 【跃迁之路】【444天】程序员高效学习方法论探索系列(实验阶段201-2018.04.25)...
  • Android开源项目规范总结
  • CoolViewPager:即刻刷新,自定义边缘效果颜色,双向自动循环,内置垂直切换效果,想要的都在这里...
  • MYSQL 的 IF 函数
  • nginx 配置多 域名 + 多 https
  • Vue组件定义
  • webpack4 一点通
  • WinRAR存在严重的安全漏洞影响5亿用户
  • 第十八天-企业应用架构模式-基本模式
  • 复习Javascript专题(四):js中的深浅拷贝
  • 机器学习 vs. 深度学习
  • 批量截取pdf文件
  • 如何借助 NoSQL 提高 JPA 应用性能
  • 用mpvue开发微信小程序
  • - 语言经验 - 《c++的高性能内存管理库tcmalloc和jemalloc》
  • ​Redis 实现计数器和限速器的
  • ​VRRP 虚拟路由冗余协议(华为)
  • ​业务双活的数据切换思路设计(下)
  • # Redis 入门到精通(八)-- 服务器配置-redis.conf配置与高级数据类型
  • #[Composer学习笔记]Part1:安装composer并通过composer创建一个项目
  • #define 用法
  • %check_box% in rails :coditions={:has_many , :through}
  • (16)UiBot:智能化软件机器人(以头歌抓取课程数据为例)
  • (3)(3.2) MAVLink2数据包签名(安全)
  • (a /b)*c的值
  • (leetcode学习)236. 二叉树的最近公共祖先
  • (板子)A* astar算法,AcWing第k短路+八数码 带注释
  • (二)延时任务篇——通过redis的key监听,实现延迟任务实战
  • (二十三)Flask之高频面试点
  • (区间dp) (经典例题) 石子合并
  • (删)Java线程同步实现一:synchronzied和wait()/notify()
  • (一) storm的集群安装与配置
  • ****三次握手和四次挥手
  • *算法训练(leetcode)第四十五天 | 101. 孤岛的总面积、102. 沉没孤岛、103. 水流问题、104. 建造最大岛屿
  • .NET 4.0网络开发入门之旅-- 我在“网” 中央(下)
  • .Net core 6.0 升8.0
  • .NET Core 发展历程和版本迭代
  • .net core 依赖注入的基本用发