Na projektech, kterých se účastním, se ještě dnes setkávám kódem, který považuje logování pomocí System.out za výborný nápad. Proto bych v tomto článku chtěl rozebrat, co považuji konci roku 2013 za nejlepší logovací řešení.
Přehled
V javě máme několik možností, jak logovat:
- System.out respektive System.err,
- java.util.logging (JUL),
- Jakarta (Apache) commons logging (JCL),
- log4j,
- slf4j a
- logback.
System.out resp. System.err
Tuto variantu používám jen při zkoušení izolovaných věcí a záměrně odřezávám nepotřebné závislosti. Funguje na všech verzí javy.
Hlavní důvody, proč nepoužívat System.out
- Nelze konfiguračně vypnout na různých prostředích což má za následek výkonostní a bezpečnostní problémy a
- nelze konfiguračně nastavit úroveň zpráv.
Java Util Logging (JUL)
Tato možnost již máme v JRE myslím od verze 1.5. Kupodivu jsem ji na komerčních projektech ani v open-source projektech nepotkal. Podle mě se neujala, protože přišla tak trochu s křížkem po funuse.
log4j
Tuto možnost jsem používal na SE i EE projektech před pěti a více lety. Nenarážel jsem na limity tohoto řešení a byl jsem s ním byl spokojen. Možnosti konfigurovatelnosti ale daleko zaostávají za jeho nástupcem - logback.
Jakarta Commons Logging (JCL)
Toto řešení mělo za cíl unifikovat rozhraní mezi různými logovacími frameworky. Samo o sobě logování neřeší, jen posílá zprávy do konkrétních implentací - log4i, JUL. Rozhraní je skutečně jednoduché a můj oblíbený spring framework je tímto api prolezlý skrz naskrz. Toto řešení bohužel sebou nese některé problémy, kvůli kterým bych toto řešení nedoporučoval.
slf4j
Tato knihovna řeší stejný problém jako JCL - tedy unifikace rozhraní nad různými logovacími API. Nové komerční projekty i řada open-source projektů dnes používá právě toto api. Dnes ho používám na několika komerčních i sranda projektech k plné spokojenosti.
logback
Autorem je tvůrce log4j i slf4j - Ceki Gülcü.
Důvody, proč přejí z log4j na logback sám sepsal v článku Logback: Reasons to Switch
Mě osobně nejvíce oslovily dvě vlastnosti:
- podmíněná konfigurace, kterou používám pro nastavení úrovně logování v závislosti na prostředí.
- SiftingAppender, který umožňuje logovat dle dynamického parametru, např zalogovaného uživatele.
Závěr
- Nepoužívejte System.out resp. System.err
- Používejte slf4j spolu s logback.
1 komentář:
Je to vhodne rozdelene na api a implementaci, takze se da v komponentach pouzit jen to slf4j. Automaticky se pouzije prvni nalezena implementace (Logback (a vlastne jinou neznam)). Pomoci logback.xml se to dobre konfiguruje.
Okomentovat