當前位置:首頁 » 操作系統 » djangolinux安裝

djangolinux安裝

發布時間: 2024-10-30 04:18:51

『壹』 django如何debug(2023年最新解答)

導讀:今天首席CTO筆記來給各位分享關於django如何debug的相關內容,如果能碰巧解決你現在面臨的問題,別忘了關注本站,現在開始吧!

Django部署在linux下,如何調試?

就正常的print,就可以在日誌裡面找到部署容器log裡面找到輸出。

求Django大神幫忙,如何才能調試出。

提示很清楚了,沒有settings模塊(settings可能是django.conf文件夾中的,也能是你項目的settings.py文件)首先要找到出錯的文件,可以截個錯誤圖?

求幫助pycharmdebugdjango

首先進去軟體,然後

file--settings--ProjectInterpreter

在這右邊會有你安裝的包。第一次應該是什麼都沒有的

然後--點擊最下面的,安裝pipsetuptools。安裝完成之後,點右上角的「+」號

在裡面搜索,你想要安裝的框架模塊然後就可以了

如何利用pycharm調試Django

雖然用的pycharm是付費的,但是自從發現它預置的終端列印unicode字元串會出現半個之後,我就開始回歸用終端調試了。

首先,用print。

然後,用importpprint;pprint.pprint(xxx)。

最後,用importpdb;pdb.set_trace(),加斷點,調試。

要調試一個用java寫的後端,django寫的前端的web應用應該怎麼調試

在以前,你選擇pythonweb架構會受制於可用的web伺服器,反之亦然。如果架構和伺服器可以協同工作,那你就走運了:

但你有可能面對(或者曾有過)下面的問題,當要把一個伺服器和一個架構結合起來是發現他們不是被設計成協同工作的:

基本上你只能用可以一起運行的而非你想要使用的。

那麼,你怎麼可以不修改伺服器和架構代碼而確保可以在多個架構下運行web伺服器呢?答案就是(或簡稱WSGI,讀作「wizgy」)。

WSGI允許開發者將選擇web框架和web伺服器分開。現在你可以混合匹配web伺服器和web框架,選擇一個適合你需要的配對。比如,你可以在Gunicorn或者Nginx/uWSGI或者Waitress上運行Django,Flask,或Pyramid。真正的混合匹配,得益於WSGI同時支持伺服器和架構:

WSGI是第一篇和這篇開頭又重復問道問題的答案。你的web伺服器必須具備WSGI介面,所有的現代PythonWeb框架都已具備WSGI介面,它讓你不對代碼作修改就能使伺服器和特點的web框架協同工作。

現在你知道WSGI由web伺服器支持,而web框架允許你選擇適合自己的配對,但它同樣對於伺服器和框架開發者提供便利使他們可以專注於自己偏愛的領域和專長而不至於相互牽制。其他語言也有類似介面:java有ServletAPI,Ruby有Rack。

說這么多了,你肯定在喊,給我看代碼!好吧,看看這個極簡的WSGI伺服器實現:

#TestedwithPython2.7.9,LinuxMacOSX

importsocket

importStringIO

importsys

classWSGIServer(object):

address_family=socket.AF_INET

socket_type=socket.SOCK_STREAM

request_queue_size=1

def__init__(self,server_address):

#Createalisteningsocket

self.listen_socket=listen_socket=socket.socket(

self.address_family,

self.socket_type

)

#Allowtoreusethesameaddress

listen_socket.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,1)

#Bind

listen_socket.bind(server_address)

#Activate

listen_socket.listen(self.request_queue_size)

#Getserverhostnameandport

host,port=self.listen_socket.getsockname()[:2]

self.server_name=socket.getfqdn(host)

self.server_port=port

#/Webapplication

self.headers_set=[]

defset_app(self,application):

self.application=application

defserve_forever(self):

listen_socket=self.listen_socket

whileTrue:

#Newclientconnection

self.client_connection,client_address=listen_socket.accept()

#.Then

#

self.handle_one_request()

defhandle_one_request(self):

self.request_data=request_data=self.client_connection.recv(1024)

#Printformattedrequestdataala'curl-v'

