欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python工程師面試題 與Python Web相關

 更新時間:2021年09月01日 11:51:33   作者:劉元濤  
這篇文章主要為大家分享了Python工程師面試題,面試題的內(nèi)容主要與Python Web相關,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文為大家分享的Python工程師面試題主要與Python Web相關,供大家參考,具體內(nèi)容如下

1、解釋一下 WSGI 和 FastCGI 的關系?

CGI全稱是“公共網(wǎng)關接口”(CommonGateway Interface),HTTP服務器與你的或其它機器上的程序進行“交談”的一種工具,其程序須運行在網(wǎng)絡服務器上?!GI可以用任何一種語言編寫,只要這種語言具有標準輸入、輸出和環(huán)境變量。如php,perl,tcl等。
FastCGI像是一個常駐(long-live)型的CGI,它可以一直執(zhí)行著,只要激活后,不會每次都要花費時間去fork一次(這是CGI最為人詬病的fork-and-execute模式)。它還支持分布式的運算, 即 FastCGI 程序可以在網(wǎng)站服務器以外的主機上執(zhí)行并且接受來自其它網(wǎng)站服務器來的請求。
FastCGI是語言無關的、可伸縮架構(gòu)的CGI開放擴展,其主要行為是將CGI解釋器進程保持在內(nèi)存中并因此獲得較高的性能。眾所周知,CGI解釋器的反復加載是CGI性能低下的主要原因,如果CGI解釋器保持在內(nèi)存中并接受FastCGI進程管理器調(diào)度,則可以提供良好的性能、伸縮性、Fail- Over特性等等。
WSGI的全稱為: PythonWeb Server Gateway Interface v1.0 (Python Web 服務器網(wǎng)關接口),
它是 Python 應用程序和 WEB 服務器之間的一種接口。
它的作用,類似于FCGI 或 FASTCGI 之類的協(xié)議的作用。
WSGI 的目標,是要建立一個簡單的普遍適用的服務器與 WEB 框架之間的接口。
Flup就是使用 Python 語言對 WSGI 的一種實現(xiàn),是可以用于 Python 的應用開發(fā)中的一種工具或者說是一種庫。
Spawn-fcgi是一個小程序,這個程序的作用是管理fast-cgi進程,那么管理wsgi進程也是沒有問題的,功能和php-fpm類似。
故,簡單地說,WSGI和FastCGI都是一種CGI,用于連接WEB服務器與應用程序,而WSGI專指Python應用程序。而flup是WSGI的一種實現(xiàn),Spawn-fcgi是用于管理flup進程的一個工具,可以啟動多個wsgi進程,并管理它們。

2、解釋一下 Django 和 Tornado 的關系、差別

