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 18:11 | Nová verze

Společnost Oracle oficiálně oznámila vydání Java SE 9 (JDK 9), Java Platform Enterprise Edition 8 (Java EE 8) a Java EE 8 Software Development Kit (SDK). Java SE 9 přináší více než 150 nových vlastností.

Ladislav Hagara | Komentářů: 0
včera 12:11 | Komunita

Na Humble Bundle lze získat hororovou počítačovou hru Outlast (Wikipedie) běžící také v Linuxu zdarma. Speciální akce končí v sobotu v 19:00.

Ladislav Hagara | Komentářů: 1
včera 10:33 | Humor

Mozilla.cz upozorňuje na Knihu Mozilly (Wikipedie), tj. velikonoční vajíčko ve Firefoxu. Zobrazit jej lze zadáním about:mozilla do adresního řádku. Aktuální verze Firefoxu obsahuje proroctví 15:1 "Dvojčata Mamonu se rozhádala a jejich souboje uvrhly svět do nové tmy. Zvířeti se ale tma hnusila. A tak se stalo mrštnější a silnější, šlo vpřed a jeho počty rostly. A zvíře přineslo oheň a světlo do tmy". Firefox 57 bude obsahovat proroctví 11:14. To je zatím jenom v angličtině. Pomoci lze s překladem do češtiny.

Ladislav Hagara | Komentářů: 8
včera 01:22 | Zajímavý projekt
Před měsícem byla spuštěna kampaň na podporu chytrého telefonu Librem 5, jenž by měl respektovat bezpečnost, svobodu a soukromí uživatelů. Cílem kampaně je vybrat alespoň milion a půl dolarů. Aktuálně je vybráno přes 600 000 dolarů, tj. 40 %. Kampaň poběží ještě další měsíc. Podporu projektu oznámilo KDE i GNOME.
Ladislav Hagara | Komentářů: 27
včera 00:55 | Komunita

Agentura DISA (Defense Information Systems Agency) publikovala (pdf) Ubuntu 16.04 Security Technical Implementation Guide (STIG) (zip), tj. doporučené bezpečnostní nastavení Ubuntu 16.04. Ubuntu se tak dostalo mezi unixové operační systémy a linuxové distribuce AIX, HP-UX, Oracle Linux, Red Hat a Solaris [reddit].

Ladislav Hagara | Komentářů: 2
21.9. 22:55 | Bezpečnostní upozornění

CSIRT.CZ informuje, že byly vydány nové bezpečnostní aktualizace, které opravují několik zranitelných míst v Sambě. Útočník může využít zranitelnosti s cílem získání přístupu k potenciálně citlivých informací. Uživatelům a správcům je doporučeno, aby zkontrolovali bezpečnostní opatření pro CVE-2017-12150, CVE-2017-12151 a CVE-2017-12163 a provedli potřebné aktualizace.

Ladislav Hagara | Komentářů: 0
21.9. 21:44 | Komunita

Společnost Red Hat aktualizovala svůj slib ohledně softwarových patentů. Slib nově zahrnuje i open source software pod permisivními licencemi.

Ladislav Hagara | Komentářů: 0
21.9. 08:55 | Komunita

