LINUXSOFT.cz Přeskoč levou lištu
Uživatel: Heslo:  
   CZUKPL

> Tři způsoby jak provozovat Python s Lighttpd

Když sem začal přemýšlet o výměně PHP za Python, narazil sem na základní problém, a to jak dotyčnou Python webovku vlastně provozovat a tím pádem jí i psát. Nabízí se v podstatě několik možností, mod_python, CGI, FastCGI a aplikační server. O vybraných možnostech budu psát v následujícím článku, ale o mod_python se jen zmíním.

8.9.2009 00:00 | Ondřej Tůma | Články autora | přečteno 11102×

CGI

Stejně jako libovolná aplikace, i aplikace psané v Pythonu se mohou pouštět přes CGI. Python má pro tyto případy samozřejmě škálu základních  modulů, které ulehčují práci při psaní aplikace pro CGI. Režie serveru je pak zřejmá, aplikace se pouští pokaždé, když je volán Pythoní script z webového serveru. Co dotaz, to jedno spuštění v okamžiku požadavku. Pro malé nezatížené weby, či méně využívané aplikace dostačující. Z vyjmenovaných možností tedy nejnáročnější na systémové prostředky, ale nejméně náročné na konfiguraci.

lighttpd.conf: server.modules += ( "mod_cgi" ) static-file.exclude-extensions += (".py") cgi.assign = ( ".py" => "/usr/bin/python", ) cgi_app.py: import cgi def main(): cgi.test() return main()

mod_python

mod_python je modul do serveru Apache. Pokud přehlédnu, že bych rád provozoval aplikace psané v Pythonu i mimo prostředí serveru Apache, nejlépe na Lighttpd, jde o běžný způsob jak propojit Apache a Python. mod_python se v tomto podobá mod_php, tedy zpřístupňuje některé taje Apache jazyku (Pythonu snad o něco více), a práce vypadá tak, že při požadavku na Pythoní script, prostě server tento script spustí pomocí interpretru v mod_python. Apache tento modul inicializuje při svém spuštění a pak svůj proces forkuje do zásoby. Takže v okamžiku požadavku na takový script je již Python v paměti a jen spustí script (oproti PHP vlastně jen bytecode pokud existuje). Problém je že se mod_python spouští i když to není třeba, což je vlastně důvod, proč například na notebooku vyvíjím aplikace pod malým, nenáročným a výkonným Lighttpd. Tento způsob provozu je tedy o něco výkonnější než CGI, ale jen proto, že se interpretr jazyka spouští dopředu, bez ohledu na to, zda bude využit. Na rozdíl od PHP sem ale nenašel způsob jak například hostovat mod_python genericky, tj bez přidávání jednotlivých aplikací do konfiguračních souborů Apache, i když by to podle některých návodů snad mělo jít.

FastCGI

FastCGI je na tom výrazně lépe. V případě PHP se vlastně interpretr pustí a čeká v paměti, až mu webový server předhodí nějaký ten script ke zpracování. U Pythonu je ale situace o malinko jiná. Nenašel sem způsob, jak provozovat Python v režimu FastCGI stejně jako PHP (i když by to šlo vlastně naprogramovat:)), ale Python se k takovému použití staví čelem. Nejde tedy jen o puštěný interpretr jazyka, ale o celou aplikaci. Aplikace prostě běží v systému pořád, a obsluhuje požadavky webového serveru. Stejně jako u mod_python i zde je problém v případě nějakého mass-hostingu. Na serveru by pak \\\"zbytečně\\\" běželo třeba 1000 aplikací Pythonu současně, ale to je daň za rychlou odezvu \\\"aplikačního serveru\\\". Schválně sem uvedl slova aplikační server, protože v tomto případě jde už opravdu o aplikační server. V žebříčku efektivity řadím tento způsob na až druhé místo proto, že vyžaduje doinstalaci dalších modulů do Pythonu. A způsob provozu FastCGI aplikací v Pythonu je velmi nejednotný a přináší mnoho problémů při rozcházení.

