abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 18:55 | IT novinky

    Dnešním dnem lze již také v Česku nakupovat na Google Store (telefony a sluchátka Google Pixel).

    Ladislav Hagara | Komentářů: 0
    dnes 18:33 | IT novinky

    Apple představil (keynote) iPad Pro s čipem Apple M4, předělaný iPad Air ve dvou velikostech a nový Apple Pencil Pro.

    Ladislav Hagara | Komentářů: 0
    dnes 17:11 | Nová verze

    Richard Biener oznámil vydání verze 14.1 (14.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 14. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.

    Ladislav Hagara | Komentářů: 0
    dnes 13:44 | Komunita

    Free Software Foundation zveřejnila ocenění Free Software Awards za rok 2023. Vybráni byli Bruno Haible za dlouhodobé příspěvky a správu knihovny Gnulib, nováček Nick Logozzo za front-end Parabolic pro yt-dlp a tým Mission logiciels libres francouzského státu za nasazování svobodného softwaru do praxe.

    Fluttershy, yay! | Komentářů: 0
    dnes 13:11 | IT novinky

    Před 10 lety Microsoft dokončil akvizici divize mobilních telefonů společnosti Nokia a pod značkou Microsoft Mobile ji zanedlouho pohřbil.

    Ladislav Hagara | Komentářů: 1
    včera 21:33 | Komunita

    Fedora 40 release party v Praze proběhne v pátek 17. května od 18:30 v prostorách společnosti Etnetera Core na adrese Jankovcova 1037/49, Praha 7. Součástí bude program kratších přednášek o novinkách ve Fedoře.

    Ladislav Hagara | Komentářů: 5
    včera 21:11 | IT novinky

    Stack Overflow se dohodl s OpenAI o zpřístupnění obsahu Stack Overflow pro vylepšení OpenAI AI modelů.

    Ladislav Hagara | Komentářů: 1
    včera 17:55 | Nová verze

    AlmaLinux byl vydán v nové stabilní verzi 9.4 (Mastodon, 𝕏). S kódovým názvem Seafoam Ocelot. Přehled novinek v příspěvku na blogu a v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 17:11 | IT novinky

    Před 50 lety, 5. května 1974 v žurnálu IEEE Transactions on Communications, Vint Cerf a Bob Kahn popsali protokol TCP (pdf).

    Ladislav Hagara | Komentářů: 0
    včera 13:44 | Zajímavý článek

    Bylo vydáno do češtiny přeložené číslo 717 týdeníku WeeklyOSM přinášející zprávy ze světa OpenStreetMap.

    Ladislav Hagara | Komentářů: 0
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (63%)
     (8%)
     (14%)
     (16%)
    Celkem 132 hlasů
     Komentářů: 8, poslední 4.5. 08:25
    Rozcestník

    Dotaz: je LAMP / PHP single thread?

    13.10.2019 22:38 marky
    je LAMP / PHP single thread?
    Přečteno: 414×
    Mám jedno CMS v PHP články formátujem cez markdown hľadal som nejaký šikovný konvertor pre PHP takže som vybral tento https://parsedown.org/ akurát mi v ňom nefungovali veci nad rámec štandardu markdown napríklad pridávanie CSS classov na elementy cez {.nejakatrieda}. Vyhodil som ho teda. A upravil som jednu aplikáciu ktorá obsahuje jeden vymakaný (nephpčkový) markdown parser MarkDig. Ten má kopu rozšírení, pridal som teda do appky nový controller MarkdownController a akciu ToHtml takže teraz ten markdown parser pouzivam z PHP aplikácie cez restové api.

    POST /markdown/to-html pošlem mu postom string v markdowne a dostanem json obsahujúci html.

    Lenže to má jednu drobnú nevýhodu: Pristupujem z jednej domény na inú. Celý preklad z MD do HTML trvá nejaky kratky cas mozno 500 ms. lenže na tých pol sekundy vlastne zamrzne celé PHP možno dokonca aj celý apache. Keď som mal otovrený debugger tej aplikácie (ktorá poskytovala to REST api) a dal som si breakpoint na miesto kde sa prekladá markdown do HTML a začal som ju krokovať tak spolu s ňou zamzla aj tá PHP aplikácia ktorá očakávala response z rest api.

    Neviem presne technické detaily ako funguje PHP (cakal som ine spravanie), ale mám dojem že PHP beží na len jednom vlákne. A a kým mi ne-php REST api nevráti response tak vlastne neni k dispozízii cela stranka? Správne to chápem? Takže asi by bolo dobré aby to neblokovalo hlavné vlákno. Keby som nebol v PHP tak by som to hodil buď na nové vlákno alebo spustil ako task, thread, TPL, thread pool, alebo pouzil backgroundworker alebo niečo podobnbé ale podporuje také niečo aj PHP? A rovnako aj posielanie emailov by malo prestat blokovat hlavne vlakno

    Odpovědi

    13.10.2019 23:26 M. Ponkrác | skóre: 3
    Rozbalit Rozbalit vše Re: je LAMP / PHP single thread?
    Nevím jak je to dnes, ale před řadou let fungoval Apache tak, že spustil houf procesů nebo threadů. A v tomto poolu pak honil HTTP requesty.

    Pár HTTP requestů tedy nemohlo zablokovat ani Apache, ani PHP, protože paralelně jich mohlo běžet větší množství.

    Jinak ano, PHP je single-thread. Ale protože je většinou spuštěn x-krát v poolu, tak jeden request by to neměl mít možnost zablokovat.

    Onlouvám se, pokud jsou mé informace již zastaralé, a dnes už se to dělá jinak. Už to pár let nesleduji jak se to vyvíjí.
    14.10.2019 00:23 Kit | skóre: 45 | Brno
    Rozbalit Rozbalit vše Re: je LAMP / PHP single thread?
    PHP běží jednovláknově, ale Apache vytvoří pro každý HTTP požadavek nové vlákno (resp. si ho vezme z poolu) a v každém z nich může běžet jiné PHP. K blokování tedy nedochází.

    PHP samo umí fungovat jako jednovláknový HTTP server, u kterého by k takovému problému mohlo dojít. Proto se používá jen pro testovací účely.

    BTW: 500 ms na zpracování Markdownu je hodne. To je v tom celá kniha?
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    14.10.2019 06:00 Matlák
    Rozbalit Rozbalit vše Re: je LAMP / PHP single thread?
    Keď som mal otovrený debugger tej aplikácie (ktorá poskytovala to REST api) a dal som si breakpoint na miesto kde sa prekladá markdown do HTML a začal som ju krokovať tak spolu s ňou zamzla aj tá PHP aplikácia ktorá očakávala response z rest api.

    Nevím jestli to chápu dostatečně ale tohle mi přijde logické - protože krokuješ překlad jehož výsledek pak vracíš, nemůžeš čekat že ta aplikace která response čeká ho nějakým zázrakem dostane s předstihem dřív, než ten překlad odkrokuješ nebo pustíš. To je tuším něco jako kauzalita.

    Pokud bys to pustil asynchronně (a že je to v PHP podporované velmi mizerně) tak bys a) musel stejně čekat než se ten proces dokončí abys mohl ukončit skript a vrátit výsledek a nebo b) bys výsledek zahodil a tvé REST API by nevrátilo nic.

    p.s. pomiňme teď fakt že vracet z REST služby HTML zabalené v JSON je oescapovaný hnus a že používat PHP v PHP přes REST je ještě větší hnus

    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.