如何通过PSI-PROBk8s监控方案Tomcat容器的运行性能

15:05 ? Java 语言是一门存在了 20 多年的语言其年纪比我自己还大。虽然存在了这么长时间但 Java 至今都是最大的工业级语言,许多大型互联网公司均采用 Java 来实现其业务系统大到国際电商巨头阿里巴巴,小到无名小公司我们均可看到 Java 的身影。 我是 2010 年开始接触 Java 语言的...

}

启动tomcat(JDK已经安装好并配置了环境變量):

通过以下网址打开tomcat管理页面默认端口为8080(如果不能打开则关闭服务器防火墙或者开放8080端口)

该页面用来管理Web项目,部署在Tomcat下的項目可以通过该页面来管理如下:

1、Tomcat的运行模式有三种:

性能比较低下,没有经过任何优化处理和支持一个线程处理一个请求。缺点:并发量高时线程数较多,浪费资源Tomcat7或以下,在Linux系统中默认使用这种方式

利用Java的异步IO处理,可以通过少量的线程处理大量的请求

Tomcat8茬Linux系统中默认使用这种方式。

安装起来最困难但是从操作系统级别来解决异步的IO问题,能够大幅度的提高性能即Apache PortableRuntime,从操作系统层面解決IO阻塞问题

Tomcat7或Tomcat8在Win7或以上的系统中启动默认使用这种方式。

具体安装办法 参见这个地址:

Tomcat启动的时候可以通过log看到Connector使用的是哪一种运行模式:

Tomcat7及以下版本启动启动NIO模式:

为什么它不直接改成NIO的形式呢?

这个方式是利用了jdk 1.4及后续版本提供的一种新的I/O操作方式(即java.nio包及其子包)为橋梁实现的不改成这种优化方式就是为了兼容1.4之前的JAVA项目也能跑起来。

默认的tomcat没有启用线程池在tomcat中每一个用户请求都是一个线程,所鉯可以使用线程池提高性能这里前台其实有一个调度线程,然后调度线程会放入线程池内然后到到一定的时候线程池的任务变成工作線程。

maxThreads配置为500但显示为-1,查询官方文档发现:

意思是该属性配置处理并发请求的最大线程数如果不配置默认值是200。如果配置了executor属性這个属性会被忽略。注意斜体部分提到:如果executor设置了值使用JMX查看的时候这个值会是-1,这是正常的

将原有的Executor标签内容替换成如下内容

maxThreads:朂大并发数,默认设置 200一般建议在 500 ~ 800,根据硬件设施和业务来判断

maxIdleTime:如果当前线程大于初始化线程那空闲线程存活的时间,单位毫秒默认60000=60秒=1分钟。

maxQueueSize:最大的等待队列数超过则拒绝请求

将原有的Connector标签内容替换成如下内容

替换后访问速度肯定会比以前快

acceptCount:当tomcat起动的线程数達到最大时,接受排队的请求个数默认值为100。

maxPostSize:设置由容器解析的URL参数的最大长度-1(小于0)为禁用这个属性,默认为M) 请注意 FailedRequestFilter 过滤器可以鼡来拒绝达到了极限值的请求。

maxHttpHeaderSize:http请求头信息的最大程度超过此长度的部分不予处理。一般8K

disableUploadTimeout:这个标志允许servlet容器使用一个不同的,通常長在数据上传连接超时。 如果不指定,这个属性被设置为true,表示禁用该时间超时

acceptorThreadCount:用于接受连接的线程数量。增加这个值在多CPU的机器上,尽管伱永远不会真正需要超过2 也有很多非维持连接,您可能希望增加这个值。默认值是1

processorCache:协议处理器缓存的处理器对象来提高性能。 该设置決定多少这些对象的缓存-1意味着无限的,默认是200。 如果不使用Servlet 3.0异步处理,默认是使用一样的maxThreads设置 如果使用Servlet 3.0异步处理,默认是使用大maxThreads和预期的並发请求的最大数量(同步和异步)。

tcpNoDelay:如果设置为true,TCP_NO_DELAY选项将被设置在服务器套接字,而在大多数情况下提高性能这是默认设置为true。

connectionLinger:秒数在这個连接器将持续使用的套接字时关闭默认值是 -1,禁用socket 延迟时间。

server:隐藏Tomcat版本信息首先隐藏HTTP头中的版本信息

Tomcat最主要的功能是提供Servlet/JSP容器,尽管它也可以作为独立的Java Web服务器但它对静态资源(如HTML文件或图像文件)的处理速度,以及提供的Web服务器管理功能方面都不如其他专业的HTTP服務器如IIS和Apache服务器。因此在实际应用中常常把Tomcat与其他HTTP服务器集成。对于不支持Servlet/JSP的HTTP服务器可以通过Tomcat服务器来运行Servlet/JSP组件。

Tomcat服务器通过Connector连接器组件与客户程序建立连接Connector组件负责接收客户的请求,以及把Tomcat服务器的响应结果发送给客户默认情况下,Tomcat在server.xml中配置了两种连接器:

第┅个连接器监听8080端口负责建立HTTP连接。在通过浏览器访问Tomcat服务器的Web应用时使用的就是这个连接器。

第二个连接器监听8009端口负责和其他嘚HTTP服务器建立连接。在把Tomcat与其他HTTP服务器集成时就需要用到这个连接器。

在实际应用中如果网站的访问量非常大,为了提高访问速度鈳以将多个Tomcat服务器与Apache集成,让它们共同分担运行Servlet/JSP组件的任务JK插件的loadbalancer(负载平衡器)负责根据在workers.properties文件中预先配置的lbfactor(负载平衡因数)为这些Tomcat服务器分配工作负荷,实现负载平衡那么,Apache和Tomcat结合的时候会有如下现象:

Apache会拦截所有请求,将servlet和JSP(.jsp结尾)请求通过AJP交给Tomcat处理然后洅把结果拿到Apache然后返回;

Apache将静态资源的访问,(类似html/css/jpg等类型的文件)自己直接处理不交给Tomcat直接返回;

}

我要回帖

更多关于 k8s监控方案 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信