Tomcat如何配置访问日志和线程数

 更新时间:2023年11月29日 09:52:06   作者:山鬼、  
Tomcat是一个功能强大且易于使用的Java Servlet容器,适用于开发和部署各种类型的Java Web应用程序,本文主要介绍了Tomcat如何配置访问日志和线程数,以优化性能并提高系统可靠性
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud

(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun

前言

Tomcat(全名为Apache Tomcat)是一个开源的Java Servlet容器,也可以被看作是一个Web应用服务器。它由Apache软件基金会开发和维护,是一个非常流行的用于部署Java Web应用程序的服务器。以下是关于Tomcat的一些重要信息:

  • Servlet容器:Tomcat是一个Java Servlet容器,它的主要功能是执行和管理Java Servlets和JavaServer Pages(JSPs)。Servlets和JSPs是用于构建动态Web应用程序的Java技术。

  • 开源性质:Tomcat是开源的,这意味着任何人都可以免费下载、使用、修改和分发它。这使得它成为一个受欢迎的选项,特别是对于小型和中小型项目。

  • 跨平台性:Tomcat是跨平台的,它可以在多种操作系统上运行,包括Windows、Linux和macOS等。

  • 支持Java EE标准:Tomcat实现了Java EE(Enterprise Edition)规范的一部分,使得开发人员可以使用标准的Java EE技术构建和部署Web应用程序。

  • 模块化:Tomcat的架构是模块化的,它包括多个组件,如连接器、容器、安全性等。这使得开发人员可以根据需要选择性地启用或禁用这些组件,以满足其应用程序的要求。

  • 高性能:Tomcat经过优化,具有良好的性能,特别适合处理高并发的Web请求。

  • 管理和监控工具:Tomcat提供了Web界面和命令行工具,用于管理和监控应用程序的部署和性能。

  • 扩展性:Tomcat支持多种扩展和插件,可以通过添加第三方组件来增强其功能。

  • 安全性:Tomcat包括一些安全特性,如SSL/TLS支持和访问控制,以确保应用程序的安全性。

  • 社区支持:Tomcat拥有庞大的用户和开发社区,可以轻松找到有关配置、问题解决和扩展的支持和资源。

总之,Tomcat是一个功能强大且易于使用的Java Servlet容器,适用于开发和部署各种类型的Java Web应用程序。它的开源性质和活跃的社区使其成为一个受欢迎的选择,特别是在Java Web开发领域。

一、tomcat access log的配置

1.access log的配置

server:
  tomcat:
    accesslog:
      enabled: true        #是否开启日志
      directory: /home/admin/arpro-backend-prod/logs/arpro-monitor   #日志存储目录
      pattern: '%t %a %A %m %U%q %s %D %I %B'  #日志格式
      prefix: TomcatAccess        #日志文件前缀
      rename-on-rotate: true     #是否启用日志轮转

2.查看磁盘上的日志文件

在这里插入图片描述

3.accesslog参数解释:

enabled,取值true、false,需要accesslog时设置为true

directory,指定access文件的路径

rotate,指定是否启用日志轮转。默认为true。这个参数决定是否需要切换切换日志文件,如果被设置为false,则日志文件不会切换,即所有文件打到同一个日志文件中,并且file-date-format参数也会被忽略

pattern,定义日志的格式,

pattern的配置:

%a - 远程IP地址

%A - 本地IP地址

%b - 发送的字节数(Bytes sent), 不包括HTTP headers的字节,如果为0则展示’-’

%B - 发送的字节数(Bytes sent), 不包括HTTP headers的字节

%h - 远程主机名称(如果resolveHosts为false则展示IP)

%H - 请求协议

%l - 远程用户名,始终为’-'(Remote logical username from identd)

%m - 请求的方法(GET, POST等)%p - 接受请求的本地端口

%q - 查询字符串,如果存在,有一个前置的’?’

%r - 请求的第一行(包括请求方法和请求的URI)

%s - response的HTTP状态码(200,404等)%S - 用户的session ID

%t - 日期和时间,Common Log Format格式

%u - 被认证的远程用户, 不存在则展示’-’

%U - 请求URL路径%v - 本地服务名

%D - 处理请求的时间,单位为毫秒

%T - 处理请求的时间,单位为秒%I - 当前请求的线程名(can compare later with stacktraces)

二、Tomcat配置线程数

server:
  tomcat:
    uri-encoding: UTF-8
    min-spare-threads: 300  #最小线程数
    max-threads: 1000  #最大线程数
    accept-count: 500     #最大等待队列长度
    max-connections: 1800     #最大链接数

首先,线程数是一个重点,每一次HTTP请求到达Web服务器,Web服务器都会创建一个线程来处理该请求,该参数决定了应用服务同时可以处理多少个HTTP请求。

比较重要的有两个:初始线程数和最大线程数。

初始线程数:保障启动的时候,如果有大量用户访问,能够很稳定的接受请求。最大线程数:用来保证系统的稳定性。

超时时间:用来保障连接数不容易被压垮。如果大批量的请求过来,延迟比较高,很容易把线程数用光,这时就需要提高超时时间。这种情况在生产中是比较常见的 ,一旦网络不稳定,宁愿丢包也不能把服务器压垮。

  • min-spare-threads:最小备用线程数,tomcat启动时的初始化的线程数。
  • max-threads:Tomcat可创建的最大的线程数,每一个线程处理一个请求,超过这个请求数后,客户端请求只能排队,等有线程释放才能处理。(建议这个配置数可以在服务器CUP核心数的200~250倍之间)
  • accept-count:当调用Web服务的HTTP请求数达到tomcat的最大线程数时,还有新的HTTP请求到来,这时tomcat会将该请求放在等待队列中,这个acceptCount就是指能够接受的最大等待数,默认100。如果等待队列也被放满了,这个时候再来新的请求就会被tomcat拒绝(connection refused)。
  • max-connections:这个参数是指在同一时间,tomcat能够接受的最大连接数。一般这个值要大于(max-threads)+(accept-count)。
  • connection-timeout:最长等待时间,如果没有数据进来,等待一段时间后断开连接,释放线程。

三、实时查看tomcat线程数

获取tomcat进程pid

ps -ef|grep java

统计该tomcat进程内的线程个数

ps -Lf 进程号 |wc -l

到此这篇关于Tomcat如何配置访问日志和线程数的文章就介绍到这了,更多相关Tomcat配置访问日志和线程数内容请搜索程序员之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持程序员之家! 

相关文章

  • tomcat虚拟路径的配置方法汇总

    tomcat虚拟路径的配置方法汇总

    本文给大家简单汇总介绍了tomcat虚拟路径的配置方法,十分的简单实用,有需要的小伙伴可以参考下。
    2016-01-01
  • Tomcat 多站点配置详解及实现方法

    Tomcat 多站点配置详解及实现方法

    这篇文章主要介绍了Tomcat 多站点配置详解及实现方法的相关资料,需要的朋友可以参考下
    2016-12-12
  • Tomcat 部署程序方法步骤

    Tomcat 部署程序方法步骤

    本文主要介绍了Tomcat部署程序的方法步骤,具有一定的参考价值,下面跟着小编一起来看下吧
    2016-12-12
  • Tomcat获取Nginx反向代理的客户端域名

    Tomcat获取Nginx反向代理的客户端域名

    今天小编就为大家分享一篇关于Tomcat获取Nginx反向代理的客户端域名,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • 在Win10上安装Tomcat服务器及配置环境变量的详细教程(图文)

    在Win10上安装Tomcat服务器及配置环境变量的详细教程(图文)

    Tomcat 服务器是一个免费的开放源代码的 Web 应用服务器,属于轻量级应用服务器,本文主要讲述Windows环境Tomcat服务器安装与环境变量配置,感兴趣的朋友跟随小编一起看看吧
    2019-11-11
  • Tomcat 7通过设置不同的端口部署两个项目

    Tomcat 7通过设置不同的端口部署两个项目

    最近因为有个Web项目,需要部署两个相同项目到Tomcat中,第二个是拷贝第一个的,使用的项目是使用SpringMVC框架的,尝试了几种方法,这篇文章给大家总结一个比较靠谱的方法,有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2016-10-10
  • Nginx/Httpd负载均衡tomcat配置教程

    Nginx/Httpd负载均衡tomcat配置教程

    这篇文章主要介绍了Nginx/Httpd负载均衡tomcat配置方法,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-07-07
  • 关于给Tomcat设置maxPostSize的问题及注意事项

    关于给Tomcat设置maxPostSize的问题及注意事项

    这篇文章主要介绍了关于给Tomcat设置maxPostSize的问题及注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-07-07
  • 详解tomcat各个端口的作用

    详解tomcat各个端口的作用

    这篇文章主要介绍了详解tomcat各个端口的作用,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-10-10
  • 解决tomcat出现:java.lang.IllegalStateException:无输出目录问题

    解决tomcat出现:java.lang.IllegalStateException:无输出目录问题

    这篇文章主要介绍了解决tomcat出现:java.lang.IllegalStateException:无输出目录问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01

最新评论

?


http://www.vxiaotou.com