Django遇到的地雷,大家要注意


当前第2页 返回上一页

按照套路先安装pip3(如果直接安装pip是默认安装在python2中的):sudo apt-get install python3-pip,接着用pip安装Django:sudo pip3 install Django,最后用pip安装gunicorn:sudo pip3 install gunicorn (现在自动安装的版本是19.7.1)。环境安装完毕,切换到项目地址:cd /mnt/g/Django/hello,然后输入gunicorn hello.wsgi ,结果又出错了。OSError: [Errno 92] Protocol not available ,后来折腾卸载pip发现gunicorn 依赖于python-gunicorn(19.4.5),所以卸载了gunicorn(19.7.1):pip3 uninstall gunicorn ,然后安装了gunicorn(19.4.5):pip3 install gunicorn==19.4.5。然后命令gunicorn hello.wsgi 启动成功,没有出现Failed to find application,成功访问了127.0.0.1:8000/admin/ 。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

Lee@Kein:/mnt/g/Django/hello$ gunicorn hello.wsgi

[2017-07-16 15:16:25 +0800] [428] [INFO] Starting gunicorn 19.7.1Traceback (most recent call last):

  File "/usr/local/lib/python3.5/dist-packages/gunicorn/sock.py", line 44, in set_options

    sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEPORT, 1)

OSError: [Errno 92] Protocol not available

 

During handling of the above exception, another exception occurred:

 

Traceback (most recent call last):

  File "/usr/local/bin/gunicorn", line 11, in <module>sys.exit(run())

  File "/usr/local/lib/python3.5/dist-packages/gunicorn/app/wsgiapp.py", line 74, in run

    WSGIApplication("%(prog)s [OPTIONS] [APP_MODULE]").run()

  File "/usr/local/lib/python3.5/dist-packages/gunicorn/app/base.py", line 203, in run

    super(Application, self).run()

  File "/usr/local/lib/python3.5/dist-packages/gunicorn/app/base.py", line 72, in run

    Arbiter(self).run()

  File "/usr/local/lib/python3.5/dist-packages/gunicorn/arbiter.py", line 198, in run

    self.start()

  File "/usr/local/lib/python3.5/dist-packages/gunicorn/arbiter.py", line 157, in start

    self.LISTENERS = sock.create_sockets(self.cfg, self.log, fds)

  File "/usr/local/lib/python3.5/dist-packages/gunicorn/sock.py", line 180, in create_sockets

    sock = sock_type(addr, conf, log)

  File "/usr/local/lib/python3.5/dist-packages/gunicorn/sock.py", line 32, in __init__self.sock = self.set_options(sock, bound=bound)

  File "/usr/local/lib/python3.5/dist-packages/gunicorn/sock.py", line 89, in set_optionsreturn super(TCPSocket, self).set_options(sock, bound=bound)

  File "/usr/local/lib/python3.5/dist-packages/gunicorn/sock.py", line 46, in set_optionsif err[0] not in (errno.ENOPROTOOPT, errno.EINVAL):

TypeError: 'OSError' object is not subscriptable

OSError: [Errno 92] Protocol not available

1

2

3

4

5

Lee@Kein:/mnt/g/Django/hello$ gunicorn hello.wsgi

[2017-07-16 15:22:16 +0800] [470] [INFO] Starting gunicorn 19.4.5[2017-07-16 15:22:16 +0800] [470] [INFO] Listening at: http://127.0.0.1:8000 (470)

[2017-07-16 15:22:16 +0800] [470] [INFO] Using worker: sync

[2017-07-16 15:22:17 +0800] [473] [INFO] Booting worker with pid: 473Not Found: /static/admin/css/base.css

Not Found: /static/admin/css/login.css

3.虚拟机安装ubuntu系统,按照上面的套路,成功一次性启动了服务。也反过来思考win10上遇到的问题,成功把坑2填上了。

另外的一些问题是:

1.django 在Linux里面无法安装mysqlclient,这个时候安装PyMySQL,运行django项目会报错,只需要在一个文件加入一句话即可。

项目根目录下,找到对应app目录下的__init__.py,添加这一句:

import pymysql

pymysql.install_as_MySQLdb()

例子:

我的项目是eagle,在eagle下有manage.py这个文件,同时还有你自己的app,在这个app下有view.py这个文件。

2.nginx里面的static格式注意,使用location /static/ 和 location /static 加载时是不同的,要根据html中的格式符合。

3.搞了一天才了解的一个问题,大部分教程都是说开启uwsgi --ini eagle.ini链接uwsgi和django,然后开启nginx,但是,

如果你的eagle.ini中没有添加log路径,不会被后台运行,这个时候只能关闭uwsgi,

然后开启nginx,当你在浏览器输入地址后,发现502错误,查看/var/log/nginx/myweb_error.log,发现报错息 ,恭喜你入坑了。

原因是刚刚的uwsgi被关闭,你没有重启,网上的很多人都不知道这个原因。。。

坑爹啊,乱七八糟的回答。根据我的方式,有两种方法,一种是开启nginx后再运行

uwsgi --ini eagle.ini,一种是在eagle.ini添加log路径后会自动后台运行

以上就是Django遇到的地雷,大家要注意的详细内容,更多文章请关注木庄网络博客!!

返回前面的内容

相关阅读 >>

Python创建于英国吗

如何使用Python画曲线图

Python怎么将列表转为字符串

Python中break和continue语句的差别(实例解析)

Python实现的直接插入排序算法示例

django框架入门使用1.0

怎么利用Python输出星座

Python怎么把input的值储存到一个列表

mod在Python中怎么用

Python如何随机读取目录文件

更多相关阅读请进入《Python》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...

    正在狠努力加载,请稍候...