|
||||||||||||||||||||||||||||||||||||||||||||||||
Menu
Distributions (131)
Software (10844)
|
Java na web XII. - Debugování a logováníDnes se budeme věnovat nástrojům pro monitorování a opravu kódu – debugování a logování. Díky nim budeme schopni snadněji odhalovat chyby v kódu a sledovat chod naší aplikace.
V minulém díle jsme se věnovali testování aplikace pomocí unit testingu, dnes na toto téma navážeme dalšími dvěma nástroji – debugováním a logováním. Pusťme se tedy do toho. DebugováníJako i jiné velké IDE obsahuje NetBeans integrované prostředí pro debugování. Díky němu můžete pokládat do zdrojového kódu tzv. breakpointy (zarážky), kontrolovat a upravovat části kódu za chodu, postupovat programem řádek po řádku či sledovat proměnné a vlákna. Už nikdy nebudete při hledání chyb potřebovat Spuštění a základní příkazyPro spuštění debugování stačí kliknout na ikonku Debug Project (Ctrl+F5), hned poté přibudou na lištu další ikony a otevře se několik panelů, z nichž nás budou zajímat především přehledy Variables a Breakpoints. Po spuštění můžete využívat tyto funkce:
BreakpointsBreakpointy slouží k označení řádků, na kterých se má aplikace při vykonávání kódu (v módu debugování) zastavit a vyčkat na další pokyny. Díky breakpointům můžete určit sledované proměnné, zjišťovat kdy se které hodnoty mění apod. Pro přidání breakpointu stačí kliknout na číslo řádku, stejným způsobem je možné jej i oddělat. V panelu Breakpoints je seznam všech přidaných breakpointů. Pomocí check boxů je můžete dočasně vypnout. Skvělou funkcí je sdružování breakpointů do skupin, stačí na ně kliknout pravým tlačítkem a zvolit Move Into Group. Poklepáním na položku breakpointu se také rychle dostanete k jeho řádku ve zdrojovém kódu. VariablesProměnné na řádcích označených breakpointy můžete nalézt v panelu Variables. V tabulce jsou zde zobrazeny názvy proměnných, jejich typy i hodnoty. Některé objekty je možné rozbalit a sledovat jejich vnitřní hodnoty. Pokud chcete mít o některé z proměnných stálý přehled, klikněte na její položku pravým tlačítkem a zvolte Create Fixed Watch. Úprava kódu za běhuKód aplikace je při debugování možné měnit i za běhu, můžete se tak vyhnout neustále se opakujícímu sestavování aplikace, stačí při úpravě stisknout tlačítko Apply Code Changes. Tuto funkci ale není možné použít vždy. Pokud upravujete logiku v metodách či „ladíte“ drobné části kódu, je vše v pořádku, větší změny (jako například přidávání/odebírání proměnných) provádět nelze. LogováníDíky logování můžete kontrolovat a zaznamenávat děni (či případné chyby) v aplikaci. Někdy je logování využíváno i jako způsob debugování. Pro vytvoření třídy Logger, která má na starost zápis logů z aplikace, stačí tento kód: private final static Logger LOGGER = Logger.getLogger(NazevTridy.class.getName()); LevelNaléhavost logu se udává pomocí tzv. Levelů, zde je jejich seznam (počínaje nejvážnějším):
Navíc je možné používat OFF a ALL, pro vypnutí nebo zapnutí všech logů. Následující kód nastavuje logování na level INFO, budou se tedy zapisovat pouze logy o naléhavosti INFO a vážnější (WARNING a SEVERE): LOGGER.setLevel(Level.INFO); Zápis loguPokud už máte vytvořený logger a zadaný jeho level, můžete provést zápis logu například takto: LOGGER.info("Zápis do logu"); Vytvořit logger, nastavit level a zapsat log můžete ale i jedním příkazem: Logger.getLogger(UpravaZapisku.class.getName()).log(Level.INFO, "Zápis do logu"); Handler a formatterKaždý logger má přístup k handlerům, ty se starají o převzetí logů a jejich následovný zápis na určené místo (standardně do log souboru a konzole). Na výstup handleru je možné připojit formatter, který dále zpracuje vystupující logy, ty lze poté zapisovat do databáze, HTML souborů apod. Čtení logůNejjednodušším způsobem čtení logů vyvíjené aplikace je využití výstupní konzoly aplikačního serveru Apache Tomcat umístěné přímo v NetBeans. Textové logy se nacházejí ve složce Tomcatu /logs. Můžete je otevírat buď obyčejnými textovými editory, či za pomoci specializovaných programů, které usnadňují navigaci a filtraci. Jendou z takový aplikací je i Glogg, pro jeho instalaci stačí do terminálu zadat: sudo apt-get install glogg Úprava aplikacePojďme si nyní vyzkoušet logování v naší aplikaci. Pro příklad si upravíme třídu Controller, přidejte tedy na její začátek (mimo všechny metody) kód pro vytvoření loggeru: private final static Logger LOGGER = Logger.getLogger(Controller.class.getName()); Dále přepíšeme všechno logování v blocích Try-Catch tak, aby využívalo náš logger. Změňte tedy všechny původní kódy zalogování na: LOGGER.log(Level.SEVERE, null, ex); Poslední změnou bude přidání informačního logu o pokusu přidání prázdného zápisku. Změňte tedy adresu /zapisky v metodě POST na: if(adresa.equals("/pridat")) { // ... try { // ... } catch (SQLException ex) { LOGGER.log(Level.SEVERE, null, ex); } // ... } else { LOGGER.info("Proběhl pokus o přidání nevyplněného zápisku."); presmeruj(request, response, "/?upozorneni=True"); } } Nyní už můžete aplikaci spustit a pokusit se o přidání prázdného zápisku, ve výstupu Apache Tomcat by se měl objevit nový zápis logu. ZávěrTo je k tomuto dílu vše. Příští téma bude poněkud uživatelsky vděčnější, budeme se totiž věnovat internacionalizaci aplikace. Zdrojové kódy aplikace naleznete na GitHubu: https://github.com/PetrHoracek/JavaNaWeb
|
Search Software
Search Google
|
||||||||||||||||||||||||||||||||||||||||||||||
©Pavel Kysilka - 2003-2024 | maillinuxsoft.cz | Design: www.megadesign.cz |