English 中文(简体)
Logging a global ID in multiple components
原标题:

I have a system which contains multiple applications connected together using JMS and Spring Integration. Messages get sent along a chain of applications.

[App A] -> [App B] -> [App C]

We set a global id in the message header so we can trace each message lifecycle through the system.

I would like to be able to prepend any log message in the system with the message global id.

Has anyone else done this? Is there any way to associate this variable to the Thread so I can access it in future methods? I d rather not pass the variable around in methods of the system.

最佳回答

I think ThreadLocal may be what you want here, though some may find this approach an abuse of ThreadLocal s purpose, or good design. Something like:

public class MyIDManager {
  public static final ThreadLocal<Long> myID = new ThreadLocal<Long>();
}

...
// set ID at some point
MyIDManager.myID.set(theNewID);

...
// read it later
long currentID = MyIDManager.get();

The magic here is that myID s value is actually specific to a Thread, and will be different when accessed from different threads.

You can then do what you like with the ID, including logging it.

问题回答
Thread t = Thread.currentThread();
t.setName("Your ID Here");

Another answer, which I believe the first post is alluding to, is to simply ask your logging framework to include the thread name in the log statement. For example, log4j lets you add the thread name with t in its PatternLayout: http://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/PatternLayout.html I ve seen this in other frameworks too.

BTW, this approach is part of a wider enterprise logging pattern. I attempted to document this pattern here. The summary is:

TL;DR

At the earliest inception of a ‘process’ create an ID which is a combination of an ‘origin id’ and ‘unique id’. This non-business related global inception ID (GIID), should be used for every log output to provide machine readability and tool use. When each new business level or operational id is obtained or generated, it is logged to provide an ‘association’ with this GIID. This is similar to various existing practices so it is presented as a Software Design Pattern.





相关问题
Spring Properties File

Hi have this j2ee web application developed using spring framework. I have a problem with rendering mnessages in nihongo characters from the properties file. I tried converting the file to ascii using ...

Logging a global ID in multiple components

I have a system which contains multiple applications connected together using JMS and Spring Integration. Messages get sent along a chain of applications. [App A] -> [App B] -> [App C] We set a ...

Java Library Size

If I m given two Java Libraries in Jar format, 1 having no bells and whistles, and the other having lots of them that will mostly go unused.... my question is: How will the larger, mostly unused ...

How to get the Array Class for a given Class in Java?

I have a Class variable that holds a certain type and I need to get a variable that holds the corresponding array class. The best I could come up with is this: Class arrayOfFooClass = java.lang....

SQLite , Derby vs file system

I m working on a Java desktop application that reads and writes from/to different files. I think a better solution would be to replace the file system by a SQLite database. How hard is it to migrate ...

热门标签