Django源自一個在線新聞 Web站點,于 2005 年以開源的形式被釋放出來。
Django 框架的核心組件有:
用于創(chuàng)建模型的對象關系映射為最終用戶設計的完美管理界面一流的 URL 設計設計者友好的模板語言緩存系統(tǒng)等等
它鼓勵快速開發(fā),并遵循MVC設計。Django遵守 BSD版權(quán),最新發(fā)行版本是Django
1.4,于2012年03月23日發(fā)布.Django的主要目的是簡便、快速的開發(fā)數(shù)據(jù)庫驅(qū)動的網(wǎng)站。它強調(diào)代碼復用,多個組件可以很方便的以“插件”形式服務于整個框架,Django有許多功能強大的第三方插件,你甚至可以很方便的開發(fā)出自己的工具包。這使得Django具有很強的可擴展性。它還強調(diào)快速開發(fā)和DRY(Do Not RepeatYourself)原則。
Tornado是 FriendFeed使用的可擴展的非阻塞式 web 服務器及其相關工具的開源版本。這個 Web 框架看起來有些像 web.py 或者 Google 的 webapp,不過為了能有效利用非阻塞式服務器環(huán)境,這個 Web 框架還包含了一些相關的有用工具和優(yōu)化。
Tornado 和現(xiàn)在的主流 Web 服務器框架(包括大多數(shù)Python 的框架)有著明顯的區(qū)別:它是非阻塞式服務器,而且速度相當快。得利于其 非阻塞的方式和對epoll的運用,Tornado 每秒可以處理數(shù)以千計的連接,這意味著對于實時 Web服務來說,Tornado 是一個理想的 Web 框架。我們開發(fā)這個 Web 服務器的主要目的就是為了處理 FriendFeed 的實時功能 ——在 FriendFeed 的應用里每一個活動用戶都會保持著一個服務器連接。(關于如何擴容 服務器,以處理數(shù)以千計的客戶端的連接的問題。

3、解釋下django-debug-toolbar的使用

使用django開發(fā)站點時,可以使用django-debug-toolbar來進行調(diào)試。在settings.py中添加'debug_toolbar.middleware.DebugToolbarMiddleware'到項目的MIDDLEWARE_CLASSES 內(nèi)。

4、解釋下Django使用redis緩存服務器

為了能在Django中使用redis,還需要安裝redis for Django的插件。然后在Django的settings中配置了。現(xiàn)在連接和配置都已經(jīng)完成了,接下來是一個簡單的例子:

from django.conf import settings 
from django.core.cache import cache 
#read cache user id 
def read_from_cache(self, user_name): 
  key = 'user_id_of_'+user_name 
  value = cache.get(key) 
  if value == None: 
    data = None 
  else: 
    data = json.loads(value) 
  return data 
#write cache user id 
def write_to_cache(self, user_name): 
  key = 'user_id_of_'+user_name 
  cache.set(key, json.dumps(user_name), settings.NEVER_REDIS_TIMEOUT) 

5、如何進行Django單元測試

Django的單元測試使用python的unittest模塊,這個模塊使用基于類的方法來定義測試。類名為django.test.TestCase,繼承于python的unittest.TestCase。

from django.test import TestCase 
from myapp.models import Animal 
  
class AnimalTestCase(TestCase): 
  def setUp(self): 
    Animal.objects.create(name="lion", sound="roar") 
    Animal.objects.create(name="cat", sound="meow") 
  
  def test_animals_can_speak(self): 
    """Animals that can speak are correctly identified""" 
    lion = Animal.objects.get(name="lion") 
    cat = Animal.objects.get(name="cat") 
    self.assertEqual(lion.speak(), 'The lion says "roar"') 
    self.assertEqual(cat.speak(), 'The cat says "meow"') 

執(zhí)行目錄下所有的測試(所有的test*.py文件):運行測試的時候,測試程序會在所有以test開頭的文件中查找所有的test cases(inittest.TestCase的子類),自動建立測試集然后運行測試。

$ python manage.py test 

執(zhí)行animals項目下tests包里的測試:

$ python manage.py testanimals.tests 

執(zhí)行animals項目里的test測試:

$ python manage.py testanimals 

單獨執(zhí)行某個test case:

$ python manage.py testanimals.tests.AnimalTestCase 

單獨執(zhí)行某個測試方法:

$ python manage.py testanimals.tests.AnimalTestCase.test_animals_can_speak 

為測試文件提供路徑:

$ python manage.py testanimals/ 

通配測試文件名:

$ python manage.py test--pattern="tests_*.py" 

啟用warnings提醒:

$ python -Wall manage.py test 

6、解釋下Http協(xié)議

HTTP是一個屬于應用層的面向?qū)ο蟮膮f(xié)議,由于其簡捷、快速的方式,適用于分布式超媒體信息系統(tǒng)。
HTTP協(xié)議的主要特點可概括如下:

  • 1.支持客戶/服務器模式。
  • 2.簡單快速:客戶向服務器請求服務時,只需傳送請求方法和路徑。請求方法常用的有GET、HEAD、POST。每種方法規(guī)定了客戶與服務器聯(lián)系的類型不同。由于HTTP協(xié)議簡單,使得HTTP服務器的程序規(guī)模小,因而通信速度很快。
  • 3.靈活:HTTP允許傳輸任意類型的數(shù)據(jù)對象。正在傳輸?shù)念愋陀蒀ontent-Type加以標記。
  • 4.無連接:無連接的含義是限制每次連接只處理一個請求。服務器處理完客戶的請求,并收到客戶的應答后,即斷開連接。采用這種方式可以節(jié)省傳輸時間。
  • 5.無狀態(tài):HTTP協(xié)議是無狀態(tài)協(xié)議。無狀態(tài)是指協(xié)議對于事務處理沒有記憶能力。缺少狀態(tài)意味著如果后續(xù)處理需要前面的信息,則它必須重傳,這樣可能導致每次連接傳送的數(shù)據(jù)量增大。另一方面,在服務器不需要先前信息時它的應答就較快。

7、解釋下Http請求頭和常見響應狀態(tài)碼

Accept:指瀏覽器或其他客戶可以接愛的MIME文件格式??梢愿鶕?jù)它判斷并返回適當?shù)奈募袷健?br /> Accept-Charset:指出瀏覽器可以接受的字符編碼。英文瀏覽器的默認值是ISO-8859-1.
Accept-Language:指出瀏覽器可以接受的語言種類,如en或en-us,指英語。
Accept-Encoding:指出瀏覽器可以接受的編碼方式。編碼方式不同于文件格式,它是為了壓縮文件并加速文件傳遞速度。瀏覽器在接收到Web響應之后先解碼,然后再檢查文件格式。
Cache-Control:設置關于請求被代理服務器存儲的相關選項。一般用不到。
Connection:用來告訴服務器是否可以維持固定的HTTP連接。HTTP/1.1使用Keep-Alive為默認值,這樣,當瀏覽器需要多個文件時(比如一個HTML文件和相關的圖形文件),不需要每次都建立連接。
Content-Type:用來表名request的內(nèi)容類型??梢杂肏ttpServletRequest的getContentType()方法取得。
Cookie:瀏覽器用這個屬性向服務器發(fā)送Cookie。Cookie是在瀏覽器中寄存的小型數(shù)據(jù)體,它可以記載和服務器相關的用戶信息,也可以用來實現(xiàn)會話功能。

