Spring Integration - Logging

niceWork

Mitglied
Hi @all!

Ich bin auf der Suche nach einem sehr "speziellen" Lösungsansatz.
Es geht um ein bestehendes Projekt, in welchem wir mit Spring Integration arbeiten. Wir loggen in diesem Tool einiges mit, um gut debuggen zu können. Eine solche Log-Zeile könnte z. B. so aussehen:

Java:
2022-06-14 13:32:46.659 DEBUG 8 --- [eResolution-325] ionFlow$$EnhancerBySpringCGLIB$$f7eeb538 : GenericMessage [payload=xxxxx......

Wie man in diesem Beispiel sieht, ist die ausführende Klasse durch "ionFlow$$Enhancer... " maskiert, das erschwert die Lesbarkeit und ist für mich kontraproduktiv. Jetzt würde mich interessieren, ob es eine Möglichkeit gibt, das zu ersetzen?

Im Flow wird folgende Logzeile mehrmals verwendet, diese müsste daran "schuld" sein:
Java:
.log(DEBUG, getClass().getName())

Ich glaube, das liegt am Methodenaufruf Ich glaube, das liegt am Methodenaufruf
Java:
getClass().getName()
zur Laufzeit, dass da irgendwelche interne Proxies o. ä. "reinpfuschen". zur Laufzeit, dass da irgendwelche interne Proxies o. ä. "reinpfuschen".

Freue mich auf eure Antworten!

Besten Dank und LG

Edit: Falsche Formatierung von Code behoben
 

Robert Zenz

Top Contributor
Ohne jetzt zu wissen was genau du tust, aber waere das anlegen einer statischen Logger Instanz nicht die Loesung?

Java:
// Pseudo-Code weil zu faul um nachzuschauen:
private static final Logger LOGGER = LoggerFactory.newInstance(MyCoolClass.class);

Dann hast du den Logger an deine Klasse gebunden, nicht an die welche es zur Laufzeit wird durch Spring.
 

niceWork

Mitglied
Danke Robert für die schnelle Antwort!
Das Problem ist noch etwas komplexer. Ich habe mittlerweile rausgefunden, dass man der log-Methode als zweiten Parameter einfach einen String übergeben kann, der dann den Klassennamen im Logging definiert. Würde soweit funktionieren:
Java:
private static final String LOGGING_CLASS_NAME = xxx.class.getName();
// ....
.log(DEBUG, LOGGING_CLASS_NAME);

Jetzt möchte ich das noch "eskalieren" - alle Flows leiten von einem Interface ab. In diesem hätte ich gerne eine default Methode die den statischen Namen der aktuellen Klasse zurückgibt. Wie könnte ich das am besten anstellen, dass ich den aktuellen Klassenname wo die Methode aufgerufen wird nehme und dann statisch zurückgebe?
 

KonradN

Super-Moderator
Mitarbeiter
In der default Methode kannst Du doch auf this zugreifen, also kannst Du etwas machen wie this.getClass().getName() um an den Namen der Klasse zu kommen.
 

Robert Zenz

Top Contributor
Wie könnte ich das am besten anstellen, dass ich den aktuellen Klassenname wo die Methode aufgerufen wird nehme und dann statisch zurückgebe?

Gar nicht. Entweder du holst den Namen zur Kompilierung (MyService.class.getName()), oder du holst ihn zur Laufzeit (this.getClass().getName()). Deine Schnittstelle kann nur letzteres, weil sie nichts von an den ableitenden Klassen weisz, und zur Laufzeit ist es die Spring-Klasse.

Deine Loesung waere schon die beste, aber idealerweise hast du eine Logger-Klasse welche es dir erlaubt nicht jedesmal den Klassennamen angeben zu muessen, sondern nur einmal, wie in meinem Beispiel.
 

Robert Zenz

Top Contributor
Nein, ist gelogen. Du kannst dir natuerlich Logik schreiben welche die Basisklassen sucht im Klassen-Baum. Etwas Pseudo-Code:

Java:
private Class<?> getWantedParentClass() {
    Class<?> currentClass = this.getClass();
    
    while (currentClass != null) {
        if (matchesWantedCriteria(currentClass)) {
            return currentClass;
        }
        
        currentClass = currentClass.getParent();
    }
    
    // Fallback
    return this.getClass();
}

Dann musst du nur definieren was "deine" Klassen sind welche du willst. Also du gehst den Ableitungsbaum von den Spring-Klassen abwaerts bis du deine Klasse findest welche du fuer das Logging verwenden willst.
 

LimDul

Top Contributor
Die Idee ging mir beim lesen auch durch den Kopf, aber die hat für mich einen größeren Kritikpunkt. Im Fehlerfall, wenn das Logging aufgerufen wird, wird damit eine Menge Logik ausgeführt um den Fehler zu protokollieren. Wenn diese Logik Fehler hat, ist das sehr unschön. Logging sollte so simpel wie möglich sein und so robust wie möglich - eine Exception im catch Block beim loggen ist (wenn man sie nicht explizit behandelt) so ziemlich der Worst Case bzgl. der Nachvollziehbarkeit, weil dann der ursprüngliche Fehler komplett geschluckt wird.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
R Spring Boot Integration-testing mit Keycloak Frameworks - Spring, Play, Blade, Vaadin & Co 1
R Spring Boot Integration-testing mit Keycloak Frameworks - Spring, Play, Blade, Vaadin & Co 13
T JSF - Spring Security Integration Frameworks - Spring, Play, Blade, Vaadin & Co 0
T Spring MVC - JSF 2.0 Integration Frameworks - Spring, Play, Blade, Vaadin & Co 2
D JBoss 5.1 mit Seam-Projekt incl. Spring Integration Frameworks - Spring, Play, Blade, Vaadin & Co 1
D JBoss Seam 2.2 und Integration meiner Spring-Beans Frameworks - Spring, Play, Blade, Vaadin & Co 3
8u3631984 Ist es möglich in Spring Entity generische Listen verwenden Frameworks - Spring, Play, Blade, Vaadin & Co 3
R Spring Boot Test Assertions mit Objekten Frameworks - Spring, Play, Blade, Vaadin & Co 6
8u3631984 Pfad zu Test Datei in application.yml in Spring Boot Test Frameworks - Spring, Play, Blade, Vaadin & Co 7
R Spring Boot sql Beziehungen Frameworks - Spring, Play, Blade, Vaadin & Co 12
8u3631984 Spring JPA Probleme beim SPeichern von Sets Frameworks - Spring, Play, Blade, Vaadin & Co 3
M Spring Boot 3 Datenbanken zur Laufzeit Verbinden Frameworks - Spring, Play, Blade, Vaadin & Co 5
8u3631984 Spring JDBC Probleme beim Spaltennamen Frameworks - Spring, Play, Blade, Vaadin & Co 3
LimDul Spring-Batches in Docker über Rest starten/verfolgen Frameworks - Spring, Play, Blade, Vaadin & Co 0
ExceptionOfExpectation In Meiner Spring-Boot Applikation verlangt die Datenbank Wert für eine ID Frameworks - Spring, Play, Blade, Vaadin & Co 5
H Spring Boot Applikation und JHM Benchmark sowie ContextConfiguration in H2 Tests ich bekomme es nicht hin Frameworks - Spring, Play, Blade, Vaadin & Co 2
ExceptionOfExpectation Tests in Spring-Boot Frameworks - Spring, Play, Blade, Vaadin & Co 4
R Eure Erfahrungen mit Primefaces und Spring - wer managed die Beans Frameworks - Spring, Play, Blade, Vaadin & Co 4
Avalon Get Request doppelt abfeuern ohne Post Redirect Get Pattern. Spring Boot Thymeleaf MVC Frameworks - Spring, Play, Blade, Vaadin & Co 12
thor_norsk Konfigurationsprobleme mit Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 9
L Spring Data und Rest Controller? Frameworks - Spring, Play, Blade, Vaadin & Co 4
thor_norsk Spring Boot Fehler Frameworks - Spring, Play, Blade, Vaadin & Co 1
L Spring Data und Rest Conroller? Frameworks - Spring, Play, Blade, Vaadin & Co 4
thor_norsk Spring Boot und Docker Frameworks - Spring, Play, Blade, Vaadin & Co 5
B Spring Amazon-SP-Api Frameworks - Spring, Play, Blade, Vaadin & Co 3
8u3631984 Aktualisiere Spring Controller Frameworks - Spring, Play, Blade, Vaadin & Co 4
L Spring Data: Modellierung mit einer Embeddable bean Frameworks - Spring, Play, Blade, Vaadin & Co 2
D Spring Boot Test ob Validation geprüft wurde Frameworks - Spring, Play, Blade, Vaadin & Co 8
K Spring Boot OneToMany Frameworks - Spring, Play, Blade, Vaadin & Co 6
8u3631984 Spring Boot Docker Image erstellen und mit docker-compose konfigurieren Frameworks - Spring, Play, Blade, Vaadin & Co 1
M Wann Spring Batch nutzen? Frameworks - Spring, Play, Blade, Vaadin & Co 1
P Spring Hessian Remote Beispiel Frameworks - Spring, Play, Blade, Vaadin & Co 20
8u3631984 Spring 2.7.8 Info Enpoint nicht zuerreichen Frameworks - Spring, Play, Blade, Vaadin & Co 1
gradlew.bat spring-boot:run funktioniert nicht Frameworks - Spring, Play, Blade, Vaadin & Co 4
Zrebna Spring Boot/Thymeleaf: Bestätigungsemail senden. Frameworks - Spring, Play, Blade, Vaadin & Co 2
Zrebna Spring - Thymeleaf: Wieso wird gem. Fallunterscheidung entsprechende View nicht geladen? Frameworks - Spring, Play, Blade, Vaadin & Co 3
Dimax Spring UsernameNotFoundException(msg); auf der View msg ausdrücken Frameworks - Spring, Play, Blade, Vaadin & Co 1
Dimax Spring UsernameNotFoundException(Message) auf der View Message ausdrücken Frameworks - Spring, Play, Blade, Vaadin & Co 2
B Spring Boot und JPA Error creating bean Frameworks - Spring, Play, Blade, Vaadin & Co 24
R Spring Security: Wie kommt 'UserDetails' an Username und Passwort ran? Frameworks - Spring, Play, Blade, Vaadin & Co 6
R Spring Security: Wie den User dynamisch authentifizieren? Frameworks - Spring, Play, Blade, Vaadin & Co 8
R Spring Security: Authentication & Permissions Frameworks - Spring, Play, Blade, Vaadin & Co 4
R Spring Boot: Warum soll PasswordEncoder in einer neuen Methode definiert sein? Frameworks - Spring, Play, Blade, Vaadin & Co 1
8u3631984 Cross-Origin beim Abrufen von Spring Endpoint Frameworks - Spring, Play, Blade, Vaadin & Co 1
D Spring Boot und Microservices Frameworks - Spring, Play, Blade, Vaadin & Co 1
M Spring Boot additional Datasource for a single entity Frameworks - Spring, Play, Blade, Vaadin & Co 0
T Spring Resourcen Ordner ermitteln Frameworks - Spring, Play, Blade, Vaadin & Co 5
B Spring JPA und Repository Frameworks - Spring, Play, Blade, Vaadin & Co 12
D Mapstruct Dependency Injection funktioniert nicht mit Spring Frameworks - Spring, Play, Blade, Vaadin & Co 15
Avalon Wie sieht bei Euch das Deployment einer Spring Boot Anwendung aus? Frameworks - Spring, Play, Blade, Vaadin & Co 4
M Threads in Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 7
W DI-Problem in Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 4
T Spring Boot: Was bewirkt parent in maven genau? Frameworks - Spring, Play, Blade, Vaadin & Co 4
T Spring Security: Run-as replacement Einsatzbereich? Frameworks - Spring, Play, Blade, Vaadin & Co 1
OnDemand Vaadin+Spring Boot erster Seitenload nach Neustart endlos Frameworks - Spring, Play, Blade, Vaadin & Co 0
doncarlito87 Wie erhalte ich ein JSON aus eine NativeQuery (Spring Boot)? Frameworks - Spring, Play, Blade, Vaadin & Co 8
Avalon @Query Select Abfrage liefert falsche Werte (Spring Boot, JPA, Hibernate) Frameworks - Spring, Play, Blade, Vaadin & Co 3
Avalon Erstellung Dockerimage mit spring-boot:build-image in Spring Boot mit Umgebungsvariablen Frameworks - Spring, Play, Blade, Vaadin & Co 0
D Spring Boot Field Injection in MapStruct Frameworks - Spring, Play, Blade, Vaadin & Co 5
D Spring Anfänger benötigt Hilfe Frameworks - Spring, Play, Blade, Vaadin & Co 9
OnDemand Spring Boot seltsame Logeinträge: Manipulationsversuche? Frameworks - Spring, Play, Blade, Vaadin & Co 2
D Spring Date keine neue Tabelle fuer Attribut Frameworks - Spring, Play, Blade, Vaadin & Co 1
T Spring Security Config File anpassen Frameworks - Spring, Play, Blade, Vaadin & Co 1
8u3631984 Spring Cloud : Resttemplate mit Loadballancer Frameworks - Spring, Play, Blade, Vaadin & Co 11
Dimax Spring resource not found Frameworks - Spring, Play, Blade, Vaadin & Co 2
M Spring MongoDB unique index Frameworks - Spring, Play, Blade, Vaadin & Co 3
M Spring Entity testen Frameworks - Spring, Play, Blade, Vaadin & Co 1
M Spring Entity testen Frameworks - Spring, Play, Blade, Vaadin & Co 5
Dimax Spring App Probleme beim Ausführen auf dem Tomcat Server Frameworks - Spring, Play, Blade, Vaadin & Co 1
D Spring WebFlux Cors konfigurieren Frameworks - Spring, Play, Blade, Vaadin & Co 1
Dimax Schöne View mit anchor scrolling in Spring Frameworks - Spring, Play, Blade, Vaadin & Co 2
Dimax Spring JPA Multiple Keys Frameworks - Spring, Play, Blade, Vaadin & Co 3
S Spring Security mit oauth2 in lokaler Konfiguration principal mocken Frameworks - Spring, Play, Blade, Vaadin & Co 0
D Spring Boot Mile Stone und Snapshot Versionen Frameworks - Spring, Play, Blade, Vaadin & Co 2
OnDemand Spring Boot Exception Body Frameworks - Spring, Play, Blade, Vaadin & Co 2
D Was ist das Framework "Spring"? Frameworks - Spring, Play, Blade, Vaadin & Co 1
M Spring Unit/Integrations Testing Frameworks - Spring, Play, Blade, Vaadin & Co 3
D Spring Unit Test: UnsatisfiedDependencyException: Error creating bean with name Frameworks - Spring, Play, Blade, Vaadin & Co 2
H Resource Liste Lazy Autowired Spring Context Frameworks - Spring, Play, Blade, Vaadin & Co 2
M Java Spring Security Frameworks - Spring, Play, Blade, Vaadin & Co 5
M Spring Security Login with Credentials Frameworks - Spring, Play, Blade, Vaadin & Co 0
N Spring Boot - Overkill für private Projekte? Frameworks - Spring, Play, Blade, Vaadin & Co 3
krgewb Spring und GWT - & wird zu & amp; Frameworks - Spring, Play, Blade, Vaadin & Co 2
K Migration eines internen Frameworks zu Spring:Boot Frameworks - Spring, Play, Blade, Vaadin & Co 0
OnDemand JPA/Spring Repository Like Suche leeres Ergebnis Frameworks - Spring, Play, Blade, Vaadin & Co 0
Z Hibernate & Postgres in Spring Boot (Syntaxprobleme) Frameworks - Spring, Play, Blade, Vaadin & Co 2
Z Spring Boot mit JPA;, Hibernate, Rest & Lombok Frameworks - Spring, Play, Blade, Vaadin & Co 8
M Spring Initializer - Webservices Frameworks - Spring, Play, Blade, Vaadin & Co 0
D Spring Hateoas Frameworks - Spring, Play, Blade, Vaadin & Co 1
ma095 Spring und Postgresql Errors Frameworks - Spring, Play, Blade, Vaadin & Co 4
OnDemand Spring+Vaadin App startet nicht Frameworks - Spring, Play, Blade, Vaadin & Co 1
OnDemand Spring Request externe API SSL Error Frameworks - Spring, Play, Blade, Vaadin & Co 7
OnDemand Spring Repo speichert, aber es kommt in der DB nicht an Frameworks - Spring, Play, Blade, Vaadin & Co 3
Dimax Im Spring ,Mysql-Funktion aufrufen Frameworks - Spring, Play, Blade, Vaadin & Co 2
OnDemand Spring Security/Boot/Vaadin Cookie Problem bei iFrame Frameworks - Spring, Play, Blade, Vaadin & Co 4
OnDemand Spring Boot: Feld ignorieren Frameworks - Spring, Play, Blade, Vaadin & Co 3
8u3631984 Spring + Thymleaf : Checkbox Object mappen Frameworks - Spring, Play, Blade, Vaadin & Co 0
N Buch zum Spring Framework bzw. Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 3
OnDemand Jasypt Spring Boot HIbernate wie komme ich an den Key? Frameworks - Spring, Play, Blade, Vaadin & Co 4
8u3631984 Spring Boot im Docker Container - Logback wird nicht verwendet Frameworks - Spring, Play, Blade, Vaadin & Co 13

Ähnliche Java Themen

Neue Themen


Oben