Flask ja Django on Pythonil põhinevad veebiarenduse raamistikud. Selles õpetuses võrreldakse üksikasjalikult Django vs Flask. Flask vs Node on ka lühidalt käsitletud:
See on alati olnud läbiv dilemma, kui tuleb küsimus raamistiku valimisest oma järgmise projekti jaoks. Iga paari kuu tagant näed uut tehnoloogiat ja raamistikku, mis ületab eelmise kasutatud raamistiku nõrkuse.
Raamistik on pigem nagu vaikiv kultuur ja konventsioonide kogum, mida peate järgima, et olla selles pidevalt muutuvas tehnoloogiamaailmas asjakohasem ja produktiivsem. Võrreldes sellega liigub veebiarendus palju kiiremini kui töölauaarendus.
Django vs Flask
Selles õpiobjektis joonistame üksikasjalikult välja Django ja Flaski võrdluse. Flask ja Django on Pythonil põhinevad veebiarenduse raamistikud. Paljud on liikumas kergete mikroraamistike suunas. Need raamistikud on agiilsed, paindlikud, väikesed ja aitavad arendada mikroteenuseid ja serverita rakendusi.
Arvestades NodeJS-i populaarsust, oleme ka Flask vs. Node jaotises Flask vs. Node esitanud Flaski ja Node'i võrdluse. Django ja Flask'i hindamine järgmiste omaduste alusel aitab teil valida ühe üle teise.
Vaikimisi administraator
Mõlemad raamistikud pakuvad bootstrapped admin-rakendust. Django puhul on see sisseehitatud ja tuleb vaikimisi paigaldusega kaasa. Flaski puhul tuleb aga paigaldada Flask-Appbuilder, et saada admin-liides.
Vahepeal ärge unustage luua Django puhul superuser ja Flaski puhul admin, et saaksite brauseri abil administraatori backendisse sisse logida.
Andmebaasid ja ORMS
Django tarnitakse vaikimisi sisseehitatud ORM-iga, mis toetab otseselt suhtlemist selliste RDBMS-idega nagu Oracle, MySQL, PostgreSQL, SQLite jne. See ORM toetab ka migratsioonide genereerimist ja haldamist. Sisseehitatud valideerimistega andmebaasimudelite loomine on suhteliselt mugavam.
Flask ei sea samuti ette ühtegi kindlat meetodit ja seda on võimalik kasutada koos erinevate laiendustega, mis toetavad sarnaseid funktsioone, nagu on kirjeldatud Django puhul. Oleme ühes sarja õpetustes toonud näiteid Flask-SQLAlchemy, Flask-Migrate, Flask-MongoEngine kohta.
Vaated ja marsruudid
Mõlemal raamistikul on mehhanismid meetodipõhiste ja klassipõhiste vaadete deklareerimiseks. Django puhul on marsruute ja vaateid mainitud eraldi failides. Samuti tuleb alati päringu objekt selgesõnaliselt üle anda.
Teisest küljest saame Flaskis kasutada dekoraatorit, et mainida marsruute vastavate käitlejate jaoks. Taotluse objekt Flaskis on globaalne ja on lihtsalt kättesaadav ilma selgesõnalise edasiandmiseta. Oleme ühes meie õpiobjektis üksikasjalikult käsitlenud vaadete ja marsruutide kasutamise kontseptsioone.
Vormid ja mallid
Django vormid on raamistikku sisseehitatud ja ei vaja paigaldamist. Vormid on rakenduste jaoks üsna olulised ja Djangos saab vorme edastada mallide siltidele ja neid saab mallides esitada. Flaski puhul peame aga kasutama Flask-WTF-i.
Vormide loomiseks kasutasime ka Flask-Appbuilderit. Lisaks saab WTF-Alembiciga genereerida HTML-vormid andmebaasi mudelite põhjal.
Mõlemad raamistikud toetavad Jinja2 templating, ja mõlemad toetavad teenindavad staatilisi faile sisseehitatud funktsioonidega, et luua ressursside URL-id ja on üsna levinud muster kõigis raamistikes tänapäeval.
Kuigi muutujate edastamiseks ja mallide esitamiseks nende konkreetsetes vaate meetodites on erinevad viisid, on mõlemal raamistikul sama süntaks muutujate kasutamiseks mallides.
Paindlikkus
Django on oma suuruse ja keerukuse tõttu vähem paindlik kui Flask. Flask on kergesti laiendatav suure hulga laienduste abil, mida ta toetab. Seetõttu vajab Flaski seadistamine rohkem aega ja vaeva, sest me peame hindama rohkem laiendusi.
Arendajatele antud vabadus toob teatud mõttes kaasa aeglasema arengu ja tarnimise. Teisalt järgib Django juba kehtestatud konventsioone ja järgib arhetüüpe, mis nõuavad vähem kõrvalekaldeid projekti eesmärkidest ja eesmärkidest.
Õpikõver
Django ja Flask'i õppimiseks kulub peaaegu sama palju aega. Flask'il on väiksem API; seetõttu võivad inimesed selle kiiremini valmis saada, mis puudutab põhiraamistikku. Sama keeruliseks muutub see, kui tegemist on selle laienduste kasutamisega. See võib varsti muutuda tülikaks.
Kuid just seetõttu, et kõik ei ole pakitud ühte paketti, on Flask'i raamistiku puhul lihtsam harjutada probleemide lahusust.
Soovitame õppida mustreid, mitte järgitavat süntaksit. Nii Djangol kui ka Flaskil on suurepärane dokumentatsioon. Seda saab funktsioonide arendamisel hõlpsasti jälgida.
Projekti suurus ja kestus
Kui töötate suurema projekti kallal, kus on suuremad meeskonnad, on parem kasutada ära Django küpsust ja ulatuslikku kaasajate toetust. Kui teie projekt on väiksem ja vajab vähem arendajaid, on parem valida Flask.
Lisaks, kui teie projekt kestab kaua, siis on Django õige valik; vastasel juhul võite valida Flask.
Rakenduse tüüp
Varem peeti Djangot õigeks valikuks, kui oli vaja täisväärtuslikke ettevõtte veebirakendusi. Kuid tänapäeval on Flask sama küps ja võib samades tingimustes hästi toimida.
Kuid arendajad valivad Flaski pigem väikeste või staatiliste veebisaitide arendamiseks või RESTful API veebiteenuste kiireks pakkumiseks.
Arendaja värbamine
Kvalifitseeritud ressursside olemasolu kasutatava raamistiku konventsioonis tasub end ära. Võite oodata kiiremat arendamist, kiiremat testimist, kiiremat tarnimist ja kiiremat probleemide parandamist.
Flaski puhul on üsna lihtne leida uusi arendajaid. Django puhul on aga keeruline leida kvalifitseeritud ressursse. Django arendajaid ei ole palju valmis tööle võtma. Lisaks on Django raamistik üsna vana ja seetõttu on enamiku uute töötajate palkamine kallis võrreldes Flaski raamistiku oskustega.
Uued tehnikumi lõpetajad valivad ka kerged raamistikud nagu Flask, sest tööstuse suundumused on lahtiseotud mikroteenustega rakenduste loomise poole või tehnoloogia, mis toetab serverless rakendamise loomist. Javascript on laialdaselt kasutusel koos raamistike, mis on lihtsamini kasutatavad ja populaarsemad.
Avatud lähtekood
Nii Flask kui ka Django on avatud lähtekoodiga projektid. Django leiate aadressil //github.com/django/django/django ja Flask aadressil //github.com/pallets/flask. Neid projekte vaadates on Django toetajate arv üsna suurem kui Flaski toetajate arv.
Seetõttu võime oodata rohkem ja kiiremat tuge, kui meil on mõned probleemid ja päringud, mis vajavad lahendamist. Vastupidiselt tüüpilistele oletustele on Flask projekti kasutajate arv suurem kui Django oma.
Üks Flaskiga seotud puudutav asjaolu on see, et konkreetse ülesande jaoks ei pruugi olla stabiilset laiendust. Seetõttu jääb parima välja filtreerimise töö laienduse kasutajale.
Näiteks, me kasutasime Flask-Twitter-oembedderit, et töötada Twitteri API-ga eelmises õpetuses, kuid sellel laiendusel oli mõningaid probleeme, mille tõttu pidime Flask-Cache'i asemel kasutama Flask-Caching'i.
Me pidime isegi lisama kohandatud paigaldusavalduse Flask-twitter-oembedderi paigaldamiseks meie uuendatud Githubi repost, selle asemel, et seda projekti requrements.txt failis mainida.
Sage hooldus on tüüpiline väljakutse, millega avatud lähtekoodiga projekti puhul silmitsi seisate. Avatud lähtekoodiga projekti tugi ja haldamine on tavaliselt seotud tasuliste teenustega. Te võite olla sunnitud kaua ootama, et projekti toetajad mõne probleemi parandaksid.
Tulemuslikkus
Flask raamistik on kergem kui Django ja toimib paremini, kusjuures erinevused on tühised, eriti kui arvestada I/O operatsioone.
Vaadake allpool toodud võrdlusi. Taotluste arvu suurenemise korral jääb Flaski jõudlus peaaegu samaks. Django võtab aga rohkem aega mallide renderdamiseks pärast ORM-i abil andmete kättesaamist.
Python Flask Vs Django: Tabulatiivne võrdlus
# | Omadused | Django | Kolb |
---|---|---|---|
1 | Vaikimisi administraator | Sisseehitatud Admin Backend | Installige Flask-Appbuilder |
2 | Vaikimisi administraatori lubamine | Veenduge, et settings.py failis eemaldate admini paigaldatud rakenduse kommentaarid. ... # Taotluse määratlus INSTALLED_APPS = [ "veebisait", 'django.contrib.admin', # muu kood ] ... | Impordi AppBuilder ja SQLA flask_appbuilderist, initsialiseeri kõigepealt DB ja seejärel Appbuilder. from flask import Flask from flask_appbuilder import AppBuilder, SQLA app=Flask(__name__) db = SQLA(app)appbuilder=AppBuilder(app, db.session) |
3 | Loo administraatori kasutaja | python manage.py createsuperuser | flask fab create-admin |
4 | Andmebaasid ja ORMS | Sisseehitatud ORM RDBMS-i jaoks Kasutage Django-nonrel NoSQL backendide jaoks | Installige Flask-SQLAlchemy NoSQL-spetsiifiline Flask laiendus nagu Flask-MongoEngine |
5 | Vaated ja marsruudid | URLConf failis urls.py from django.urls import path alates .import views urlpatterns = [ path('/path', views.handler_method), # muud urlid ja käitlejad ] | Kasutage @app.route("/path") kaunistajat Views'ile, et kaardistada marsruut funktsiooniga. @app.route("/path") def handler_method(): # muu kood edasise loogikaga |
6 | Renderdamise mallid | Vaadetes from django.shortcuts import render def example_view(request): tempvar="value_for_template" return render( taotlus, 'demo.html', {'tempvar':tempvar} ) | Vaadetes from . import app from flask import request from flask import render_template @app.route("/path") def demo(): tempvar="value_for_template" return render_template( "demo.html", temp_var=temp_var ) |
7 | Muutuv interpolatsioon mallides | Templates/demo.html {{ tempvar }} | Templates/demo.html {{ tempvar }} |
8 | Paindlikkus | Vähem paindlik | Paindlikumad |
9 | Disainiotsused | Vähem projekteerimisotsuseid koos arendajatega. | Rohkem vabadust arendajatele. |
10 | Projekti kõrvalekaldumine | Vähem kõrvalekaldumine projekti eesmärkidest. | Rohkem kõrvalekaldeid tänu arendajatele antud vabadusele. |
11 | Koodibaasi suurus | Suurem koodibaas | Väiksem koodibaas |
12 | APIde arv | Rohkem APIsid | Vähem APIsid |
13 | Rakenduse tüüp | Täielikud veebirakendused | Väiksemad rakendused / mikroteenused |
14 | RESTful rakendused | Django REST raamistik RESTful rakenduste jaoks. | Kasutage järgmisi laiendusi RESTful rakenduste jaoks. Flask-RESTful Flask-RESTX Ühendus |
15 | Tulemuslikkus | Aeglane jõudlus, kui taotluste arv on suur. | Järjepidev jõudlus kogu aeg. |
16 | Avatud lähtekoodiga panus | Rohkem Forks, Watches ja Commits. | Väiksem arv Forks, Watches ja Commits. |
17 | Arendajad | Nõuab kogenud arendajaid ja neid ei ole lihtne värvata. | Enamik arendajaid on vähem kogenud ja neid leidub piisaval arvul. |
Flask Vs Node
Veebiarenduse korstnaga seoses selgub, et veebi jaoks arendamine nõuab erinevate tehnoloogiate ühendamist. Veebirakendus tuleb jagada frontendiks ja backendiks. Rakenduse frontend osa on kõige parem arendada tehnoloogiatega, mis töötavad brauseris, näiteks JavaScript, HTML ja CSS.
Üldiselt on backend arendatud serveripoolsetes keeltes, mis sobivad serveripoolseks kasutamiseks ja võivad vajaduse korral suhelda aluseks oleva operatsioonisüsteemi, ühendatud andmebaaside või võrguga.
JavaScriptil põhinev raamistik nimega NodeJS muutis aga eespool esitatud seisukohta ja võimaldas arendajatele järjepidevust ja ühtsust veebirakenduste esi- ja tagakülje arendamisel. Arendajad said arendada tagakülje jaoks JavaScriptiga.
Selles Flask vs Node osas võrdleme Flaski, mis on Pythoni programmeerimiskeelel põhinev raamistik, Node'iga, mis põhineb Chrome'i JavaScripti runtime'il erinevatel kriteeriumidel, nagu arhitektuur, kiirus, kogukonna toetus jne.
# | Kriteeriumid | Kolb | Sõlme |
---|---|---|---|
1 | Keele tööaeg | Python | Chrome'i V8 JavaScript mootor |
2 | Arhitektuur | Mitteblokeeriv I/O nõuab mitteblokeerivate veebiserverite, näiteks gunicorn, kasutamist. Mikroraamistiku (back end) kategooria. | Pakub loomupäraselt mitteblokeerivat I/O-d. Fullstack kategooria |
3 | Pakettide haldur | pip | npm |
4 | Kiirus | Aeglasem, sest eraldi Pythoni interpretaator on aeglasem. | Kiirem tänu Just-In-Time kompilaatorile. |
5 | Avatud lähtekood | Jah | Jah |
6 | Ühenduse toetus | Githubis 2.3 K Kellad 51,4 K Tähed 13,7 K Kahvlid | Githubis 2.9 K Kellad 71,9 K Tähed 17,6 K Kahvlid |
7 | Vigade kõrvaldamine | Lihtsam tõrje Pythoni tõrjevahendiga ilma sõltuvusteta. | Nõuab rohkem vaeva. Lihtsam arendus IDEga koos Bluebird / Promise Libraryga. |
8 | Hooldus | Madal hoolduskoormus | Kõrgemad hoolduskulud |
9 | Reaalajas rakendused | Iseenesest ei sobi. Siiski võib see töötada koos socket.io'ga reaalajas kasutamise korral. Kasutage Flask-socketio laiendust. | Sobib tänu sündmusepõhisele arhitektuurile ja voogesituse moodulitele. Iseenesest asünkroonne. |
10 | Raamatukogud | Küpsem ja stabiilsem. | Vähem küps ja stabiilne, kuid aktiivse arenduse ja parandatud versioonide raames. |
11 | Kood Kvaliteet | See on loodud ainult tagumise osa jaoks. | See on mõnikord ohus, sest uued esipoole arendajad lähevad üle backendile. |
12 | Arendustiimi koosseis | Meeskonnad koosnevad tavaliselt back end arendajatest ja front end arendajatest. Kontseptsioonid on eraldi. | Arendajad saavad vahetada rolle ja töötada nii esi- kui ka tagakülje jaoks. |
13 | Integratsioon olemasoleva süsteemi ja rakendustega | Lihtsam integreerida teiste olemasolevate pärandrakendustega, kasutades Pythoni ökosüsteemi masinõppe ja suurandmete rakenduste jaoks. | Üsna uus ja nõuab kohandatud või uute raamatukogude loomist teiste olemasolevate rakendustega integreerimiseks. |
Korduma kippuvad küsimused
K #1) Mida ma peaksin kõigepealt õppima, kas Django või Flask?
Vastus: Kõigepealt on parem kasutada Flask'i. Kui olete omandanud pisut kogemusi veebiarenduses, võite võtta kasutusele Django. Django eeldab, et te juba teate, kuidas veebirakendused töötavad, ja ta hoolitseb suurema osa funktsionaalsuse eest ise.
K #2) Kas Flask või Django on parem?
Vastus: Nii Flask kui ka Django on suurepärased ja sobivad oma otstarbeks. Djangot kasutatakse silmapaistvamate ettevõtte mastaabis rakenduste loomiseks. Flaski kasutatakse staatiliste ja väiksemate rakenduste loomiseks. Flask sobib ka prototüüpimiseks. Flaski laienduste abil saame aga luua ka suuri rakendusi.
K #3) Millised ettevõtted kasutavad Flaski?
Vastus: Mõned ettevõtted, kes kasutavad Flaski, on Reddit, Mailgun, Netflix, Airbnb jne.
K #4) Millised saidid kasutavad Djangot?
Vastus: Mõned Djangot kasutavad näiteks Instagram, Spotify, YouTube, Dropbox, Bitbucket, Eventbrite jne.
Kokkuvõte
Me ei tohiks tegelikult pikalt ühe raamistiku külge kinnistuda. Me peaksime olema valmis õppima uusi tehnoloogiakomplekte ja võtma vastu sealse trendi stäkke. Mõned meist tahavad võrdlemisi out of the box, akut sisaldavaid lähenemisviise jäikade väljalaske tsüklitega, säilitades tihedamat tagasiühilduvust jne.
Kui arvate, et kuulute pigem sellesse gruppi, siis peate valima Django. Samas on uskumatu käia kaasas ka Flask raamistiku uute funktsioonide ja paindlikkusega. Kui soovite säilitada järjepidevust front- ja backend vahel, siis võite valida täieliku raamistiku, näiteks NodeJS.
Raamistiku valimine on pigem valik, mis sõltub kontekstist ja probleemidest, mida püüame lahendada. Raamistiku valimine on alati raske. Loodame, et oleme selles õpetuses esitanud olulised ülevaatepunktid ja see aitab teil ühe raamistiku lõplikul valikul. Soovitame siiski õppida mõlemad raamistikud.
Lihtsam on alustada Flaskiga ja seejärel liikuda edasi Django juurde, kui olete omandanud mõningaid kogemusi veebiarenduses. Kui mingil põhjusel on teie arendustegevuses vaja kasutada JavaScripti, siis võite jätkata NodeJSiga.