補充:

狀態(tài)代碼有三位數(shù)字組成,第一個數(shù)字定義了響應的類別,且有五種可能取值:
1xx:指示信息--表示請求已接收,繼續(xù)處理
2xx:成功--表示請求已被成功接收、理解、接受
3xx:重定向--要完成請求必須進行更進一步的操作
4xx:客戶端錯誤--請求有語法錯誤或請求無法實現(xiàn)
5xx:服務器端錯誤--服務器未能實現(xiàn)合法的請求
常見狀態(tài)代碼、狀態(tài)描述、說明:
200 OK     //客戶端請求成功
400 Bad Request  //客戶端請求有語法錯誤,不能被服務器所理解
401 Unauthorized //請求未經(jīng)授權(quán),這個狀態(tài)代碼必須和WWW-Authenticate報頭域一起使用
403 Forbidden  //服務器收到請求,但是拒絕提供服務
404 Not Found  //請求資源不存在,eg:輸入了錯誤的URL
500 Internal Server Error //服務器發(fā)生不可預期的錯誤
503 Server Unavailable  //服務器當前不能處理客戶端的請求,一段時間后可能恢復正常
eg:HTTP/1.1 200 OK (CRLF)

希望通過本文能夠幫助大家順順利利通過Python面試。

相關文章

  • Python利用Beautiful Soup模塊創(chuàng)建對象詳解

    Python利用Beautiful Soup模塊創(chuàng)建對象詳解

    這篇文章主要介紹了Python利用Beautiful Soup模塊創(chuàng)建對象的相關資料,文中介紹的非常詳細,相信對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。
    2017-03-03
  • Python?文檔解析lxml庫的使用詳解

    Python?文檔解析lxml庫的使用詳解

    lxml 是 Python 常用的文檔解析庫,能夠高效地解析 HTML/XML 文檔,常用于 Python 爬蟲,這篇文章主要介紹了Python?文檔解析:lxml庫的使用,需要的朋友可以參考下
    2022-09-09
  • 如何利用Python實現(xiàn)簡單C++程序范圍分析

    如何利用Python實現(xiàn)簡單C++程序范圍分析

    這篇文章主要介紹了如何利用Python實現(xiàn)簡單C++程序范圍分析,文章以舉例說明及過程實現(xiàn)思路的方式展開講解,具有一定的的參考價值,需要的小伙伴可以參考一下,希望對你有所幫助
    2022-02-02
  • python如何讀取100G的大文件實例探究

    python如何讀取100G的大文件實例探究

    這篇文章主要為大家介紹了python如何讀取100G的大文件實例探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2024-01-01
  • python的staticmethod與classmethod實現(xiàn)實例代碼

    python的staticmethod與classmethod實現(xiàn)實例代碼

    這篇文章主要介紹了python的staticmethod與classmethod實現(xiàn)實例代碼,分享了相關代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下
    2018-02-02
  • Flask框架通過Flask_login實現(xiàn)用戶登錄功能示例

    Flask框架通過Flask_login實現(xiàn)用戶登錄功能示例

    這篇文章主要介紹了Flask框架通過Flask_login實現(xiàn)用戶登錄功能,結(jié)合實例形式較為詳細的分析了flask框架使用Flask_login實現(xiàn)用戶登陸功能的具體操作步驟、相關實現(xiàn)技巧與操作注意事項,需要的朋友可以參考下
    2018-07-07
  • Python辦公自動化之將任意文件轉(zhuǎn)為PDF格式

    Python辦公自動化之將任意文件轉(zhuǎn)為PDF格式

    這種把某個文件轉(zhuǎn)為pdf枯燥無聊的工作,既沒有什么技術(shù)含量又累. 今天辰哥就教大家將任意文件批量轉(zhuǎn)為PDF,這里以日常辦公的word、excel、ppt為例,這三種格式的文件轉(zhuǎn)為PDF.需要的朋友可以參考下
    2021-06-06
  • Python爬蟲之App爬蟲視頻下載的實現(xiàn)

    Python爬蟲之App爬蟲視頻下載的實現(xiàn)

    這篇文章主要介紹了Python爬蟲之App爬蟲視頻下載的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • 詳解Python中RegEx在數(shù)據(jù)處理中的應用

    詳解Python中RegEx在數(shù)據(jù)處理中的應用

    正則表達式(Regular?Expressions,簡稱?RegEx)是一種強大的文本匹配和搜索工具,它在數(shù)據(jù)處理、文本解析和字符串操作中發(fā)揮著關鍵作用,下面就跟隨小編一起來了解一下RegEx的具體使用吧
    2024-01-01
  • python中List添加與刪除元素的幾種方法實例

    python中List添加與刪除元素的幾種方法實例

    列表基本上是?Python?中最常用的數(shù)據(jù)結(jié)構(gòu)之一了,并且刪除操作也是經(jīng)常使用的,下面這篇文章主要給大家介紹了關于python中List添加與刪除元素的相關資料,需要的朋友可以參考下
    2022-09-09

最新評論