abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×

včera 22:22 | Komunita

V Norimberku probíhá do neděle 28. května openSUSE Conference 2017. Na programu je celá řada zajímavých přednášek. Sledovat je lze online. K dispozici jsou také videozáznamy (YouTube) již proběhnuvších přednášek. Dění lze sledovat na Twitteru.

Ladislav Hagara | Komentářů: 0
včera 11:33 | IT novinky

Red Hat kupuje společnost Codenvy stojící za stejnojmenným webovým (cloudovým) integrovaným vývojovým prostředím (WIDE) postaveném na Eclipse Che.

Ladislav Hagara | Komentářů: 0
včera 08:55 | Nová verze

V listopadu 2014 byl představen fork Debianu bez systemd pojmenovaný Devuan. Po dva a půl roce jeho vývojáři oznámili vydání první stabilní verze 1.0. Jedná se o verzi s dlouhodobou podporou (LTS) a její kódové jméno je Jessie, podle planetky s katalogovým číslem 10 464.

Ladislav Hagara | Komentářů: 10
25.5. 20:22 | Zajímavý článek

Nadace Raspberry Pi vydala již osmapadesáté číslo (pdf) stostránkového anglicky psaného časopisu MagPi věnovanému Raspberry Pi a projektům postaveným na tomto jednodeskovém počítači a druhé číslo (pdf) časopisu Hello World primárně určeného pro učitele informatiky a výpočetní techniky.

Ladislav Hagara | Komentářů: 0
25.5. 19:55 | Humor

Portál Stack Overflow informuje na svém blogu, že pomohl ukončit editor Vim už více než milionu vývojářů. V loňském roce například hledal odpověď na otázku Jak ukončit editor Vim v průměru 1 z 20 000 návštěvníků.

Ladislav Hagara | Komentářů: 10
25.5. 19:22 | Nová verze

Po pěti měsících od vydání verze 3.5.0 byla vydána nová stabilní verze 3.6.0, tj. první z nové řady 3.6, minimalistické linuxové distribuce zaměřené na bezpečnost Alpine Linux (Wikipedie). Z novinek lze zmínit například podporu dvou nových 64bitových platforem little-endian POWER machines (ppc64le) a IBM z Systems (s390x) nebo nové balíčky Rust 1.17.0, Cargo 0.18.0, GHC 8.0.2 a Julia 0.5.2.

Ladislav Hagara | Komentářů: 0
24.5. 21:33 | Bezpečnostní upozornění

V Sambě byla nalezena a opravena bezpečnostní chyba CVE-2017-7494. Má-li útočník právo ukládat soubory na vzdálený server, může tam uložit připravenou sdílenou knihovnu a přinutit smbd server k jejímu načtení a tím pádem ke spuštění libovolných příkazů. Chyba je opravena v upstream verzích 4.6.4, 4.5.10 a 4.4.14. Chyba se týká všech verzí Samby od verze 3.5.0 vydané 1. března 2010.

Ladislav Hagara | Komentářů: 7
24.5. 20:44 | Nová verze

Byla vydána nová stabilní verze 4.3.0 integrovaného vývojového prostředí (IDE) Qt Creator. Z novinek lze zmínit například integraci editoru kódu do Qt Quick Designeru.

Ladislav Hagara | Komentářů: 1
24.5. 20:11 | Bezpečnostní upozornění

Společnost Check Point informuje na svém blogu o novém vektoru útoku. Pomocí titulků lze útočit na multimediální přehrávače VLC, Kodi, Popcorn Time, Stremio a pravděpodobně i další. Otevření útočníkem připraveného souboru s titulky v neaktualizovaném multimediálním přehrávači může vést ke spuštění libovolných příkazů pod právy uživatele. Ukázka na YouTube. Chyba je opravena v Kodi 17.2 nebo ve VLC 2.2.6.

Ladislav Hagara | Komentářů: 14
23.5. 15:18 | Zajímavý software

CrossOver, komerční produkt založený na Wine, je dnes (23. 5. 2017) dostupný ve slevě. Roční předplatné linuxové verze vyjde s kódem TWENTYONE na $21, resp. $1 v případě IP z chudších zemí. Firma CodeWeavers, která CrossOver vyvíjí, významně přispívá do Wine. Přidaná hodnota CrossOver spočívá v přívětivějším uživatelském rozhraní, integraci do desktopu a podpoře.