lighttpd.conf: server.modules += ( "mod_fastcgi" ) server.error-handler-404 = "flup-fcgi.py" fastcgi.server = ( ".py" => ( "localhost" => ( "min-procs" => 1, "host" => "127.0.0.1", "port" => 8070 ) ) ) flup-fcgi.py: #!/usr/bin/env python from flup.server.fcgi import WSGIServer def app(environ, start_response): start_response('200 OK', [('Content-Type', 'text/html')]) yield '<h1>FastCGI Environment</h1>\n' yield '<table>\n' for k, v in sorted(environ.items()): yield '<tr><th>%s</th><td>%s</td></tr>\n' % (k, v) yield '</table>\n' WSGIServer(app, bindAddress=('127.0.0.1',8070),).run()

Aplikační (webový) server

Označení aplikační server je velmi nepřesné, protože to může být i FastCGI. V podstatě jsem ale měl na mysli provoz vlastního webového serveru, naprogramovaného v Pythonu za pomocí standardních modulů. Python nabízí předpřipravený malý webový server, který v podstatě může nahradit celý Lighttpd. Tento server ale neumí sám od sebe řešit mnoho problémů, které řeší opravdové webové servery jako jsou Lighttpd, Apache a další. Samozřejmě můžeme si naprogramovat celý webový server, otázka ale je, zda je to rozumný nápad. V tomto případě se hodí, když tento webový Python server, bude obsluhovat jen logiku aplikace a o zbytek se postará webový server před ním.

Použití je tedy jednoduché, prostě se webový server nakonfiguruje jako proxy server a ten některé požadavky přesměruje na něj. Na žebříčku efektivity dávám první místo, pro snadnost spuštění takového webového serveru a možná a o malinko menší zátěži než u FastCGI. Je ale třeba si uvědomit, že stejně jako i FastCGI, i zde bude každá aplikace v systému spuštěná, ať je využívána nebo ne, a bude čekat na požadavky webového \\\"proxy\\\" serveru před ní. Z hlediska bezpečnostního, je ale takovéto hostování bezpečnější, protože aplikační server může, a je to vhodné, běžet s právy uživatele serveru, nikoli s právy web serveru.

lighttpd.conf: $HTTP["url"] !~ ".(png|jpg|jpeg|css|html|htm)" { proxy.server = ( "" => ( ( "host" => "127.0.0.1", "port" => 8071 ) ) ) } web-test.py: #!/usr/bin/python from wsgiref.simple_server import make_server def simple_app(environ, start_response): status = '200 OK' headers = [('Content-type', 'text/html; charset=utf-8')] start_response(status, headers) ret = [("<tr><td>%s:</td><td>%s</td></tr>\n" % (key, value)).encode("utf-8") for key, value in environ.items()] return ['<h1>Pytho Web Server Test</h1>','<table>'] + ret + ['</table>'] httpd = make_server('', 8071, simple_app) httpd.serve_forever()

Závěrem

Nijak nechci hodnotit pozici Pythonu u webhostingových firem, i když je zatím velmi oslabená, a je to mima jiného i problematičností konfigurace. Python je ale přeci jen více nízkoúrovňový jazyk než PHP a dokáže si z ledasčem poradit, když to zvládne programátor. Uvedené možnosti nejsou zcela jistě jediné, a určitě existuje i mnoho dalších. Tyto jsou z mého pohledu rozumně schůdné, relativně dobře konfigurovatelné a ještě je mezi nimi na výběr.

Verze pro tisk

pridej.cz

 

DISKUZE

Nejsou žádné diskuzní příspěvky u dané položky.



Příspívat do diskuze mohou pouze registrovaní uživatelé.
> Vyhledávání software
> Vyhledávání článků

18.6.2018 0:43 /František Kučera

Červnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 21. 6. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát na téma: F-Droid, aneb svobodný software do vašeho mobilu. Kromě toho budou k vidění i vývojové desky HiFive1 se svobodným/otevřeným čipem RISC-V.


