雄猫 - 标准输出文件非常大



我想限制Tomcat日志文件夹中的标准输出文件大小。

我的问题是:

  1. 我需要配置额外的日志记录配置,除了-Djava.util.logging.FileHandler.limit=25000000
  2. 是否需要重新启动 Apache 服务才能生效更改?

我想在"Java"选项卡下添加"Java选项"部分,添加以下内容:-Djava.util.logging.FileHandler.limit=25000000

已经在 Java 选项部分中定义了以下参数:

-Dcatalina.home=C:Program FilesApache Software FoundationTomcat 8.0
-Dcatalina.base=C:Program FilesApache Software FoundationTomcat 8.0
-Djava.endorsed.dirs=C:Program FilesApache Software FoundationTomcat 8.0endorsed
-Djava.io.tmpdir=C:Program FilesApache Software FoundationTomcat 8.0temp
-Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager
-Djava.util.logging.config.file=C:Program FilesApache Software FoundationTomcat 8.0conflogging.properties

日志记录属性:

# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements.  See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You under the Apache License, Version 2.0
# (the "License"); you may not use this file except in compliance with
# the License.  You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
handlers = 1catalina.org.apache.juli.AsyncFileHandler, 2localhost.org.apache.juli.AsyncFileHandler, 3manager.org.apache.juli.AsyncFileHandler, 4host-manager.org.apache.juli.AsyncFileHandler, java.util.logging.ConsoleHandler
.handlers = 1catalina.org.apache.juli.AsyncFileHandler, java.util.logging.ConsoleHandler
############################################################
# Handler specific properties.
# Describes specific configuration info for Handlers.
############################################################
1catalina.org.apache.juli.AsyncFileHandler.level = FINE
1catalina.org.apache.juli.AsyncFileHandler.directory = ${catalina.base}/logs
1catalina.org.apache.juli.AsyncFileHandler.prefix = catalina.
2localhost.org.apache.juli.AsyncFileHandler.level = FINE
2localhost.org.apache.juli.AsyncFileHandler.directory = ${catalina.base}/logs
2localhost.org.apache.juli.AsyncFileHandler.prefix = localhost.
3manager.org.apache.juli.AsyncFileHandler.level = FINE
3manager.org.apache.juli.AsyncFileHandler.directory = ${catalina.base}/logs
3manager.org.apache.juli.AsyncFileHandler.prefix = manager.
4host-manager.org.apache.juli.AsyncFileHandler.level = FINE
4host-manager.org.apache.juli.AsyncFileHandler.directory = ${catalina.base}/logs
4host-manager.org.apache.juli.AsyncFileHandler.prefix = host-manager.
java.util.logging.ConsoleHandler.level = FINE
java.util.logging.ConsoleHandler.formatter = org.apache.juli.OneLineFormatter

############################################################
# Facility specific properties.
# Provides extra control for each logger.
############################################################
org.apache.catalina.core.ContainerBase.[Catalina].[localhost].level = INFO
org.apache.catalina.core.ContainerBase.[Catalina].[localhost].handlers = 2localhost.org.apache.juli.AsyncFileHandler
org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/manager].level = INFO
org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/manager].handlers = 3manager.org.apache.juli.AsyncFileHandler
org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/host-manager].level = INFO
org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/host-manager].handlers = 4host-manager.org.apache.juli.AsyncFileHandler
# For example, set the org.apache.catalina.util.LifecycleBase logger to log
# each component that extends LifecycleBase changing state:
#org.apache.catalina.util.LifecycleBase.level = FINE
# To see debug messages in TldLocationsCache, uncomment the following line:
#org.apache.jasper.compiler.TldLocationsCache.level = FINE

Tomcat使用java.util.logging.ConsoleHandler(不是java.util.logging.FileHandler)记录到错误文件描述符,将所有内容发送到System.err。因此,无法限制日志的大小。

但是,您可以在prunsrv中(通常重命名为tomcat8.exe):

  1. 通过将--StdOutput--StdError设置为空字符串,禁用stdout/stderr重定向到任何文件。与Tomcat一起分发的默认logging.properties文件也会将所有内容记录到catalina.<date>.log,每天轮换一次,因此Tomcat的日志不会丢失。

  2. --StdOutput--StdError选项设置为auto,这应该每天轮换它们,尽管我没有测试并且似乎还没有实现[1]。

您也可以在图形界面prunmgr(通常重命名为tomcat8w.exe)中更改此设置。

备注:如果禁用stdout/stderr到文件的重定向,则还应通过修改logging.properties来禁用ConsoleHandler

.handlers = 1catalina.org.apache.juli.AsyncFileHandler, java.util.logging.ConsoleHandler

自:

.handlers = 1catalina.org.apache.juli.AsyncFileHandler

还要检查您的 Web 应用程序是否不使用除java.util.logging以外的其他日志记录框架,并修改日志记录配置(log4j.propertiesLog4j 1.x 等),以便不记录任何内容到标准输出/错误中。


[1]这个问题有一个长期存在的错误报告。

最新更新