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

【计算机网络 - 基础问题】每日 3 题(六十)

✍个人博客:https://blog.csdn.net/Newin2020?type=blog
📣专栏地址:http://t.csdnimg.cn/fYaBd
📚专栏简介:在这个专栏中,我将会分享 C++ 面试中常见的面试题给大家~
❤️如果有收获的话,欢迎点赞👍收藏📁,您的支持就是我创作的最大动力💪
📝推荐参考地址:https://www.xiaolincoding.com/(这个大佬的专栏非常有用!)

184. 如何提高服务器的 QPS?

由前面的公式:QPS(TPS)= 并发数/平均响应时间 可以看出,要提高 QPS,我们必须做 2 个方面努力:

(1)增加并发数

  1. 比如增加 tomcat 并发的线程数,开跟服务器性能匹配的线程数,可以更多满足服务请求。
  2. 增加数据库的连接数,预建立合适数量的 TCP 连接数。
  3. 后端服务尽量无状态话,可以更好支持横向扩容,满足更大流量要求。
  4. 调用链路上的各个系统和服务尽量不要单点,要从头到尾都是能力对等的,不能让其中某一点成为瓶颈。
  5. RPC 调用的尽量使用线程池,预先建立合适的连接数。

(2)减少平均响应时间

  1. 请求尽量越前结束,越好,这样压力就不要穿透到后面的系统上,可以在各个层上加上缓存。
  2. 流量消峰。放行适当的流量,处理不了的请求直接返回错误或者其他提示。和水坝道理很类似。
  3. 减少调用链。
  4. 优化程序。
  5. 减少网络开销,适当使用长连接。
  6. 优化数据库,建立索引。

185. 网络编程中设计并发服务器,使用多进程与多线程 ,请问有什么区别?

答案一:

1)进程:子进程是父进程的复制品。子进程获得父进程数据空间、堆和栈的复制品。

2)线程:相对与进程而言,线程是一个更加接近与执行体的概念,它可以与同进程的其他线程共享数据,但拥有 自己的栈空间,拥有独立的执行序列。

两者都可以提高程序的并发度,提高程序运行效率和响应时间。

线程和进程在使用上各有优缺点:线程执行开销小,但不利于资源管理和保护;而进程正相反。同时,线程适合于 在 SMP 机器上运行,而进程则可以跨机器迁移。

答案二:

根本区别就一点:用多进程每个进程有自己的地址空间 (address space),线程则共享地址空间。所有其它区别都是由此而来的:

1)速度:线程产生的速度快,线程间的通讯快、切换快等,因为他们在同一个地址空间内。

2)资源利用率:线程的资源利用率比较好,也是因为他们在同一个地址空间内。

3)同步问题:线程使用公共变量/内存时需要使用同步机制,还是因为他们在同一个地址空间内。


http://www.mrgr.cn/news/61691.html

相关文章:

  • 2024AAAI SCTNet论文阅读笔记
  • 服务器数据恢复—raid5故障导致上层ORACLE无法启动的数据恢复案例
  • kubeneters-循序渐进Cilium网络(二)
  • 探索数据存储的奥秘:深入理解B树与B+树
  • 【YOLOv8杂草作物目标检测】
  • w~自动驾驶~合集16
  • 【C++】踏上C++学习之旅(四):细说“内联函数“的那些事
  • 【C++】智能指针的奥秘:深度解析std::unique_ptr与std::shared_ptr
  • 浅谈C#之TuochSocket
  • Python表格格式转换模块:tablib
  • 《机器学习by周志华》学习笔记-神经网络-04全局最小误差与局部极小误差
  • Vue.nextTick 使用指南:数据更新与 DOM 同步利器
  • webstrom编辑器中出现很多NBSP但是我去搜NBSP是没有的。复制这个编辑器中的NBSP粘贴发现这是个空格。怎么解决
  • Docker:技术架构的演进之路
  • 元素 offset client scroll 相关属性简介
  • Redis有什么不一样?
  • 【JVM第4课】程序计数器
  • 重构: 改善既有代码设计 - 第二版 第6--10章
  • 《IMM交互式多模型滤波MATLAB实践》专栏目录,持续更新……
  • HarmonyOS:$$语法:内置组件双向同步
  • 探索SpringBoot:构建高效闲一品交易平台
  • 微信支付宝小程序SEO优化的四大策略
  • 2024年10月HarmonyOS应用开发者基础认证全新题库
  • 打造城市新地标:气膜综合体育馆开放共享新体验—轻空间
  • idea 创建java文件增加注释
  • 3.1 大数据时代