为了账号安全,请及时绑定邮箱和手机立即绑定

Django+uwsgi+nginx微信小程序环境搭建

标签:
Java

主要是在做一个车辆违章行为检测的项目,希望通过微信小程序能够扩大应用范围,同时在后端与服务器通信,拿到违章检测的结果。但因为从来没有开发过微信小程序,于是在网上看了很多教程,也踩了很多坑,在这里结合我的实际情况将整个过程记录下来:

整个配置是Django+uwsgi+nginx


1.域名问题的解决

(1)微信小程序必须有一个独立的域名,如www.123.com,将这个域名与后端服务器绑定后,前端通过urls域名与后端进行通信【注意:urls处在实际应用时只能是域名,不能是ip地址等】

(2)域名必须通过实名认证,并通过备案。注意备案需要大概10天左右的时间,所以如果时间紧张一定要提前开始备案!!提前开始备案!!提前开始备案!!我就是因为时间紧来不及备案,所以找师兄已经备案过的域名开了一个二级域名,同样可以使用~【不过不推荐哈,最好还是老老实实备案】

(3)微信小程序需要https证书,网络上有很多免费的证书网站,搜一下就可以,会生成一个密钥和证书文件。


2.选择后台服务器(注意一定要有外网ip!!!)

我一开始选用的是实验室的服务器,但发现配置起来难度太大,原因有一下几点

·实验室服务器root权限不容易得到,而nginx配置必须使用root权限

·实验室服务器的外网ip可能会限制外来通信的进入,对端口有很多限制。这个是我个人猜测,但觉得很有道理【笑哭】。

于是在经过一周艰苦的探索后,我甚至去淘宝搜了配置价格(要500RMB+...),然后作为一个贫民+码农,觉得用淘宝未免有点跌份儿(可能50RMB我就买了hhhhhh),于是果断弃实验室服务器,选择了腾讯云服务器,后来事实证明这个决定无比正确...

腾讯云服务器是 4核 8 GB 5Mbps,有公网IP。系统是Centos


3.安装配置Django

安装Django比较简单,参加这篇教程即可: Django安装【菜鸟教程】

我的Django项目名称为HelloWorld,路径是/root/dachuang/HelloWorld

注意在Django项目的settings.py文件中,Host加入你的域名,如下图所示:

# SECURITY WARNING: don't run with debug turned on in production!DEBUG = TrueALLOWED_HOSTS = ("你的域名",)

4.安装配置uwsgi

安装:通过pip install uwsgi便可安装,配置我采用的是配置文件的方法

配置:在Django项目的同级目录下新建uwsgi文件夹(路径为/root/dachuang/uwsgi),并在其中新建一个uwsgi.ini文件,其中内容如下图所示:

[uwsgi]
http-socket = :8001   #这个端口需要打开socket=/www/hello_uwsgi.sock   
#需要生成的sock文件,nginx会通过这个sock文件与django通信#注意这个socket文件要放在服务器的根目录下,不要是某个用户的文件夹下#否则以后会出现访问权限问题chdir = /root/dachuang/HelloWorld/#Django项目的路径【绝对路径】wsgi-file = HelloWorld/wsgi.py  
#Django项目中uwsgi.py的路径【相对于Django项目根路径】master = true processes = 4 
threads = 2  
daemonize = /root/dachuang/uwsgi/logs/uwsgi.log#日志文件,可以在其中查看相关错误信息pidfile = /root/dachuang/uwsgi/uwsgi.pid

启动uwsgi --ini uwsgi.ini

关闭所有uwsgi进程: killall -9 uwsgi


5.配置安装nginx

安装yum -y install nginx  
安装成功后会发现/etc/下会出现nginx文件夹

配置:进入nginx文件夹,新建一个配置文件夹,名为conf.d(可能已经存在)

在conf.d文件夹下,新建配置文件 ***.conf,如https.conf

upstream django {
    server 服务器的外网Ip:443; #443是https的默认端口}

server {
  listen  443 ssl;
  server_name 你的域名;
  ssl on;
  ssl_certificate /etc/nginx/conf.d/证书.pem; #证书的绝对路径
  ssl_certificate_key /etc/nginx/conf.d/密钥.key;#密钥的绝对路径
  client_max_body_size 50M;  #charset utf-8;
  access_log  /www/logs/https.access.log; #nginx 日志的路径
  error_log /www/logs/https.error.log;
  location / {
    uwsgi_pass      unix:///www/hello_uwsgi.sock;
     #这里是之前配置uwsgi时新建的socket文件
    include       /etc/nginx/uwsgi_params;  #这里需要!
    }
  location /media/ {#这里是指定django项目中存储静态文件的地址
      alias /root/dachuang/HelloWorld/media/;
  }
}

修改用户:注意还需要将nginx的使用用户改变为当前用户!在nginx.conf文件中

# nginx.conf# For more information on configuration, see:#   * Official English Documentation: http://nginx.org/en/docs/#   * Official Russian Documentation: http://nginx.org/ru/docs/user root; #这里这里这里!worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;

启动nginx

重新启动nginxreload -s nginx

强制关闭所有nginx进程pkill -9 nginx


6.启动所有部件,完成配置

先启动uwsgi,再启动Nginx。【注意一旦修改了django项目中文件,就需要重新启动uwsgi和nginx!!!]。


最后吐血总结一下我踩坑的经历,祝贺所有人成功啦~

1.nginx 需要root权限!!!
2.服务器有的端口是屏蔽外网的!
3.在服务器裸机更好配
4.注意socket文件,需要放到根目录下,这样才有访问权限
5.django  setting.py中记得添加Host6.每次修改django,都需要重新启动uwsgi,因为涉及到socket文件
7.将nginx 的用户改为root  (nginx.conf)



作者:飞翔的小瓜瓜
链接:https://www.jianshu.com/p/28cc6637ebac


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消