Fluttershy, yay! | Komentářů: 27
Chystáte se pořídit CPU AMD Ryzen?
 (6%)
 (33%)
 (1%)
 (8%)
 (44%)
 (9%)
Celkem 627 hlasů
 Komentářů: 62, poslední 19.5. 01:57
    Rozcestník

    Dotaz: jetty 7 - samostatné logování requestů pro každou webapp

    Jiri 26.5.2010 10:21 Jiri "eR0" Svoboda | skóre: 37 | blog: cat /dev/mind | Prostějov
    jetty 7 - samostatné logování requestů pro každou webapp
    Přečteno: 415×
    Zkusil jsem místo jetty verze 6 nasadit verzi 7 a nedaří se mi zprovoznit samostatné logování pro každou aplikaci.

    U verze 6 má třída WebAppContext metodu addHandler(), takže stačí do příslušného <context>.xml dopsat pár řádků, jak je uvedeno např. na http://docs.codehaus.org/display/JETTY/Logging+Requests dole.

    U verze 7 třída WebAppContext metodu addHandler() nemá, takže tento postup nefunguje. Tuto metodu jsem ale našel u třídy HandlerCollection, ovšem nevím, jak to do konfiguračního souboru zakomponovat. Navíc se zdá, že instance HandlerCollection je společná pro třídu Server, takže nevím, zda je vhodné/možné tam přidávat handlery pro jednotlivé webapps. Nebo je třeba založit vlastní instanci?

    Jsem zmaten a google nepomáhá. Našel jsem pár podobných otázek, ale bez odpovědi.

    Řešení dotazu:


    Odpovědi

    26.5.2010 10:36 Filip Jirsák | skóre: 66 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: jetty 7 - samostatné logování requestů pro každou webapp
    Použijte ContextHandler, do něj vložte HandlerCollection, který postupně zavolá všechny vložené handlery bez ohledu na výsledek předchozího handleru, a do něj vložte postupně WebAppContext a po něm RequestLogHandler.
    Jiri 26.5.2010 14:11 Jiri "eR0" Svoboda | skóre: 37 | blog: cat /dev/mind | Prostějov
    Rozbalit Rozbalit vše Re: jetty 7 - samostatné logování requestů pro každou webapp
    Díky za odpověď. Na jejím podkladě jsem sesmolil tohle:
    <?xml version="1.0"  encoding="ISO-8859-1"?>
    <!DOCTYPE Configure PUBLIC "-//Jetty//Configure//EN" "http://www.eclipse.org/jetty/configure.dtd">
    
    <Configure class="org.eclipse.jetty.server.handler.ContextHandler">
      <Set name="contextPath">/</Set>
      <Set name="resourceBase">
        <SystemProperty name="jetty.home" default="."/>/webapps/neco.cz
      </Set>
      <Set name="virtualHosts">
        <Array type="java.lang.String">
          <Item>local.neco.cz</Item>
        </Array>
      </Set>
    
      <New class="org.eclipse.jetty.server.handler.HandlerCollection">
        <Call name="addHandler">
          <Arg>
            <New class="org.eclipse.jetty.server.handler.RequestLogHandler">
              <Set name="requestLog">
                <New id="RequestLogImpl" class="org.eclipse.jetty.server.NCSARequestLog">
                  <Arg>
                    <SystemProperty name="jetty.logs" default="./logs"/>/yyyy_mm_dd-neco.cz-request.log
                  </Arg>
                  <Set name="retainDays">90</Set>
                  <Set name="append">true</Set>
                  <Set name="extended">true</Set>
                  <Set name="logCookies">false</Set>
                  <Set name="LogTimeZone">GMT</Set>
                </New>
              </Set>
            </New>
          </Arg>
        </Call>
      </New>
      <New class="org.eclipse.jetty.webapp.WebAppContext">
      </New>
    </Configure>
    
    Nejen, že to neloguje (resp. ani soubor pro log neotevře), ale navíc místo obsahu patřičného virtualhosta posílá obsah default contextu. Zkoušel jsem <Set name="virtualHosts"> ... přmístit do WebAppContext, ale výsledek je stejný.

    Přiznávám, že některá zákoutí konfigurace jetty jsou pro mne zatím španělská vesnice, hodně tápu. A dokumentace se mi zdá na rozdíl od jiných projektů dost neuchopitelná. :-(
    26.5.2010 14:50 Filip Jirsák | skóre: 66 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: jetty 7 - samostatné logování requestů pro každou webapp
    Zkuste to takhle:
    <?xml version="1.0"  encoding="ISO-8859-1"?>
    <!DOCTYPE Configure PUBLIC "-//Jetty//Configure//EN" "http://www.eclipse.org/jetty/configure.dtd">
    
    <Configure class="org.eclipse.jetty.server.handler.ContextHandler">
      <Set name="contextPath">/</Set>
      <Set name="virtualHosts">
        <Array type="java.lang.String">
          <Item>local.neco.cz</Item>
        </Array>
      </Set>
    
      <Set name="handler">
    		<New class="org.eclipse.jetty.server.handler.HandlerCollection">
    			<Call name="addHandler">
    				<Arg>
    					<New class="org.eclipse.jetty.webapp.WebAppContext">
    						<Set name="contextPath">/</Set>
    						<Set name="resourceBase">
    							<SystemProperty name="jetty.home" default="."/>/webapps/neco.cz
    						</Set>
    					</New>
    				</Arg>
    			</Call>
    			<Call name="addHandler">
    				<Arg>
    					<New class="org.eclipse.jetty.server.handler.RequestLogHandler">
    						<Set name="requestLog">
    							<New id="RequestLogImpl" class="org.eclipse.jetty.server.NCSARequestLog">
    								<Arg>
    									<SystemProperty name="jetty.logs" default="./logs"/>/yyyy_mm_dd-neco.cz-request.log
    								</Arg>
    								<Set name="retainDays">90</Set>
    								<Set name="append">true</Set>
    								<Set name="extended">true</Set>
    								<Set name="logCookies">false</Set>
    								<Set name="LogTimeZone">GMT</Set>
    							</New>
    						</Set>
    					</New>
    				</Arg>
    			</Call>
    		</New>
      </set>
    </Configure>
    
    Jiri 26.5.2010 16:11 Jiri "eR0" Svoboda | skóre: 37 | blog: cat /dev/mind | Prostějov
    Rozbalit Rozbalit vše Re: jetty 7 - samostatné logování requestů pro každou webapp
    Máme tu posun. V zásadě to funguje, tedy především to začalo logovat. Teď to má tu vadu, že pokud cesta končí lomítkem, tak neposkytne index.jsp, ale dostanu java.lang.StackOverflowError. Pokud napíšu úplnou cestu, je to v pořádku. To už je ale jiný problém, mrknu na to zítra (zřejmě chybí nastavení, které jsem předtím odněkud dědil).
    26.5.2010 16:18 Filip Jirsák | skóre: 66 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: jetty 7 - samostatné logování requestů pro každou webapp
    To vypadá, že se to zacyklí při interním přesměrovávání. Nejsem si jist, jak fungují ty kontexty vnořené do sebe – ale v tom ContextHanlderu contextPath určitě musí být nastaven, aby se logovala jen příslušná webová aplikace (i když zrovna v tomhle případě je webová aplikace v rootu, takže by to vyšlo nastejno, i kdyby se logovalo vše).
    Jiri 27.5.2010 17:56 Jiri "eR0" Svoboda | skóre: 37 | blog: cat /dev/mind | Prostějov
    Rozbalit Rozbalit vše Re: jetty 7 - samostatné logování requestů pro každou webapp
    Tak jsem nad tím dnes strávil zase pár hodin... Nejprve jsem se to pokoušel udělat pomocí jinak seskládaných objektů v konfiguraci, aby těch handlerů nebylo tolik v sobě (dnes jsem toho hodně pochopil). Zdá se ale, že jediná použitelná kombinace je ta vámi nabídnutá. Takže jsem se zaměřil na tu výjimku.

    Zacyklí se to opravu při forwardu, ale konkrétně to vypadá takto:
    ...
    at org.eclipse.jetty.server.Dispatcher$ForwardAttributes.setAttribute(Dispatcher.java:474)
    at org.eclipse.jetty.server.Dispatcher$ForwardAttributes.removeAttribute(Dispatcher.java:495)
    at org.eclipse.jetty.server.Dispatcher$ForwardAttributes.setAttribute(Dispatcher.java:474)
    at org.eclipse.jetty.server.Dispatcher$ForwardAttributes.removeAttribute(Dispatcher.java:495)
    at org.eclipse.jetty.server.Dispatcher$ForwardAttributes.setAttribute(Dispatcher.java:474)
    at org.eclipse.jetty.server.Dispatcher$ForwardAttributes.removeAttribute(Dispatcher.java:495)
    at org.eclipse.jetty.server.Dispatcher$ForwardAttributes.setAttribute(Dispatcher.java:474)
    at org.eclipse.jetty.server.Dispatcher$ForwardAttributes.removeAttribute(Dispatcher.java:495)
    at org.eclipse.jetty.server.Request.removeAttribute(Request.java:1371)
    at org.eclipse.jetty.server.Dispatcher.forward(Dispatcher.java:212)
    at org.eclipse.jetty.server.Dispatcher.forward(Dispatcher.java:115)
    ...
    
    Metoda removeAttribute(name) volá setAttribute(name, null) a ta při splnění určitých podmínek (které jsou v tomto případě evidentně splněny) volá opět removeAttribute(name).

    Podle dalšího pohledu do zdrojáku se zdá, že pravou příčinou je zajímavě okomentovaný řádek:

    request.removeAttribute(__JSP_FILE); // TODO remove when glassfish 1044 is fixed

    Takže jsem asi narazil na chybu, která vznikla ja dočasný workaround chyby 1044 v Glassfish.

    A teď, babo raď...
    27.5.2010 18:38 Filip Jirsák | skóre: 66 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: jetty 7 - samostatné logování requestů pro každou webapp
    To ale máte nějakou starší verzi (před stabilní 7.0.0), ne? Podle mne se takhle kód, který je už v 7.0.0 stable zacyklit nemůže… I když u těch pre verzí by se to normálně takhle zacyklit taky nemělo, ale možná ten kód v některé verzi vypadal ještě jinak. Každopádně ten řádek s __JSP_FILE s tím nesouvisí. Pokud používáte nějakou starší verzi, zkuste nejnovější stabilní, a jinak napište, jakou verzi používáte – protože tohle spíš vypadá na chybu v Jetty (kdyby to byla chyba v konfiguraci, muselo by se to zacyklit už dřív).
    Jiri 28.5.2010 07:04 Jiri "eR0" Svoboda | skóre: 37 | blog: cat /dev/mind | Prostějov
    Rozbalit Rozbalit vše Re: jetty 7 - samostatné logování requestů pro každou webapp
    Dělá mi to ve verzích jetty-hightide-7.0.1.v20091125 a jetty-hightide-7.1.0.v20100505. Jiné verze jsem nezkoušel. Hightide používám, protože na rozdíl od eclipse verze má podporu JSP.

    Jako runtime pouzivam jdk1.6.0_18.

    Podle vás to mám zkusit nahlásit?
    Jiri 31.5.2010 08:05 Jiri "eR0" Svoboda | skóre: 37 | blog: cat /dev/mind | Prostějov
    Rozbalit Rozbalit vše Re: jetty 7 - samostatné logování requestů pro každou webapp
    V pátek jsem to nahlásil jako bug. Někdo se ozval a ještě mě požádal o debug log. Takže uvidíme.
    Jiri 7.6.2010 15:24 Jiri "eR0" Svoboda | skóre: 37 | blog: cat /dev/mind | Prostějov
    Rozbalit Rozbalit vše Re: jetty 7 - samostatné logování requestů pro každou webapp
    Takže skoro vyřešeno.

    Ta nekonečná smyčka sama o sobě chybou nebyla, způsobovaly ji opravdu ty do sebe vnořené kontexty.

    Bug report však poukázal na to, že Jetty 7 opravdu neumí logovat pro každý kontext zvlášť. Dnes ráno jeden z vývojářů doplnil podporu této vlastnosti do zdrojáků.

    Bug report a jeho příjemný důsledek je zde: http://jira.codehaus.org/browse/JETTY-1231

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.