知识点题目集合

题目

1.路由的hash模式和history模式有什么区别?

是前端路由匹配的两种模式,不涉及服务器,是利用浏览器的hash和history来实现,两者都是利用浏览器的自身特性,通过客户端来进行路由匹配,不会触发完整的http请求。hash是url的#添加hash来作为标识;history的url比较完整,符合规范。

Hash模式:hash不在http请求中。通过onhashchange来监听hash变化。只有当hash后面的值不同时,才会触发onhashchange事件。

History模式:通过HTML5的history对象,使用pushState、replaceState、popState(前进后退时触发)来监听url的变化,通过修改历史记录来修改url。在二级目录刷新时,在客户端找不到对应的路由,会进行http请求,报错404,所以需要后端配合,配置所有的入口文件为index.html。pushState可添加任意类型的数据,也可与当前url一致,还可设置title。

2.QPS:

每秒数万次的高并发场景

QPS=并发量/平均响应时间

实际上,平均响应时间会变高。

出现高并发的情况:

  1. 某个业务请求接口出现问题,响应时间及慢,将Web服务器的可用连接数占满,导致无连接进程可用,影响其他业务。

  2. 用户行为,系统不可用,用户点击越频繁。在负载均衡中,一台服务器挂了,分流到其他服务器,其他服务器也挂。

  3. 大量CC攻击或者DDOS攻击。

处理高并发状况:

  1. 重启服务

  2. 过载保护,如果检测到系统超负载状态,拒绝请求。将过载保护设置在CGI入口层。

高并发解决方案:

  1. 应用层面:读写分离、缓存、队列、集群、令牌、系统拆分、隔离、系统升级。

  2. 时间换空间:降低单次请求时间。

  3. 空间换时间:拉长整体处理业务时间。

优化提升QPS:

  1. 调整服务器的最大连接数。

  2. 内存操作级别的存储Redis。

  3. 增加服务器配置,如更好的CPU,加大网络带宽。

  4. 使用cdn,高防cdn和高防IP。

  5. 负载均衡。

相关推荐
MXN_小南学前端29 分钟前
Vue3 + Spring Boot 工单系统实战:用户反馈和客服处理的完整闭环(提供gitHub仓库地址)
前端·javascript·spring boot·后端·开源·github
踩着两条虫42 分钟前
强强联合!VTJ.PRO 正式接入 DeepSeek V4,AI 编码能力再跃升
前端·vue.js·ai编程
im_AMBER1 小时前
Leetcode 160 最小覆盖子串 | 串联所有单词的子串
开发语言·javascript·数据结构·算法·leetcode
得想办法娶到那个女人1 小时前
项目中 TypeScript 类型推导 极简实战总结
前端·javascript·typescript
Beginner x_u1 小时前
前端八股整理(Vue 02)|组件通信、生命周期、v-if 与 v-show
前端·javascript·vue.js
zs宝来了2 小时前
React 18 并发模式:Fiber 架构与时间切片
前端·javascript·框架
万物得其道者成2 小时前
Vue3 使用 Notification 浏览器通知,解决页面关闭后旧通知点击无法跳转问题
前端·vue.js·edge浏览器
一條狗2 小时前
学习日报 20260423|[特殊字符] 深度解析:Vue 3 SPA 部署到 Spring Boot 的 404/500 错误排查与完美解决方案-2
vue.js·spring boot·学习
天若有情6732 小时前
反向封神!C++ 全局单例不避反用,实现无锁多线程函数独占访问
java·javascript·c++
LIO3 小时前
Vue 3 实战——搜索框检索高亮的优雅实现
前端·vue.js