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 02:00 | Pozvánky

Konference OpenAlt 2018 (dříve LinuxAlt a Openmobility) proběhne již o víkendu 3. a 4. listopadu na FIT VUT v Brně. Motto konference je "Otevřeným přístupem k otevřené společnosti". Připraveno je 8 tracků přednášek a workshopů. Pořadatelé připravili výběr toho nejzajímavějšího.

Ladislav Hagara | Komentářů: 0
včera 01:00 | IT novinky

Bylo vydáno RFC 8484 řešící posílání DNS dotazů a získávání DNS odpovědí přes protokol HTTPS (DoH, DNS over HTTPS). V aktuálních verzích Firefoxu je DoH ve výchozím nastavení zakázáno. Povolit jej lze v about:config změnou hodnoty network.trr.mode (Trusted Recursive Resolver). V srpnu zveřejnila Mozilla výsledky experimentu s DNS přes HTTPS ve Firefoxu Nightly.

Ladislav Hagara | Komentářů: 42
19.10. 13:00 | Komunita

Při prvním spuštění Ubuntu 18.04 LTS (Bionic Beaver) je spuštěn nástroj Ubuntu Report. Pokud uživatel souhlasí, jsou pomocí tohoto nástroje odeslány do Canonicalu informace o daném počítači (doba instalace, počet procesorů, rozlišení displeje, velikost paměti, časová zóna, ...). V červnu byly zveřejněny první statistiky. Podrobnější statistiky jsou nově k dispozici na samostatné stránce.

Ladislav Hagara | Komentářů: 13
19.10. 01:00 | Pozvánky

O víkendu probíhá v Košicích pravidelné setkání příznivců otevřených technologií OSS Víkend. Na programu je řada zajímavých přednášek a workshopů.

Ladislav Hagara | Komentářů: 0
19.10. 00:11 | Nová verze

Byla vydána nová verze 1.3 otevřeného, licenčními poplatky nezatíženého, univerzálního ztrátového formátu komprese zvuku Opus (Wikipedie) a jeho referenční implementace libopus. Vylepšena byla například detekce, zda se jedná o řeč nebo o hudbu. Přidána byla podpora prostorového zvuku (immersive audio) dle plánovaného RFC 8486. Podrobnosti a zvukové ukázky na demo stránce.

Ladislav Hagara | Komentářů: 0
18.10. 22:33 | Nová verze

Bylo vydáno Ubuntu 18.10 s kódovým názvem Cosmic Cuttlefish (Kosmická sépie). Ke stažení jsou Ubuntu Desktop a Server, Ubuntu Cloud Images, Ubuntu Netboot, Kubuntu, Lubuntu a Lubuntu Alternate, Ubuntu Budgie, Ubuntu Kylin, Ubuntu MATE, Ubuntu Studio a Xubuntu. Podrobnosti v poznámkách k vydání.

Ladislav Hagara | Komentářů: 3
18.10. 18:33 | Nová verze

Byl vydán PostgreSQL ve verzi 11.0. Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
18.10. 17:33 | IT novinky

Nadace Raspberry Pi představila na svém blogu Raspberry Pi TV HAT, tj. rozšíření jednodeskového počítače Raspberry Pi umožňující příjem televizního vysílání DVB-T a DVB-T2. Cena rozšíření je 21,50 $.

Ladislav Hagara | Komentářů: 12
18.10. 17:07 | Nová verze

Vychází OpenBSD 6.4. Z řady novinek namátkou: podpora dalších architektur (arm64 např. dostal z Linuxu vypůjčený ovladač radeondrm), hypervizor vmm podporuje i qcow2 disky a šablony, jádro dokáže automaticky přepínat mezi dostupnými bezdrátovými sítěmi, sítě pracují o něco efektivněji, z bezpečnosti „přísaha byla doplněna odhalením“ (pledge(2) lze vhodně doplnit pomocí unveil(2)), SMT je ve výchozím stavu vypnutý, ale lze jej zapnout. Syntaxe nastaveni OpenSMTPD se změnila. S vydáním vychází také nová verze LibreSSL - 2.8.2.

Daniel Čižinský | Komentářů: 6
17.10. 23:15 | IT novinky

Firma Raptor Computing Systems, která stojí také za pracovní stanicí Talos II, představila levnější desku Blackbird s podporou jednoho 4-/8jádrového CPU POWER9 Sforza a formátem microATX; bližší specifikace jsou ve wiki výrobce.

Fluttershy, yay! | Komentářů: 30
Přispíváte osobně k vývoji svobodného softwaru?
 (40%)
 (43%)
 (24%)
 (22%)
 (11%)
 (36%)
Celkem 279 hlasů
 Komentářů: 16, poslední dnes 03:42
Rozcestník

Dotaz: php7+apache exec nefunguje

1.9.2017 09:42 pou | skóre: 16
php7+apache exec nefunguje
Přečteno: 746×
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: 16
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: 28
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.
Řešení 1× (pou (tazatel))
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: 16
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: 16
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: 16
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: 16
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: 16
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.
Řešení 1× (pou (tazatel))
6.9.2017 22:28 pou | skóre: 16
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.