print(''.join(

'{line} '.format(line=line)

forlineinrequest_data.splitlines()

))

self.parse_request(request_data)

#

env=self.get_environ()

#It'

#

result=self.application(env,self.start_response)

#

self.finish_response(result)

defparse_request(self,text):

request_line=text.splitlines()[0]

request_line=request_line.rstrip(' ')

#

(self.request_method,#GET

self.path,#/hello

self.request_version#HTTP/1.1

)=request_line.split()

defget_environ(self):

env={}

#

#butit'

#

#

#RequiredWSGIvariables

env['wsgi.version']=(1,0)

env['wsgi.url_scheme']='http'

env['wsgi.input']=StringIO.StringIO(self.request_data)

env['wsgi.errors']=sys.stderr

env['wsgi.multithread']=False

env['wsgi.multiprocess']=False

env['wsgi.run_once']=False

#RequiredCGIvariables

env['REQUEST_METHOD']=self.request_method#GET

env['PATH_INFO']=self.path#/hello

env['SERVER_NAME']=self.server_name#localhost

env['SERVER_PORT']=str(self.server_port)#8888

returnenv

defstart_response(self,status,response_headers,exc_info=None):

#Addnecessaryserverheaders

server_headers=[

('Date','Tue,31Mar201512:54:48GMT'),

('Server','WSGIServer0.2'),

]

self.headers_set=[status,response_headers+server_headers]

#_responsemustreturn

#a'write'callable.Wesimplicity'ssakewe'llignorethatdetail

#fornow.

#returnself.finish_response

deffinish_response(self,result):

try:

status,response_headers=self.headers_set

response='HTTP/1.1{status} '.format(status=status)

forheaderinresponse_headers:

response+='{0}:{1} '.format(*header)

response+=' '

fordatainresult:

response+=data

#Printformattedresponsedataala'curl-v'

print(''.join(

'{line} '.format(line=line)

forlineinresponse.splitlines()

))

self.client_connection.sendall(response)

finally:

self.client_connection.close()

SERVER_ADDRESS=(HOST,PORT)='',8888

defmake_server(server_address,application):

server=WSGIServer(server_address)

server.set_app(application)

returnserver

if__name__=='__main__':

iflen(sys.argv)2:

sys.exit(':callable')

app_path=sys.argv[1]

mole,application=app_path.split(':')

mole=__import__(mole)

application=getattr(mole,application)

httpd=make_server(SERVER_ADDRESS,application)

print('WSGIServer:ServingHTTPonport{port}... '.format(port=PORT))

httpd.serve_forever()

這比第一篇的代碼長的多,但也足夠短(只有150行)來讓你理解而避免在細節里越陷越深。上面的伺服器可以做更多——可以運行你鍾愛web框架所寫基本的web應用,Pyramid,Flask,Django,或其他PythonWSGI框架.

不相信我?你自己試試看。保存上面的代碼為webserver2.py或者直接在Github下載。如果你不傳入任何參數它會提醒然後推出。

$pythonwebserver2.py

:callable

結語:以上就是首席CTO筆記為大家整理的關於django如何debug的全部內容了,感謝您花時間閱讀本站內容,希望對您有所幫助,更多關於django如何debug的相關內容別忘了在本站進行查找喔。

熱點內容
androidaudiousb 發布:2024-11-23 11:18:59 瀏覽:253
看巴士的解壓密碼 發布:2024-11-23 10:30:18 瀏覽:578
oracle的sql練習題 發布:2024-11-23 10:28:37 瀏覽:315
linux進程間同步 發布:2024-11-23 10:14:25 瀏覽:185
android朋友圈圖片 發布:2024-11-23 10:02:08 瀏覽:159
eclipsejar源碼亂碼 發布:2024-11-23 10:01:33 瀏覽:145
oracle導入資料庫數據 發布:2024-11-23 09:57:09 瀏覽:796
高訪問網址 發布:2024-11-23 09:53:02 瀏覽:520
android內置apk 發布:2024-11-23 09:46:18 瀏覽:320
郵箱伺服器搭建windows 發布:2024-11-23 09:44:46 瀏覽:560