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í
×

dnes 00:22 | Bezpečnostní upozornění

Společnost ZONER informuje o bezpečnostním incidentu, při kterém došlo ke zcizení a zveřejnění části přihlašovacích údajů zákazníků k elektronické poště a webhostingu CZECHIA.COM.

Ladislav Hagara | Komentářů: 0
včera 23:44 | Nová verze

Byla vydána nová stabilní verze 1.13 (1.13.1008.32) webového prohlížeče Vivaldi (Wikipedie). Z novinek vývojáři zdůrazňují možnost zobrazení otevřených i uzavřených listů pomocí ikonky Okno na postranní liště a vylepšené stahování (YouTube). Nejnovější Vivaldi je postaveno na Chromiu 62.0.3202.97.

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

Byla vydána verze 2017.3 dnes již průběžně aktualizované linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux. Aktualizovat systém lze pomocí příkazů "apt update; apt dist-upgrade; reboot". Z novinek lze zmínit 4 nové nástroje: InSpy, CherryTree, Sublist3r a OSRFramework.

Ladislav Hagara | Komentářů: 0
včera 01:55 | Bezpečnostní upozornění

Společnost Uber potvrdila bezpečnostní incident a únik dat v roce 2016. Unikly údaje o 57 milionech cestujících (jména, emailové adresy a čísla mobilních telefonů) a 600 tisících řidičích (navíc čísla řidičských průkazů).

Ladislav Hagara | Komentářů: 1
21.11. 23:44 | Humor

Co vypíše příkaz man půl hodiny po půlnoci? Text "gimme gimme gimme". Jedná se o virtuální velikonoční vajíčko připomínající skupinu ABBA a její hit Gimme! Gimme! Gimme! (A Man After Midnight). Problém nastane, pokud gimme gimme gimme nabourá automatizované testování softwaru. To se pak příkaz man musí opravit [Bug 1515352] [reddit].

Ladislav Hagara | Komentářů: 10
21.11. 18:11 | Zajímavý článek

Mozilla.cz informuje, že Firefox na Fedoře podporuje Client Side Decorations. Firefox na Linuxu se vykresluje včetně standardního záhlaví okna, které je v případě webového prohlížeče většinou nadbytečné a ubírá drahocenné vertikální místo na obrazovce. Verze distribuovaná uživatelům Fedory však nyní obsahuje experimentální podporu pro takzvané Client Side Decorations, které umožňují vykreslování „oušek“ panelů do záhlaví okna.

Ladislav Hagara | Komentářů: 12
21.11. 05:00 | Bezpečnostní upozornění

Maxim Goryachy a Mark Ermolov ze společnosti Positive Technologies budou mít v prosinci na konferenci Black Hat Europe 2017 přednášku s názvem "Jak se nabourat do vypnutého počítače, a nebo jak v Intel Management Engine spustit vlastní nepodepsaný kód". O nalezeném bezpečnostním problému informovali společnost Intel. Ta bezpečnostní problém INTEL-SA-00086 v Intel Management Engine (ME), Intel Server Platform Services (SPS) a Intel

… více »
Ladislav Hagara | Komentářů: 38
21.11. 01:33 | Zajímavý projekt

Na Humble Bundle byla spuštěna akce Humble Book Bundle: Java. Za 1 dolar a více lze koupit 5 elektronických knih, za 8 dolarů a více 10 elektronických knih a za 15 dolarů a více 15 elektronických knih věnovaných programovacímu jazyku Java od nakladatelství O'Reilly. Peníze lze libovolně rozdělit mezi nakladatelství O'Reilly, neziskovou organizaci Code for America a Humble Bundle.

Ladislav Hagara | Komentářů: 0
21.11. 00:11 | Zajímavý projekt

Článek na OMG! Ubuntu! představuje rodinu písma IBM Plex. Jedná se o open source písmo (GitHub) navržené a uvolněné společností IBM (YouTube, Carbon Design System). Ukázka na Font Squirrel.

Ladislav Hagara | Komentářů: 12
20.11. 23:22 | Komunita

Na Humble Bundle lze získat počítačovou hru Brütal Legend (Wikipedie, YouTube) běžící také v Linuxu zdarma. Speciální akce končí ve středu v 19:00.

Ladislav Hagara | Komentářů: 0
Jak se vás potenciálně dotkne trend odstraňování analogového audio konektoru typu 3,5mm jack z „chytrých telefonů“?
 (9%)
 (1%)
 (1%)
 (1%)
 (75%)
 (14%)
