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 01:00 | Komunita

    Debian dnes slaví 32 let. Ian Murdock oznámil vydání "Debian Linux Release" 16. srpna 1993.

    Ladislav Hagara | Komentářů: 15
    15.8. 17:44 | IT novinky

    Policisté zadrželi odsouzeného drogového dealera Tomáše Jiřikovského, který daroval ministerstvu spravedlnosti za tehdejšího ministra Pavla Blažka (ODS) bitcoiny v miliardové hodnotě, a zajistili i darovanou kryproměnu. Zadržení Jiřikovského může být podle ministerstva důležité k rozuzlení kauzy, která vypukla koncem května a vedla ke konci Blažka. Zajištění daru podle úřadu potvrzuje závěry dříve publikovaných právních

    … více »
    Ladislav Hagara | Komentářů: 7
    15.8. 13:44 | IT novinky

    Administrativa amerického prezidenta Donalda Trumpa jedná o možném převzetí podílu ve výrobci čipů Intel. Agentuře Bloomberg to řekly zdroje obeznámené se situací. Akcie Intelu v reakci na tuto zprávu výrazně posílily. Trump minulý týden označil Tana za konfliktní osobu, a to kvůli jeho vazbám na čínské společnosti, čímž vyvolal nejistotu ohledně dlouholetého úsilí Intelu o obrat v hospodaření. Po pondělní schůzce však prezident o šéfovi Intelu hovořil příznivě.

    Ladislav Hagara | Komentářů: 3
    15.8. 05:44 | IT novinky

    Společnost Purism stojící za linuxovými telefony a počítači Librem má nově v nabídce postkvantový šifrátor Librem PQC Encryptor.

    Ladislav Hagara | Komentářů: 10
    14.8. 18:00 | Nová verze

    VirtualBox, tj. multiplatformní virtualizační software, byl vydán v nové verzi 7.2. Přehled novinek v Changelogu. Vypíchnou lze vylepšené GUI.

    Ladislav Hagara | Komentářů: 0
    14.8. 14:11 | IT novinky

    Eric Migicovsky, zakladatel společnosti Pebble, v lednu oznámil, že má v plánu spustit výrobu nových hodinek Pebble s již open source PebbleOS. V březnu spustil předprodej hodinek Pebble Time 2 (tenkrát ještě pod názvem Core Time 2) za 225 dolarů s dodáním v prosinci. Včera představil jejich konečný vzhled (YouTube).

    Ladislav Hagara | Komentářů: 29
    14.8. 12:44 | Zajímavý software

    Byla oznámena nativní podpora protokolu ACME (Automated Certificate Management Environment) ve webovém serveru a reverzní proxy NGINX. Modul nginx-acme je zatím v preview verzi.

    Ladislav Hagara | Komentářů: 1
    14.8. 12:22 | Nová verze

    Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 25.08. Přehled novinek i s náhledy a videi v oficiálním oznámení.

    Ladislav Hagara | Komentářů: 0
    13.8. 11:55 | IT novinky

    Společnost Perplexity AI působící v oblasti umělé inteligence (AI) podala nevyžádanou nabídku na převzetí webového prohlížeče Chrome internetové firmy Google za 34,5 miliardy dolarů (zhruba 723 miliard Kč). Informovala o tom včera agentura Reuters. Upozornila, že výše nabídky výrazně převyšuje hodnotu firmy Perplexity. Společnost Google se podle ní k nabídce zatím nevyjádřila.

    Ladislav Hagara | Komentářů: 5
    13.8. 04:33 | Bezpečnostní upozornění

    Intel vydal 34 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20250812 mikrokódů pro své procesory řešící 6 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 0
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (52%)
     (19%)
     (4%)
     (5%)
     (2%)
     (1%)
     (1%)
     (17%)
    Celkem 406 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    Rozcestník

    Dotaz: php7+apache exec nefunguje

    1.9.2017 09:42 pou | skóre: 18
    php7+apache exec nefunguje
    Přečteno: 832×
    Dobrý den,

    mám následující php skript:
    	$answer=exec("/usr/bin/touch /tmp/alfa", $list);
    	print_r($list);
    	print_r($answer);
    	echo "OK";
    
    jeden by řekl, že na tom nic není. Jenže po spuštění stránky (výpis je jen OK) se v /tmp soubor "alfa" nevytvoří.

    Pokud provedu spuštění skriptu ručně (php zkouska.php) vse je v pořádku a soubor v /tmp se vytvoří.

    Zkoušel jsem se přihlásit jako www-data (su www-data) a skript spustit, opět vše v pořádku (alfa se vytvořil).

    Jedná se o debian 9.1, php7, apache2 - s defaultním nastavením.

    Práva do /tmp jsou 777

    Děkuji za radu

    Řešení dotazu:


    Odpovědi

    1.9.2017 10:47 NN
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    V logu apache to vypada jak?
    1.9.2017 10:58 pou | skóre: 18
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    Nic zváštního (dle mě) :

    Hlášky po restartu apache2 + načtení stránky obsahující kód víše:

    error.log:

    [Fri Sep 01 10:54:41.097293 2017] [mpm_prefork:notice] [pid 4161] AH00169: caught SIGTERM, shutting down [Fri Sep 01 10:54:41.234504 2017] [mpm_prefork:notice] [pid 4911] AH00163: Apache/2.4.25 (Debian) configured -- resuming normal operations [Fri Sep 01 10:54:41.234619 2017] [core:notice] [pid 4911] AH00094: Command line: '/usr/sbin/apache2'

    access.log:

    ::1 - - [01/Sep/2017:10:55:58 +0200] "GET /www/xxx.php HTTP/1.1" 200 317 "-" "Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Firefox/52.0"

    Beda0 avatar 1.9.2017 11:36 Beda0 | skóre: 29
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    A má účet pod který běží apache přístup do /tmp? Stalo se mi, že php nemohl číst v /tmp soubor - musel jsem udělat sysmlink do /var/www/... -> v Ubuntu, na mém Archu to fungovalo.
    1.9.2017 12:24 Peter
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    S najvyssou pravdepodobnostou za to "moze" systemd (ktory kvoly php7 predpokladam asi mas) a on "presmerovava" /tmp do tusim niekde /var/tmp/nejake_uuid_alebo_co_konkretneho_demona. Nie som pri pc, tak si to nepamatam presne, ale skus to niekde tam hladat.
    1.9.2017 12:34 NN
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    Tomu nemuzu uverit..
    1.9.2017 12:43 M.
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    A už to začíná :-D
    1.9.2017 15:19 pou | skóre: 18
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    Ok tím by to mohlo být, zkusil jsem jiné úložiště s právy 777 a tam už to funguje.

    Zeptám se ještě na jednu věc, celé to dělám kvůli tomu, že mi nefunguje prográmek, který na jiných strojích (starší debian) funguje.

    Je to program napsany v Qt který se připojuje do sdílené paměti (QtSharedMemory).

    Celé spuštění v php pak vypadá následovně:

    $answer=exec("sudo -u my_user -S /usr/bin/var_viewer -c i1", $list);

    v /etc/sudoers pak mám záznam:

    www-data ALL=(ALL) NOPASSWD: /usr/bin/var_viewer

    Na ostatních (starších) systémech to běží - vypíše se obsah sdílené paměti. Na tomto problémovém PC se sdílená pamět nenajde (takto se to chovalo pokud jsem nebyl přepnuty na uživatele, kteý pamět vytvořil (sudo -u)).

    Nechápu proč to nyní nejde.... Nějaké napady?

    1.9.2017 15:23 pou | skóre: 18
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    Ještě jsem zapomněl dodat, že FUNGUJE

    přepnout se na uživatele www-data (su www-data)

    a zavolat:

    sudo -u pou -S /usr/bin/var_viewer -c i1

    vrátí bez problému vše tak jak očekávám.
    1.9.2017 19:39 Peter
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    To je take varenie z vody - ma apache nastavenu PATH tak aby "videl" aj /usr/sbin?

    Skus a hod to sem:
    exec("sudo -u my_user -S /usr/bin/var_viewer -c i1 1>/niekde_kde_vie_apache_zapisovat/vystup.log 2>/niekde_kde_vie_apache_zapisovat/chyba.log");
    
    1.9.2017 19:56 Peter
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    A mimochodom - si si isty, ze ten sudo prikaz je spravne? Parameter velke S je na zadanie hesla pokial ma pamat neklame.
    2.9.2017 11:20 pou | skóre: 18
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    Máte pravdu to "-S" je použito špatně, nicméně to funguje i takto špatně.

    Opravil jsem to. Stále však přetrvává situace, kdy ruční spuštění php skriptu funguje a pomocí apache2 nikoliv - respektive funguje ale nenalezne sdílenou pamět.

    FUNKČNÍ:

    su www-data

    cd /var/www/html/

    php xxx.php

    Přez Apache pokud zadám stránku xxx.php - nefunkční ( program v exec se spustí vrátí chybu, že sdílená pamět není inicializovana, což není pravda to dokazuje i ruční spuštění pod uživatelem www-data).

    2.9.2017 15:39 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    Jaký program? /usr/bin/touch? Nedokážu si představit, k čemu by touch potřeboval pracovat se sdílenou pamětí. Můžete jej prohnat nástrojem strace, abyste viděl, které volání selže.
    3.9.2017 10:38 pou | skóre: 18
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    Ne ten touch byl jen test zda je exec funkční. Jde mi o toto: komentar víše
    4.9.2017 19:23 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    Třeba systemd při startu apache překryje /dev/shm, takže žádná sdílená paměť není k dispozici.
    5.9.2017 19:11 pou | skóre: 18
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    Hmm to je možné, ale jak to zjistit? Zkoušel jsem googlit ale nic :-(
    5.9.2017 20:20 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    Zmiňovaným nástrojem strace. Asi vás budou zajímat systémová volání zmíněné v shm_overview(7) případně svipc(7). Nebo se můžete podívat, jestli z apache je vidět připojený souborový systém do /dev/shm nebo obsah souboru /proc/sysvipc/shm. Nebo můžete prozkoumat unit file pro apache jestli neobsahuje podezřelé volby jako PrivateDevices. Nebo se můžete podívat do zdrojových kódu oné aplikace, kdy vypisuje onu chybovou hlášku.
    6.9.2017 22:28 pou | skóre: 18
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    Děkuji za nakopnutí.

    Takže jsem pomocí strace zjistil ID sdílené paměti. Kouknul kde je uložená - byla v /tmp, a díky diskuzi na začátku jsem přesně věděl která bije. Stačilo tedy v unit file pro apache změnit, aby neodděloval /tmp adresář a vše nyní funguje tak jak má!

    Vyřešeno

    Děkuji všem za trpělivost a za náměty!!!
    2.9.2017 09:18 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: php7+apache exec nefunguje
    PHP jsem naposledy viděl před mnoha lety, ale podle dokumentace exec() používáte špatně. Nikde nekontrolujete návratový kód spuštěného programu (dělá se přes třetí argument funkce) a nikde nekontrolujete standardní chybový výstup programu (funkce exec() to neumí, PHP stojí za starou bačkoru, jedině tak přesměrovat stderr na stdout "/usr/bin/touch /tmp/alfa 2>&1"). Když nebudete kontrolovat chyby, tak se těžko můžete dozvědět, co se pokazilo.

    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.