LINUXSOFT.cz Přeskoč levou lištu
Uživatel: Heslo:  
   CZUKPL

> 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.

7.8.2013 12:00 | Petr Horáček | Články autora | přečteno 6636×

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 println().

Spuštění a základní příkazy

Pro 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:

  • Finish Debugger Session – zastavení debugování, Shift+F5,
  • Pause – pauza,
  • Continue – pokračovat na další breakpoint, F5,
  • Step Over – přejde na další řádek, F8,
  • Step Over Expression – při prohlížení řádku přeskočí metodu bez její hlubší kontroly, Shift+F8,
  • Step Into – začne prohlížet jednotlivé metody na řádku, pokuj je dostupný jejich kód, přesune se nich, F7,
  • Step Out – vystoupí z prohlížené metody na místo jejího volání, Ctrl+F7,
  • Run to Cursor – spustí kód od aktuálního označeného řádku, F4,
  • Apply Code Changes – uloží a použije změny provedené na kódu.
Ikony debugování

Breakpoints

Breakpointy 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.

Použití breakpointů

Variables

Promě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.

Použití panelu Variables

Úprava kódu za běhu

Kó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()); 

Level

Naléhavost logu se udává pomocí tzv. Levelů, zde je jejich seznam (počínaje nejvážnějším):

  • SEVERE – velice důležité,
  • WARNING – upozornění,
  • INFO – informace,
  • CONFIG – configurace,
  • FINE – nízká důležitost,
  • FINER – nižší důležitost,
  • FINEST – nejnížší důležitost.

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 logu

Pokud 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 formatter

Kaž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.

Výstupní konzole Apache Tomcat

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 aplikace

Pojď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ěr

To 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

Verze pro tisk

pridej.cz

 

DISKUZE

Nejsou žádné diskuzní příspěvky u dané položky.



Příspívat do diskuze mohou pouze registrovaní uživatelé.
> Vyhledávání software
> Vyhledávání článků

4.10.2018 21:30 /Ondřej Čečák
LinuxDays 2018 již tento víkend, registrace je otevřená.
Přidat komentář

18.9.2018 23:30 /František Kučera
Zářijový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 20. 9. 2018 od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Tentokrát bez oficiální přednášky, ale zato s dobrým jídlem a pivem – volná diskuse na téma IoT, CNC, svobodný software, hardware a další hračky.
Přidat komentář

9.9.2018 14:15 /Redakce Linuxsoft.cz
20.9.2018 proběhne v pražském Kongresovém centru Vavruška konference Mobilní řešení pro business. Návštěvníci si vyslechnou mimo jiné přednášky na témata: Nejdůležitější aktuální trendy v oblasti mobilních technologií, správa a zabezpečení mobilních zařízení ve firmách, jak mobilně přistupovat k informačnímu systému firmy, kdy se vyplatí používat odolná mobilní zařízení nebo jak zabezpečit mobilní komunikaci.
Přidat komentář

12.8.2018 16:58 /František Kučera
Srpnový pražský sraz spolku OpenAlt se koná ve čtvrtek – 16. 8. 2018 od 19:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát jsou tématem srazu databáze prezentaci svého projektu si pro nás připravil Standa Dzik. Dále bude prostor, abychom probrali nápady na využití IoT a sítě The Things Network, případně další témata.
Přidat komentář

16.7.2018 1:05 /František Kučera
Červencový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 19. 7. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát bude přednáška na téma: automatizační nástroj Ansible, kterou si připravil Martin Vicián.
Přidat komentář

18.6.2018 0:43 /František Kučera
Červnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 21. 6. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát na téma: F-Droid, aneb svobodný software do vašeho mobilu. Kromě toho budou k vidění i vývojové desky HiFive1 se svobodným/otevřeným čipem RISC-V.
Přidat komentář

23.5.2018 20:55 /Ondřej Čečák
Od pátku 25.5. proběhne na Fakultě informačních technologií ČVUT v Praze openSUSE Conference. Můžete se těšit na spostu zajímavých přednášek, workshopů a také na Release Party nového openSUSE leap 15.0. V na stejném místě proběhne v sobotu 26.5. i seminář o bezpečnosti CryptoFest.
Přidat komentář

20.5.2018 17:45 /Redakce Linuxsoft.cz
Ve čtvrtek 31. května 2018 připravuje webový magazín BusinessIT ve spolupráci s Best Online Média s.r.o. pátý ročník odborné konference Firemní informační systémy 2018. Akce proběhne v kongresovém centru Vavruška (palác Charitas), Karlovo náměstí 5, Praha 2 (u metra Karlovo náměstí) od 9:00 hod. dopoledne do cca 15 hod. odpoledne. Konference je zaměřena na efektivní využití firemních informačních systémů a na to, jak plně využít jejich potenciál. Podrobnější informace na webových stránkách konfrence.
Přidat komentář

   Více ...   Přidat zprávičku

> Poslední diskuze

5.10.2018 17:12 / Jakub Kuljovsky
Re: Jaký kurz a software by jste doporučili pro začínajcího kodéra?

20.9.2018 10:04 / Jan Ober
Jaký kurz a software by jste doporučili pro začínajcího kodéra?

20.9.2018 10:00 / Jan Ober
Re: Gimp

20.2.2018 18:48 / Ivan Majer
portal

20.2.2018 15:57 / Jan Havel
Jak využíváte služby cloudu v podnikání?

Více ...

ISSN 1801-3805 | Provozovatel: Pavel Kysilka, IČ: 72868490 (2003-2018) | mail at linuxsoft dot cz | Design: www.megadesign.cz | Textová verze