Do 22. září probíhá v Mountain View konference XDC2017 (X.Org Developer's Conference). Na programu je řada zajímavých přednášek. Sledovat je lze online. K dispozici je záznam přednášek ze včerejšího dne.

Ladislav Hagara | Komentářů: 0
20.9. 17:33 | Nová verze

Byla vydána nová stabilní verze 1.12 (1.12.955.36) webového prohlížeče Vivaldi (Wikipedie). Z novinek vývojáři zdůrazňují možnost zobrazení metadat u digitálních fotografií, vylepšený panel stahování a omezení sytosti barvy zdůraznění (YouTube). Nejnovější Vivaldi je postaveno na Chromiu 61.0.3163.91.

Ladislav Hagara | Komentářů: 40
20.9. 10:55 | Nová verze

Byla vydána verze 4.0 programovacího jazyka Swift (Wikipedie). Zdrojové kódy jsou k dispozici na GitHubu. Ke stažení jsou oficiální binární balíčky pro Ubuntu 16.10, Ubuntu 16.04 a Ubuntu 14.04.

Ladislav Hagara | Komentářů: 5
Těžíte nějakou kryptoměnu?
 (5%)
 (3%)
 (17%)
 (75%)
Celkem 558 hlasů
 Komentářů: 22, poslední 29.8. 11:23
    Rozcestník

    Dotaz: Python spouštění shellových skriptů

    15.3.2012 00:40 Martin Matějek | skóre: 13 | blog: Flying_circus | Kladno
    Python spouštění shellových skriptů
    Přečteno: 591×
    Zdravím,

    tvořím v Pythonu (2.6.6) jednoduchý prográmek, který když dostane HTTP žádost na konkrétní URL, spustí určitou akci. Konkrétně, získá data z databáze, vyrobí konfigurační soubory pro firewall a dhcp podle šablon a resetuje tyto služby. S jednorázovými skripty (iptables) to funguje v pořádku, ale takto spuštěný dhcp-server se drží socketu, na kterém naslouchá rodič a když rodič z nějakého důvodu skončí, nemůžu ho znovu spustit protože cílový port už drží proces dhcp-serveru.

    Z toho co jsem se dočetl v dokumentaci, tak voláním subprocess.call() nebo subprocess.Popen() vždycky vyrobím potomka, ať už přes fork() nebo execvp(). Já ale potřebuju, aby se skript spustil v novém shellu jako nový proces, ne jako potomek toho to skriptu. Jde to vůbec nějak?

    Pro ukázku jsem vyrobil dva jednoduché skripty, aby bylo vidět, jak to celé (ne)funguje.

    foo.sh - spustí cokoliv co zadám v argumentu
    #!/bin/bash
    $1
    
    foo.py - vyrobí socket a spustí skript foo.sh
    import subprocess
    import socket
    import time
    
    s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    s.bind(('localhost',8080))
    s.listen(10)
    
    subprocess.call(['foo.sh', 'firefox'])
    
    time.sleep(30)
    
    Podle fuser, všechny procesy drží port 8080
    yenn@wintermute:~$ fuser -v 8080/tcp
                         USER        PID ACCESS COMMAND
    8080/tcp:            yenn       9825 F.... python
                         yenn       9826 F.... foo.sh
                         yenn       9827 F.... firefox
    
    Don't judge me by the friends I keep. No, no, no. Judge me by the enemies I have slain!

    Řešení dotazu:


    Odpovědi

    Řešení 1× (Martin Matějek (tazatel))
    15.3.2012 10:23 chochi | skóre: 29 | Praha
    Rozbalit Rozbalit vše Re: Python spouštění shellových skriptů
    Ja bych to videl takhle:
    
    subprocess.call(['./foo.sh', 'firefox'], close_fds = True)
    
    (ono je to v dokumentaci napsano dost zmatene).
    15.3.2012 16:49 Martin Matějek | skóre: 13 | blog: Flying_circus | Kladno
    Rozbalit Rozbalit vše Re: Python spouštění shellových skriptů
    Tohle to vyřešilo, díky!
    Don't judge me by the friends I keep. No, no, no. Judge me by the enemies I have slain!
    Řešení 1× (Martin Matějek (tazatel))
    rADOn avatar 15.3.2012 13:17 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: Python spouštění shellových skriptů
    Dhcp server je démon. Démon je proces který se odpojil od tty a od svého předka resp. jeho předek je init. Na to je takovej postup který každý takový program ovládá a nemusíš se v tom vrtat. Démony nespoštěj přímo ale měj je nastarovaný initem a jen jim posílej signály. Většina démonů načte nový kofigurák když dostane HUP nebo USR1. Jako bonus ti to bude lépe fungovat i když dostaneš dva http requesty najednou.
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    15.3.2012 17:08 Martin Matějek | skóre: 13 | blog: Flying_circus | Kladno
    Rozbalit Rozbalit vše Re: Python spouštění shellových skriptů
    Debianovský init skript pro dhcpd s parametrem restart nebo force-reload dhcpd zastaví, znovu spustí a navíc ještě před spuštěním zkontroluje konfigurační soubor, takže zůstanu u volání init skriptu. Ale díky moc za rady.

    PS: O zpracování http requestů se stará webserver (Python + CherryPy), takže to by neměl být problém.
    Don't judge me by the friends I keep. No, no, no. Judge me by the enemies I have slain!
    rADOn avatar 16.3.2012 13:44 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: Python spouštění shellových skriptů
    Koukám že dhcpd opravdu neumí načíst konfigurák na signál, takže se omlouvám za vnášení chaosu. Všichni ostatní démoni co znám to umí.
    "2^24 comments ought to be enough for anyone" -- CmdrTaco

    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.