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 23:14 | Nová verze

Po třech týdnech od vydání první RC verze byla vydána první stabilní verze 17.01.0 linuxové distribuce pro routery a vestavěné systémy LEDE (Linux Embedded Development Environment), forku linuxové distribuce OpenWrt. Přehled novinek v poznámkách k vydání. Dotazy v diskusním fóru.

Ladislav Hagara | Komentářů: 0
dnes 17:28 | Bezpečnostní upozornění

Byly zveřejněny informace o bezpečnostní chybě CVE-2017-6074 v Linuxu zneužitelné k lokální eskalaci práv. Jde o chybu v podpoře DCCP (Datagram Congestion Control Protocol). Do linuxového jádra se dostala v říjnu 2005. V upstreamu byla opravena 17. února (commit). Bezpečnostní chyba byla nalezena pomocí nástroje syzkaller [Hacker News].

Ladislav Hagara | Komentářů: 2
dnes 15:00 | Zajímavý software

Společnost Valve vydala novou beta verzi SteamVR. Z novinek lze zdůraznit oficiální podporu Linuxu. Další informace o podpoře této platformy pro vývoj virtuální reality v Linuxu v diskusním fóru. Hlášení chyb na GitHubu.

Ladislav Hagara | Komentářů: 0
dnes 06:00 | Nová verze

Po necelém roce od vydání verze 0.67 byla vydána verze 0.68 populárního telnet a ssh klienta PuTTY. Podrobnosti v přehledu změn. Řešeny jsou také bezpečnostní chyby.

Ladislav Hagara | Komentářů: 0
včera 21:32 | Nasazení Linuxu

Canonical představuje nejnovější verzi chytré helmy DAQRI s Ubuntu pro rozšířenou realitu. K vidění bude příští týden v Barceloně na veletrhu Mobile World Congress 2017.

Ladislav Hagara | Komentářů: 0
včera 21:31 | Pozvánky

Pro zájemce o hlubší znalosti fungování operačních systémů připravila MFF UK nový předmět Pokročilé operační systémy, v rámci něhož se vystřídají přednášející nejen z řad pracovníků fakulty, ale dorazí také odborníci ze společností AVAST, Oracle, Red Hat a SUSE. Tento předmět volně navazuje na kurz Operační systémy ze zimního semestru, ale pokud máte praktické zkušenosti odjinud (například z přispívání do jádra Linuxu) a chcete si

… více »
Martin Děcký | Komentářů: 6
včera 21:30 | Pozvánky

Czech JBoss User Group Vás srdečně zve na setkání JBUG v Brně, které se koná ve středu 1. března 2017 v prostorách Fakulty Informatiky Masarykovy Univerzity v místnosti A318 od 18:00. Přednáší Tomáš Remeš a Matěj Novotný na téma CDI 2.0 - New and Noteworthy. Více informací na Facebooku a na Twitteru #jbugcz.

mjedlick | Komentářů: 0
20.2. 23:45 | Zajímavý software

Na blogu Qt bylo představeno Qt 3D Studio. Jedná se o produkt dosud známý pod názvem NVIDIA DRIVE™ Design Studio. NVIDIA jej věnovala Qt. Jedná se o několik set tisíc řádků zdrojového kódu. Qt 3D Studio bude stejně jako Qt k dispozici jak pod open source, tak pod komerční licencí. Ukázka práce s Qt 3D Studiem na YouTube.

Ladislav Hagara | Komentářů: 10
20.2. 17:50 | Komunita

Nadace The Document Foundation (TDF) zastřešující vývoj svobodného kancelářského balíku LibreOffice slaví 5 let od svého oficiálního vzniku. Nadace byla představena 28. září 2010. Formálně byla založena ale až 17. února 2012.

Ladislav Hagara | Komentářů: 0
20.2. 12:50 | Komunita

Mozilla.cz informuje, že dosud experimentální funkce Page Shot z programu Firefox Test Pilot (zprávička) se stane součástí Firefoxu. Page Shot je nástroj pro vytváření snímků webových stránek. Umí výběr oblasti, prvku stránky (např. odstavce), nebo uložení snímku celé stránky. Snímky lze ukládat na disk nebo nahrávat na server Mozilly. Nedávno bylo oznámeno, že se součástí Firefoxu stane Activity Stream.

Ladislav Hagara | Komentářů: 52
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (13%)
 (2%)
 (71%)
 (4%)
 (10%)
Celkem 685 hlasů
 Komentářů: 66, poslední dnes 18:57
Rozcestník

Dotaz: Cron - nespouštět novou instanci

16.9.2011 09:16 Standa N.
Cron - nespouštět novou instanci
Přečteno: 248×