Celkem 749 hlasů
 Komentářů: 37, poslední 21.11. 15:21
    Rozcestník

    Dotaz: Ukládání budoucích časů vs. letní čas

    Josef Kufner avatar 2.7.2011 11:29 Josef Kufner | skóre: 67
    Ukládání budoucích časů vs. letní čas
    Přečteno: 1059×
    Zrovna píšu jednu aplikaci, se kterou budou pracovat lidé v různých časových pásmech současně. Původně jsem si říkal, že bude stačit ukládat všechny časy v UTC a podle aktuálního nastavení časové zóny klienta ho správně přepočítávat. To lze celkem lehce v MySQL udělat použitím sloupců typu TIMESTAMP a nastavováním časového pásma per session (SET time_zone = '...').

    Ovšem narazil jsem na malou zákeřnost: Pokud uložím do databáze v zimě čas, který je v létě, tak až se na tento záznam podívám v létě, bude o hodinu posunut, protože jsem mezitím změnil časové pásmo z +1:00 na +2:00.

    Takže to takle jednoduché nebude.

    Jak tedy na to? Nevíte o nějakém ověřeném a jednoduchém způsobu používaném v kalendářích?

    Na webu je na toto téma hromada textu, ale prakticky všechny jsou dosti pochybné a často i zjevně chybné. Dokonce jsem našel i diskuze o chybě v Google Calendar týkající se letního času.

    Moje aplikace je klasické PHP 5.3 + MySQL, ale to není až tak podstatné.
    Hello world ! Segmentation fault (core dumped)

    Řešení dotazu:


    Odpovědi

    2.7.2011 12:24 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Něco je špatně. Buď to vy špatně používáte, nebo je chyba v MySQL. Když máte čas s časovou zónou, je jeho převod do jiné časové zóny vždy jednoznačný a není možné, aby se to přepočítávalo jednou správně a jednou špatně podle toho, zda je léto nebo zima. Letní a „zimní“ čas není nic jiného, než dvě časové zóny, mezi kterými se v konkrétní čas přepíná, a které představují pro danou oblast výchozí zónu, pokud se uvede čas bez uvedení zóny.

    Jinak v dokumentaci typů MySQL nevidím nic o časových zónách (že mě to u MySQL ani nepřekvapuje…), v MySQL Server Time Zone Support se píše, že timestamp se vždy ukládá v UTC a převádí se do aktuální časové zóny. Začal bych tedy tím, že se podíváte pomocí mysql klienta do databáze, zda tam ty časy máte správně a zda se správně převádí, když nastavíte různé časové zóny. Druhá věc je pak ještě zkontrolovat, jak se to chová v PHP, zda vám to náhodou nepřevádí mezi časovými zónami ještě podruhé.
    Jendа avatar 2.7.2011 12:53 Jendа | skóre: 74 | blog: Výlevníček | JO70FB
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Podle mě máš chybu v tom, že v zimě paušálně ode všech ukládaných časů odečítáš 2 a ke všem zobrazovaným přičítáš 2 a v létě to samé s 1. Správně bys měl nejdřív posoudit, jaký bude v tom ukládaném datu platit čas, a podle toho to teprve přepočítat (tj. když v lednu ukládám červenec 14 hodin, do databáze se uloží 12 hodin). Jediný problém, který mě napadá, je, jak se má aplikace zachovat, když jí někdo zadá v lokálním čase ten_podzimní_den 2:30.
    Why did the multithreaded chicken cross the road? to To other side. get the
    2.7.2011 13:53 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Pokud tam nějaké hodiny přičítá nebo odčítá, je problém v tom přičítání/odčítání :-) 13:00 TZ+2:00 == 12:00 TZ+1:00 == 11:00 UTC, žádné přičítání nebo odčítání není potřeba. Akorát je potřeba počítat s tím, že uživatel očekává časovou zónu platnou v době zadávaného času, ne aktuální – takže je potřeba časovou zónu přepínat podle zadávaného/čteného data, ne podle aktuálního data. Tj. pokud zadávám nebo čtu datum a čas v prosinci, musím nastavit časovou zónu SEČ, bez ohledu na to, zda je zrovna aktuální SEČ nebo SELČ. Při zadávání času mezi 2:00 a 3:00 při přechodu z letního času na standardní je asi potřeba se uživatele na časové pásmo dotázat, protože to nijak nevyvěštíte.
    Jendа avatar 2.7.2011 14:41 Jendа | skóre: 74 | blog: Výlevníček | JO70FB
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Akorát je potřeba počítat s tím, že uživatel očekává časovou zónu platnou v době zadávaného času, ne aktuální – takže je potřeba časovou zónu přepínat podle zadávaného/čteného data, ne podle aktuálního data.
    Jo, o to mi právě šlo. Jestli MySQL má tohle už nějak vyřešené, pak není co řešit. Z dotazu jsem nabyl dojmu, že si to přepočítávání píše sám.
    Why did the multithreaded chicken cross the road? to To other side. get the
    Josef Kufner avatar 2.7.2011 14:51 Josef Kufner | skóre: 67
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Zatím ještě nepíšu (a ani nechci). Zjišťuju, jak se to dělá správně a trošku experimentuju.

    Zatím jsem ve stavu, kdy v PHP i MySQL nastavuju zónu na něco ve stylu "Europe/Prague" a používám sloupce typu TIMESTAMP. Ale nevím, zda to stačí a jestli tam nejsou schované nějaké problémy...
    Hello world ! Segmentation fault (core dumped)
    2.7.2011 17:06 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Nastavením časové zóny v PHP a MySQL ale určujete časovou zónu po aktuální čas. Vy ji ale potřebujete převádět vzhledem k datu a času, který ukládáte nebo zobrazujete. Když použijete aktuální časovou zónu, dopadne to tak, že uživatel teď zadá něco na prosinec 12:00 až 13:00, ale použije se aktuální časová zóna (tj. středoevropský letní čas), takže se to převede na 10:00 až 11:00 UTC. Až si to v prosinci zobrazí, bude aktuální „zimní“ čas a zobrazí se to jako 11:00 až 12:00 SEČ. To ale není chování, které uživatel očekává.
    Josef Kufner avatar 2.7.2011 17:20 Josef Kufner | skóre: 67
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Já vím, proto tady tenhle dotaz je ;-)
    Hello world ! Segmentation fault (core dumped)
    2.7.2011 17:44 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    V tom případě ale nevím, na co se ptáte.
    2.7.2011 19:05 Sten
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Nevím konkrétně u PHP, ale MySQL a naprostá většina rozumných systémů nastavuje zónu geograficky a potom to funguje dobře pro zimní i letní čas, tj. pokud v létě použijete 24. prosince 13:00, bude to 12:00 UTC, a naopak pokud v zimě použijete 24. červen 14:00, bude to 12:00 UTC.
    2.7.2011 19:49 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    A pokud použiju 30. října 2011 2:30? Hádání časové zóny bez nápovědy uživatele obecně nemůže fungovat. Proto mají databáze, knihovny atd. pracovat vždy s dvojicí čas + časové pásmo, a pokud chce někdo časové pásmo hádat, měla by to dělat ta aplikace, která komunikuje s uživatelem. Ta jediná má dost informací a může se v případě potřeby zeptat.
    2.7.2011 20:28 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Pokud je řeč o časové zóně, tak ta už v sobě nese i informace o případném letním a zimním čase.
    2.7.2011 22:30 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    No právě. Takže teď uživatel zadá čas v SELČ, a v prosinci se mu zobrazí v SEČ, tedy o hodinu posunutý – když uživatel čas zadával, předpokládal totiž, že jej zadává v SEČ. Je tedy logické, aby aplikace uživateli vyšla vstříc a ten předpoklad splnila.
    3.7.2011 02:18 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Jen pokud je aplikace špatně napsaná. Pokud je napsaná správně, definice časové zóny obsahuje i informaci o tom, jaký je v daném okamžiku offset oproti UTC, takže se správně převede jak aktuální čas, tak jakýkoli čas v minulosti nebo budoucnosti (samozřejmě za předpokladu, že mezitím nedojde ke změně pravidel).
    3.7.2011 21:45 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Asi každý myslíme něco jiného časovou zónou. Já píšu o těch časových zónách, které jsou definovány posunem od UTC, takže třeba SEČ (+1 h.) nebo SELČ (+2 h.). Vy zřejmě píšete o časové zóně Evropa/Praha, která může být SEČ nebo SELČ, podle toho jak kdy.

    Problém je právě s určením toho časového okamžiku. Časový okamžik je určen právě časem a časovou zónou – když časová zóna chybí, může si aplikace něco domýšlet, ale to nebude vždy fungovat. I pokud dáme aplikaci také datum a aplikace bude mít pro daný rok správné údaje o přechodu na/z letní čas, pořád tam zbývá ta hodina při přechodu zpět na sluneční čas, kdy datum, čas a geografická časová zóna nestačí.
    3.7.2011 22:07 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Asi každý myslíme něco jiného časovou zónou.

    Očividně. Ale pokud se v souvislosti s unixovými systémy používá termín timezone (časová zóna), myslí se tím téměř vždy to, o čem mluvím já.

    pořád tam zbývá ta hodina při přechodu zpět na sluneční čas, kdy datum, čas a geografická časová zóna nestačí.

    Proto se také jako interní reprezentace používá ta vyjádřená pomocí time_t, která tímto problémem netrpí. A proto funkce mktime() v tom jednom speciálním případě přihlíží i k hodnotě položky tm_isdst; protože ale tento speciální případ (u většiny zón - z těch, které vůbec nějaký letní čas mají) pokrývá přibližně jednu setinu procenta roku (navíc pečlivě vybranou tak, aby se toho dělo pokud možno co nejméně), nikdo to obvykle moc neřeší.

    2.7.2011 14:53 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Ten časový okamžik se prostě musí převádět na interní reprezentaci jako celek - mimo jiné i proto, že pravidla pro letní čas se čas od času mění. Standardní knihovní funkce mktime() a localtime() resp. localtime_r() se o to postarají, otázkou jen je, jestli je autor software použije nebo jestli se spolehne na lidovou tvořivost.
    2.7.2011 13:35 Sten
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Nezadávejte zóny absolutně, ale geograficky:

    SET time_zone='Europe/Prague'

    Potom to funguje dobře.
    Josef Kufner avatar 2.7.2011 14:56 Josef Kufner | skóre: 67
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Díky. Na tohle je potřeba importovat do MySQL data o zónách, což jsem předtím nějak minul...
    Hello world ! Segmentation fault (core dumped)

    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.