Django Gunicorn Debug

2020-03-13 05:24发布

Initially I had a Django app with the included testing server. To debug this setup, I can just add a import pdb; pdb.set_trace() anywhere in the code and have a breaking point that throws me into an interactive debugger in Terminal (on command-line).

Recently I shifted to gunicorn to gain some perf benifits. How can I get a similar behavior while using this Gunicorn setup. I have tried by setting gunicorn settings with debug=True and daemon=False but it does not work.

Anyone has a solution to this?

5条回答
Rolldiameter
2楼-- · 2020-03-13 05:33

I managed now to use gunicron with djnago and ipdb.

run python -m ipdb manage.py run_gunicorn --debug -t 3600

I'm using Django 1.4 and gunicorn 0.16.1. then you can normally use the import ipdb; ipdb.set_trace() in the code. There is no need for the werkzeug library.

I'm trying to debug a facebook app, so I can't use the build in development server, because facebook tries to use SSL and the dev server just can't respond properly

While I was looking for a solution, I found a post pdb: Using the Python debugger in Django that suggests to run python -m pdb manage.py runserver all the time. Although this is not necessary with django's dev server, I decided to give it a try with gunicordn and ipdb and it worked.

查看更多
Juvenile、少年°
3楼-- · 2020-03-13 05:35

To run green unicorn in a reverse proxy configuration (under nginx) in a debugger / debug mode, enter the following settings in PyCharm's Run / Django / Edit configurations:

Of course, use whatever port (instead of 7777) you have configured your nginx to proxy to.

Screenshot

查看更多
戒情不戒烟
4楼-- · 2020-03-13 05:37

Ok I've recently stumbed upon similar problem. I wasn't able to apply @dudklein solution (I get I/O Errors while debugger was trying to take input - ipdb, pdb etc.)

I used remote python debbuger - winpdb and it's embedded debugging.

  1. install winpdb in Your virtualenv

    pip install winpdb
    
  2. import and run embedded debugger in Your code:

    import rpdb2
    rpdb2.start_embedded_debugger('pass')
    
  3. run gunicorn with --timeout argument

    gunicorn -t 3600 env:application
    
  4. run proper view using browser eg. http://127.0.0.1:8000/your-view/

  5. connect to embedded debugger using winpdb:

    winpdb -a /path/to/django/app/views.py
    

    It will prompt You for a password (use one You set in Your code, in my example it is 'pass') and run nice GUI with debugger.

  6. if You need tutorial for winpdb - here You are.

enter image description here

查看更多
Summer. ? 凉城
5楼-- · 2020-03-13 05:41

If you are able to launch gunicorn pointing at an application instance that is an instance of the DebuggedApplication class from the werkzeug library, you will be able to set break points using the werkzeug debugger with import ipdb; ipdb.set_trace() right in your browser.

import django.core.handlers.wsgi
from werkzeug.debug import DebuggedApplication

application = django.core.handlers.wsgi.WSGIHandler()
application = DebuggedApplication(application, evalex=True)

Make sure you install werkzeug library and ipdb of course. (pip install werkzeug and pip install ipdb)

查看更多
Evening l夕情丶
6楼-- · 2020-03-13 05:48

What I finally ended up doing is run python manage.py runserver <your_external_IP>:8000 when I want to use pdb.

So you need to have 2 different repositories in the same machine, one being LIVE production build (the one running gunicorn) and the other being the TEST build, the one I need to debug on where I use pdb. When things seem stable on TEST build I merge the TEST branch with LIVE branch. No development or changes happen on LIVE branch that way I avoid merge conflicts.

Hopefully this helps others who are addicted to pdb ;)

查看更多
登录 后发表回答