未接触过的技术

这是一篇正在学习中的文章,根据我的学习来不断更新

事情开始于一个问题,close wait

最近我们的服务器出现了大量的 close wait,作为一个从未接触过java的新员工学习这个问题的路径

由问题已知 close wait 是由于 tcp连接时一方发送了fine 但是另一方没发送(或者说超时没有自动关闭socket)

这个问题通常发生在会超时的请求上,那我本能的现在代码里找超时写在什么地方

  1. HttpClient发送Http请求(HttpClient 发送请求的写法
  2. @postmapping 等 Spring 框架,可以在 server 配置中写 timeout
    @postmapping 等如果不是自己在函数中创建了 socket 也不需要自己close
    Tomcat 会统一管理

问题一:Tomcat 是啥

Dubbo、Zookeeper、Servlet、Tomcat 之间的关系

bash 复制代码
       +------------+ HTTP/TCP  +-------------+
       | Web 客户端 | --------->  | 负载均衡器  |
       +------------+           +-------------+
                               /             \
                              /               \
                             V                 V
          +----------------+         +--------------+
          | Tomcat Server 1 |        | Tomcat Server 2 |
          | - Servlet API  |         | - Servlet API  |
          | - Dubbo 消费者  |         | - Dubbo 消费者  |
          +----------------+         +--------------+
                              \                /
                                \             /
                                 V           V
	                           +---------------+
	                           | Zookeeper     |
	                           | - 注册中心   |
	                           | - 存储提供者信息 |
	                           +---------------+
	                                 ^     ^
	                                 |     |
	                              (注册)  (发现)
	                                 |     |
	                           +---------+     +---------+
	                        | Dubbo 提供者1  | | Dubbo 提供者N  |
	                        +-----------------+ +-----------------+

Web 客户端通过HTTP或TCP请求访问服务。

负载均衡器根据策略将请求分发到不同的Tomcat服务器上。

Tomcat Server托管了基于Servlet API构建的Web应用,并在其中包含Dubbo消费者组件来调用远程服务。

Servlet是Java EE规范中的接口,用于处理Web请求和响应,在这里作为Dubbo与Web应用交互的桥梁。

Dubbo消费者在运行于Tomcat容器的Web应用中调用远程服务,它通过Zookeeper获取服务提供者的地址信息。

Dubbo提供者将自己的服务注册到Zookeeper,以便消费者能发现并调用它们的服务。

Zookeeper作为Dubbo框架的服务注册中心,存储和管理所有可用服务提供者的元数据信息。

大佬文章

查看 Tomcat 版本方法:点击跳转

集群是什么?

相关推荐
大霞上仙7 分钟前
Ubuntu系统电脑没有WiFi适配器
linux·运维·电脑
杜杜的man40 分钟前
【go从零单排】go中的结构体struct和method
开发语言·后端·golang
幼儿园老大*41 分钟前
走进 Go 语言基础语法
开发语言·后端·学习·golang·go
llllinuuu43 分钟前
Go语言结构体、方法与接口
开发语言·后端·golang
Karoku06643 分钟前
【企业级分布式系统】Zabbix监控系统与部署安装
运维·服务器·数据库·redis·mysql·zabbix
cookies_s_s43 分钟前
Golang--协程和管道
开发语言·后端·golang
为什么这亚子1 小时前
九、Go语言快速入门之map
运维·开发语言·后端·算法·云原生·golang·云计算
想进大厂的小王1 小时前
项目架构介绍以及Spring cloud、redis、mq 等组件的基本认识
redis·分布式·后端·spring cloud·微服务·架构
布值倒区什么name1 小时前
bug日常记录responded with a status of 413 (Request Entity Too Large)
运维·服务器·bug
customer082 小时前
【开源免费】基于SpringBoot+Vue.JS医院管理系统(JAVA毕业设计)
java·vue.js·spring boot·后端·spring cloud·开源·intellij-idea