Přidat komentář

23.5.2018 20:55 /Ondřej Čečák
Od pátku 25.5. proběhne na Fakultě informačních technologií ČVUT v Praze openSUSE Conference. Můžete se těšit na spostu zajímavých přednášek, workshopů a také na Release Party nového openSUSE leap 15.0. V na stejném místě proběhne v sobotu 26.5. i seminář o bezpečnosti CryptoFest.
Přidat komentář

20.5.2018 17:45 /Redakce Linuxsoft.cz
Ve čtvrtek 31. května 2018 připravuje webový magazín BusinessIT ve spolupráci s Best Online Média s.r.o. pátý ročník odborné konference Firemní informační systémy 2018. Akce proběhne v kongresovém centru Vavruška (palác Charitas), Karlovo náměstí 5, Praha 2 (u metra Karlovo náměstí) od 9:00 hod. dopoledne do cca 15 hod. odpoledne. Konference je zaměřena na efektivní využití firemních informačních systémů a na to, jak plně využít jejich potenciál. Podrobnější informace na webových stránkách konfrence.
Přidat komentář

14.5.2018 7:28 /František Kučera
Květnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 17. 5. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát na téma: Audio – zvuk v GNU/Linuxu.
Přidat komentář

7.5.2018 16:20 /František Kučera
Na stránkách spolku OpenAlt vyšla fotoreportáž Pražské srazy 2017 dokumentující srazy za uplynulý rok. Květnový pražský sraz na téma audio se bude konat 17. 5. 2018 (místo a čas ještě upřesníme).
Přidat komentář

17.4.2018 0:46 /František Kučera
Dubnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 19. 4. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tématem tohoto srazu bude OpenStreetMap (OSM) aneb svobodné mapy.
Přidat komentář

16.3.2018 22:01 /František Kučera
Kulatý OpenAlt sraz v Praze oslavíme klasicky: u limonády a piva! Přijďte si posedět, dát si dobré jídlo a vybrat z mnoha piv do restaurace Kulový blesk, který najdete v centru Prahy nedaleko metra I. P. Pavlova na adrese Sokolská 13, Praha 2. Sraz se koná ve čtvrtek 22. března a začínáme v 18:00. Heslo: OpenAlt. Vezměte s sebou svoje hračky! Uvítáme, když si s sebou na sraz vezmete svoje oblíbené hračky. Jestli máte nějaký drobný projekt postavený na Arduinu, nějakou zajímavou elektronickou součástku, či třeba i pěkný úlovek z crowdfundingové akce, neváhejte. Oslníte ostatní a o zábavu bude postaráno.
Přidat komentář

13.2.2018 0:41 /František Kučera
Únorový pražský sraz OpenAltu se koná 15. 2. 2018 a tentokrát se vydáme na návštěvu do jednoho pražského datacentra. Sejdeme se v 17:50 v severovýchodní části nástupiště tramvajové zastávky Koh-I-Noor. Po exkurzi se přesuneme do restaurace U Pštrosa (Moskevská 49), kde probereme tradiční témata (svobodný software a hardware, DIY, CNC, SDR, 3D tisk…) a tentokrát bude k vidění i IoT brána od The Things Network.
Přidat komentář

   Více ...   Přidat zprávičku

> Poslední diskuze

20.2.2018 18:48 / Ivan Majer
portal

20.2.2018 15:57 / Jan Havel
Jak využíváte služby cloudu v podnikání?

16.1.2018 1:08 / Ivan Pittner
verejna ip od o2 ubuntu

15.1.2018 17:26 / Mira Harvalik
Re: Jak udělat HTML/Javascript swiping gallery do mobilu?

30.12.2017 20:16 / Michal Knoll
odmocnina

Více ...

ISSN 1801-3805 | Provozovatel: Pavel Kysilka, IČ: 72868490 (2003-2018) | mail at linuxsoft dot cz | Design: www.megadesign.cz | Textová verze