Pouštím v CRONu každé 2 minuty úlohu, která zpracovává poměrně složitý SQL job nad Oracle DB.

*/2 06-18 * * 1-5 su - oracle -c "sqlplus @/usr/local/bin/job.sql"

Job běží cca 10-20 sekund a čas si loguji do DB.
Bohužel při extrémním zatížení DB (které neovlivním) běží skript i 5 minut.

OTÁZKA:
Mohu nějak zařídit, aby se úloha v cronu nespustila znovu, dokud nedoběhla její předchozí instance?
Něco podobného jako je ve WIN-plánovači úloh.
Jediné co mne napadá, že si budu ukládat a hlídat "běží/neběží" až v DB.

Díky, Standa


Řešení dotazu:


Odpovědi

16.9.2011 10:07 David Karban | skóre: 12 | blog: DK
Rozbalit Rozbalit vše Re: Cron - nespouštět novou instanci
Zdravím,

nestačí na toto jen obyčejný zámek realizovaný souborem?

Na začátku skriptu si otestujete, jestli existuje zámek, pokud ano tak skript ještě běží. Pokud ne tak ho vytvoříte a na konci cronu jej smažete. Má to ale háček v tom, že když skript spadne, tak neodstraní zámek. To se dá vyřešit třeba tak, že v zámku máte uloženo PID procesu co běží a na začátku provedete i test zda skutečně běží.

Stejně tak se dá zámek udělat přímo v databázi.
16.9.2011 10:36 Standa N.
Rozbalit Rozbalit vše Re: Cron - nespouštět novou instanci

Díky,
právě - jediné čeho jsem se bál je situace, kdy by skript padnul, nebo by ho někdo killnul.
Zkusím to nějak realizovat, Díky.

16.9.2011 12:21 l4m4
Rozbalit Rozbalit vše Re: Cron - nespouštět novou instanci
Pokud skript může padat, nedávej zaykání do něj, ale do nějakého wrapperu (který navíc pomocí trap po sobě může vyčistit i v případě ukončení signálem - kromě KILL samozřejmě).
16.9.2011 11:16 jekub
Rozbalit Rozbalit vše Re: Cron - nespouštět novou instanci
Proč si úlohu nenaplánujete přímo v databázi (dbms_job, dbms_scheduler)?
16.9.2011 12:28 Standa N.
Rozbalit Rozbalit vše Re: Cron - nespouštět novou instanci

Aha, taková možnost mne ani nenapadla - SQL umím obstojně, ale nejsem ORACLE specialista.

Je tam někde možnost spustit max. jednu instanci?
Syntaxi si dohledám, díky.

16.9.2011 13:42 jekub
Rozbalit Rozbalit vše Re: Cron - nespouštět novou instanci
pokud je interval spouštění kratší než doba běhu, tak...
drop table t;
create table t(sid number,dt date,descr varchar2(10));

create or replace procedure p is
begin
	insert into t values(sys_context('userenv','sid'),sysdate,'start');
	dbms_lock.sleep(90);
	insert into t values(sys_context('userenv','sid'),sysdate,'stop');
end;	
/

var job number
exec dbms_job.submit(:job,'begin p;end;',sysdate,'sysdate+1/24/60')
commit;

...

select sid,to_char(dt,'DD.MM.YYYY HH24:MI:SS'),descr from t order by dt

157	16.09.2011 13:32:32	start
157	16.09.2011 13:34:02	stop
157	16.09.2011 13:34:02	start
157	16.09.2011 13:35:32	stop
157	16.09.2011 13:35:32	start
157	16.09.2011 13:37:02	stop

exec dbms_job.remove(:job)
drop procedure p;
drop table t;

16.9.2011 14:20 drunkezz | skóre: 32 | blog: kadeco
Rozbalit Rozbalit vše Re: Cron - nespouštět novou instanci
alebo priamo do skriptu spravit podmienku

cize zistit si PID beziaceho job.sql..a vzdy ked sa uloha z kronu spusti tak najprv skontroluje ci bezi alebo nebezi predchadzajuca uloha....ja to robim tak.. D.
17.9.2011 11:57 Lukáš Džunko | skóre: 39 | blog: Jooky | Bratislava
Rozbalit Rozbalit vše Re: Cron - nespouštět novou instanci
Ja na podobne pripady pouzivam vyspelejsi "fcron". Jeden s viacerych parametrov, ktore ma je moznost "serial". Job oznaceny ako serial, moze bezat len raz, aj ked podla planovania by sa mal pustit znova ... no ak je moznost to pustat rovno v DB, tak ja by som pouzil tu moznost.

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.