- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在使用 log4j2 和滚动文件附加程序,根据大小和时间滚动文件。这是我的配置文件和一个虚拟示例:
log4j2.xml
<RollingFile name="RollingFile" filename="log/${date:dd-MM-yyyy-HH}/currentRoll.log" filePattern="log/%d{dd-MM-yyyy-HH}/Roll-%i.log">
<PatternLayout>
<Pattern>%d{ISO8601}{GMT} %p %c{1.c} [%t] %m%n</Pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="1"/>
<SizeBasedTriggeringPolicy size="3KB"/>
</Policies>
</RollingFile>
<Console name="STDOUT" target="SYSTEM_OUT">
<PatternLayout>
<Pattern>%d{ISO8601}{GMT} [%t] %-5p %c{1}: %m%n</Pattern>
</PatternLayout>
</Console>
</Appenders>
<loggers>
<Root level="info">
<AppenderRef ref="Async"/>
</Root>
</loggers>
</Configuration>
和我的虚拟日志类:
public class Helloworld extends TimerTask {
private static final Logger logger=LogManager.getLogger("HelloWorld");
@Override
public void run(){
logger.info("fake info message");
logger.info("another fake info message");
}
}
我的问题是我当前的日志 (currentRoll.log) 文件位于首次创建的文件夹中节目开始了。我需要它放在最后。例如,如果我在 2014 年 11 月 25 日下午 1 点开始运行该程序,并且在下午 3 点我想查看当前日志,它们将不会位于 25-11-2014-15 文件夹中,而是位于 25-11-2014-13 文件夹中。
我的猜测是 ${date:dd-MM-yyyy-HH}
不是动态解析的。我尝试使用监视间隔轮询自动重新配置:
<Configuration status="info" name="MyApp" packages="" monitorInterval="5">
并使用“$$”,如下所示:$${date:dd-MM-yyyy-HH}
但这给了我以下错误:
"2014-11-26 17:22:27,143 ERROR Unable to create file log/${date:dd-MM-yyyy-HH-mm}/currentRoll.log java.io.IOException: The filename, directory name, or volume label syntax is incorrect
我知道 log4net 有一个 datePattern 参数可以解决这个问题,但我找不到 log4j2 的等效参数。
关于如何进行的任何建议?
最佳答案
用于滚动追加器的日期是在创建滚动日志文件时确定的。或者,用 log4j 术语来说,“整个 RollingFile 元素的解析被推迟到发生匹配为止”。也就是说,仅当滚动文件时,{date} 属性才会以指定的分辨率进行插值。
$$ 设施可用于许多属性,但我不确定 {date} 是否是其中之一。我有一种感觉,事实并非如此,在这种情况下,正在制作的文件规范将字面上包含“${date...}”。这可能是您所看到的错误的根源。
过去,我曾尝试通过附加程序文件名中的“$${sys:someProperty}”使用系统属性(您可以在“属性”部分设置默认值),但您必须确保在调用记录器之前设置有问题的系统属性,否则您可能会得到仅使用默认值的滚动文件。
请参阅 property substitution 上的 Log4J 文档对于我正在谈论的内容。
最终,我自己的解决方案可能需要以编程方式实现记录器,以便我可以更改日志文件的根名称,并将最终用户友好的属性抽象到一个简单的属性文件中,而不是在其上转储 XML 文件。
关于java - Log4j2 : change filename dynamically in RollingFile Appender,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27155363/
编辑:为了澄清,我想问的是:在什么情况下您会更喜欢一种语法而不是另一种语法? 有什么区别: .trigger('change') 和 .change() 两者都按预期工作。在任何情况下语法都会有所不同
这个问题在这里已经有了答案: Difference between .on('click') vs .click() (12 个答案) 关闭 6 年前。 有什么区别: $('选择器').change
我用的是Select2-4.0.0 和 $gameSelect.select2().on("change",function(e){....} 工作正常。 但是当我将它链接起来时('change')就
有一天在#haskell 上,有人提到了当字符串改变时字符串的类型应该如何改变的概念。这让我想起了我项目中的一些代码。它一直困扰着我,我说不清为什么。我现在推测,原因是我没有实现这个概念。这是下面的代
我使用了 .on("change") 事件函数,因为我的整个代码中有一部分是动态变化的。 .trigger("change") 在 .change() 中工作正常,但在 .on("change") 中
下面是一个非常简单的表单下拉列表设置。但是,on-change 事件拒绝触发...除非它更改为 ng-change。 这让我卡住了大约一个小时,因为我们在网站的其他地方使用了相同的设置(即模型属性/列
我有两个v-model 案例一: 这很好用 案例二: 即使改变 u1 也会触发 onDateChange(); 最佳答案 :change 绑定(bind)属性,如 v-bind:change=
我找到了 .and方法对于链接许多期望非常有用。 expect { click_button 'Update Boilerplate' @boilerplate_original.reload
出于合规性原因,我需要捕获所有数据库更改。我知道 Change Feed 存储此信息(并且我正在等待完全保真度来捕获删除)。目前,我一直在通过 Function 触发器读取 Change Feed 并
我添加了一个data-ng-change='getSubjectsClasswise(classBean.class_id);'上课标签,但主题未在主题 处加载标签。 一切看起来都很好,没有遇到问题
我有一组复选框,当您单击其中一个时,它们应该全部被选中。 当用户单击一个复选框时,它会检查以该类名称开头的所有其他复选框。我想要的是用户单击一个复选框,并且每次单击仅触发一次 $(".atpSelec
我在 Stack Overflow 上阅读了很多有关此问题的内容,并应用了所有建议的解决方案(getShell pack、布局、getparent 布局等...),但没有一个起作用。 我有一个带有文本
我想更改我的索引。我的数据框如下: partA = pd.DataFrame({'u1': 2, 'u2': 3, 'u3':4, 'u4':29, 'u5':4, 'u6':1, 'u7':323,
我有一个像这样的下拉菜单: Grade Year 旁边还有另一个下拉菜单: 3 4
这个问题已经有人问过,但我只停留在最基本的层面上。除了选择标记和尝试通过 jquery 捕获更改事件外,我没有向我的 html 添加任何内容。这是我的代码: $('#target').bin
我只是 Django 的新手几天。现在,当自定义表单中其他字段的值发生变化时,我需要同时更改一个字段中的值和表示形式。此时更改 MyModel 是受限。 我的应用程序/models.py: class
我正在使用 ListView 控件来显示一些数据行。有一个后台任务接收列表内容的外部更新。新收到的数据可能包含更少、更多或相同数量的项目,而且项目本身可能已更改。 ListView.ItemsSour
我在 android studio 中使用 git 插件。我的问题是当我提交更改列表(公开提交)时,但我在更改列表中的评论是错误的/丢失的,我想更改它。 问题: 有没有办法通过 AndroidStud
MyCustomObject * object=new MyCustomObject(); 假设我的许多类都使用了对象指针,但突然间我想在不更改地址的情况下更改指针的内容。 我认为 object =
我正在使用新的 KeyValue Observing。当变量发生变化时,我接到了我的观察者的电话,但 change struct 附带 newValue和 oldValue都为 nil ,所以它永远不
我是一名优秀的程序员,十分优秀!