我配置的是Django + uwsgi + Nginx

说下思路,先进行模块化测试:

  Django:

    Django 下 第一个坑是sql版本低问题,原因用pip安装不正确,在网上查了下按这个文章重装下就好了

    https://blog.csdn.net/qq_39969226/article/details/92218635

    重新运行提示没有site-packages

    在 [uwsgi]文件下新增pythonpath = /usr/local/python3/lib/python3.7/site-packages 就可以了

    在Django目录下输入 Python manage.py runserver 0.0.0.0:8080

    在浏览器内输入:http://127.0.0.1:8002,检查django是否运行正常。

  uwsgi:

    在/etc/目录下新建uwsgi9090.ini,添加如下配置:

 1 [uwsgi]
2 #socket 为上线使用,http为直接作为服务器使用。
3 #socket = 0.0.0.0:8080 #ip和端口号可以改
4 http = 0.0.0.0:8080
5 #项目目录
6 chdir=/usr/local/python3/bin/OutoundManageemnt
7 module=OutoundManageemnt.wsgi
8 #虚拟环境目录
9 #home = home/ray/MxOnline/mxonlineEnv
10 master = true
11 processes=4
12 threads=2
13 # 下面的参数不一定要加
14 # pidfile=uwsgi.pid uwsgi.pid 和uwsgi.log会在启动uwsgi时自动生成在项目目录下。
15 # daemonize=uswgi.log
16 # max-requests=2000
17 # chmod-socket=664
18 # vacuum=true
19 pythonpath = /usr/local/python3/lib/python3.7/site-packages

uwsgi

    Linux下输入uwsgi --ini /etc/uwsgi9090.ini

    在浏览器内输入:http://127.0.0.1:8080,检查uwsgi是否运行正常。

  Nginx:

    这个坑太多,网上的配置版本也多,我试了好多个,下面配置是在我的环境下可以运行的

### 每个指令必须有分号结束,用#号注释, 注释部分为可选项,未注释的为必须的 ###

# main全局块:配置影响nginx全局的指令。一般有运行nginx服务器的用户组,nginx进程pid存放路径,日志存放路径,配置文件引入,允许生成worker process数等。
#user nginx nginx; #配置用户或者组,默认为nobody nobody。
worker_processes 1; #允许生成的进程数,默认为1, 最大为cpu核数或者cup核数的两倍 #制定日志路径,级别。这个设置可以放入全局块,http块,server块,级别以此为:debug|info|notice|warn|error|crit|alert|emerg
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info; #pid logs/nginx.pid; #指定nginx进程运行文件存放地址 #最大文件打开数(连接),可设置为系统优化后的ulimit -HSn的结果
#worker_rlimit_nofile 51200;
#cpu亲和力配置,让不同的进程使用不同的cpu
#worker_cpu_affinity 0001 0010 0100 1000 0001 00100100 1000; #2、events块:配置影响nginx服务器或与用户的网络连接。有每个进程的最大连接数,选取哪种事件驱动模型处理连接请求,是否允许同时接受多个网路连接,开启多个网络连接序列化等。
events {
#use epoll; #epoll是多路复用IO(I/O Multiplexing)中的一种方式,但是仅用于linux2.6以上内核,可以大大提高nginx的性能
#accept_mutex on; #设置网路连接序列化,防止惊群现象发生,默认为on
#multi_accept on; #设置一个进程是否同时接受多个网络连接,默认为off
worker_connections 1024; #单个后台worker process进程的最大并发链接数
} #3、http块:可以嵌套多个server(每个server为一个站点),配置代理,缓存,日志定义等绝大多数功能和第三方模块的配置。如文件引入,mime-type定义,日志自定义,是否使用sendfile传输文件,连接超时时间,单连接请求数等。
http {
include mime.types; #文件扩展名与类型映射表。来查看mime.types文件内容,我们发现其就是一个types结构,里面包含了各种浏览器能够识别的MIME类型以及对应类型的文件后缀名字
default_type application/octet-stream; #默认文件类型,默认为text/plain #log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"'; #access_log logs/access.log main; #自定义服务日志 sendfile on; #允许sendfile方式传输文件,默认为on,表示高效文件传输模式,可以在http块,server块,location块。
#sendfile_max_chunk 100k; #每个进程每次调用传输数量不能大于设定的值,默认为0,即不设上限。
#tcp_nopush on; #激活tcp_nopush参数可以允许把httpresponse header和文件的开始放在一个文件里发布,积极的作用是减少网络报文段的数量
# tcp_nodelay on; #激活tcp_nodelay,内核会等待将更多的字节组成一个数据包,从而提高I/O性能
#keepalive_timeout 0; #设置长连接超时时间,默认为75s,可以在http,server,location块。
keepalive_timeout 65; #gzip on;
#gzip_min_length 1k; #gzip on开启才有效,设置允许压缩的页面最小字节数,页面字节数从header头的Content-Length中获取。默认值是0,表示不管页面多大都进行压缩。建议设置成大于1K。如果小于1K可能会越压越大 #upstream表示负载服务器池,定义名字为backend_server的服务器池
# upstream myweb {
# server 118.24.241.124 [weight=1 max_fails=2 fail_timeout=30s];
# server 106.12.2.195:8081 [weight=1 max_fails=2 fail_timeout=30s];
# server 106.12.2.195:8082 [weight=1 max_fails=2 fail_timeout=30s];
# server 106.12.2.195:8083 [weight=1 max_fails=2 fail_timeout=30s];
# } #设置由 fail_timeout 定义的时间段内连接该主机的失败次数,以此来断定 fail_timeout 定义的时间段内该主机是否可用。默认情况下这个数值设置为 1。零值的话禁用这个数量的尝试。设置在指定时间内连接到主机的失败次数,超过该次数该主机被认为不可用。这里是在30s内尝试2次失败即认为主机不可用! #基于域名的虚拟主机
server {
listen 80; #端口号,
server_name 0.0.0.0:80; #域名 多个用空格隔开, 也可以是IP地址如
#root /home/wwwroot/qinser #站点根目录,可以是相对路径,也可以是绝对路径,此项目也可以放置的到 location /{ }里配置
#index index.php index.html index.htm; #设置默认页 此项目也可以放置的到 location /{ }里配置 #charset koi8-r; #access_log logs/host.access.log main; location / {
proxy_pass http://0.0.0.0:8080; #请求转向myweb定义的服务器列表, 用于负载均衡,如果开启了,那么此处自己的站点就不能访问了
root /usr/local/python3/bin/OutoundManageemnt;
index index index.html index.htm;
}
location /static {
# 路径必须和STATIC_ROOT一样
alias /data/front/static/;
}
#error_page 404 /404.html; # redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
} # proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
#location ~ \.php$ {
# proxy_pass http://127.0.0.1;
#} # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
# 支持PHP配置模块 #符合php扩展名的请求调度到fcgi server
location ~ \.php$ {
#root /home/wwwroot/qinser; #上面已经配置过了,这里就不用配置了
#fastcgi_pass 0.0.0.0:8080; #因为php-fpm启用的是9000端口,因此这里表示抛给本机的9000端口
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /usr/local/nginx/html$fastcgi_script_name;
include fastcgi_params;
}
}
#每个站点都需要配置一个server模块,为了方便管理,这里把每个站点的配置文件统一放入到./vhost/目录下,并统一使用 .conf为后缀。
include /usr/local/nginx/conf/vhost/*.conf;
}

    Nginx配置端口,启动端口,做负载,分配静态文件在转给uwsgi启动的端口,Nginx配置完成后,

    在Django项目下setting.py 文件中STATIC_ROOT = '/var/www/myApp/static/'这个路径要和Nginx上配置要对应

    在项目目录下迁移静态文件Python manage.py collectstatic

    参考了https://segmentfault.com/a/1190000016108576#articleHeader0

    https://www.lylinux.net/article/2019/8/5/58.html这两位前辈很多

    最后Nginx配置最好把转发地址注释掉,做排查,启动Nginx, /usr/local/webserver/nginx/sbin/nginx

    在浏览器内输入:http://127.0.0.1:8080,检查Nginx是否运行正常。

    再把uwsgi地址注释去掉,在运行Nginx上的服务器地址。

    

配置Nginx的坑及思路的更多相关文章

  1. 在CentOS/Windows下配置Nginx(以及踩坑)

    在CentOS/Windows下配置Nginx(以及踩坑) 1. 序言 因为这类文章网上比较多,实际操作起来也大同小异,所以我并不会着重于详细配置方面,而是将我配置时踩的坑写出来. 2. CentOS ...

  2. Ubuntu18.04下配置Nginx+RTMP服务器,实现点播/直播/录制功能

    2019.3.22更新 最新的nginx-1.15.9可与openssl1.1.1兼容了 以下原文: 这个东西我眼馋挺久了,最近终于试玩了一下,感觉很好玩,在搭建的过程在也遇到一些坑,这里总结一下 安 ...

  3. 分布式文件系统 - FastDFS 配置 Nginx 模块及上传测试

    也不说废话,直接干 上一篇 分布式文件系统 - FastDFS 在 CentOS 下配置安装部署 中安装了 FastDFS 后,并配置启动了 Tracker 和 Storage 服务,已经可以上传文件 ...

  4. 如何正确配置Nginx+PHP

    对很多人而言,配置Nginx+PHP无外乎就是搜索一篇教程,然后拷贝粘贴.听上去似乎也没什么问题,可惜实际上网络上很多资料本身年久失修,漏洞百出,如果大家不求甚解,一味的拷贝粘贴,早晚有一天会为此付出 ...

  5. [原创]Centos7 从零配置Nginx+PHP+MySql

    序言 这次玩次狠得.除了编译器使用yum安装,其他全部手动编译.哼~ 看似就Nginx.PHP.MySql三个东东,但是它们太尼玛依赖别人了. 没办法,想用它们就得老老实实给它们提供想要的东西. 首先 ...

  6. 在ubuntu上面配置nginx实现反向代理和负载均衡

    上一篇文章(http://www.cnblogs.com/chenxizhang/p/4684260.html),我做了一个实验,就是利用Visual Studio,基于Nancy框架,开发了一个自托 ...

  7. windows7配置Nginx+php+mysql教程

    windows7配置Nginx+php+mysql教程 最近在学习php,想把自己的学习经历记录下来,并写一些经验,仅供参考交流.此文适合那些刚刚接触php,想要学习并想要自己搭建Nginx+php+ ...

  8. deepin 15.3 安装配置nginx

    1.安装nginx sudo apt-get install nginx 2.配置nginx sudo gedit /etc/nginx/sites-enabled/default 找到:index ...

  9. 配置nginx+php

    一般这样配置 此时很多教程会教大家这样配置Nginx+PHP: server { listen 80; server_name foo.com; root /path; location / { in ...

随机推荐

  1. linux中在某个目录下多个文件中搜索关键字

    有四种方法: find 文件目录 -name '*.*' -exec grep 'xxx' {} + -n 或是 find 文件目录 -name '*.*' | xargs grep 'xxx' -n ...

  2. Codeforces 1368F - Lamps on a Circle (交互博弈)

    这题也太新颖了吧.. 交互博弈 以前一直以为交互只能出二分 题意:长度为n的环形灯 玩家有两种操作 结束游戏 或者选择k个灯点亮 每次这个k是玩家自己选的 玩家操作后让电脑操作 电脑选择一个最优的点x ...

  3. P3980 [NOI2008]志愿者招募 (费用流)

    题意:最多1000天 每天需要至少ai个工人施工 有10000种工人可以雇佣 每种工人可以工作si到ti天 雇佣一个的花费是ci 问怎样安排使得施工花费最少 思考:最直白的建模方式 就是每种工人可以和 ...

  4. 【uva 1153】Keep the Customer Satisfied(算法效率--贪心+优先队列)

    题意:有N个工作,已知每个工作需要的时间和截止时间.要求所有工作穿行完成,第一项任务开始的时间不早于时刻0.问最多能完成多少个工作.(N≤800000) 解法:贪心.可以模型化题目为:已知N个任务的长 ...

  5. 关于贪心算法的经典问题(算法效率 or 动态规划)

    如题,贪心算法隶属于提高算法效率的方法,也常与动态规划的思路相挂钩或一同出现.下面介绍几个经典贪心问题.(参考自刘汝佳著<算法竞赛入门经典>).P.S.下文皆是我一个字一个字敲出来的,绝对 ...

  6. Leetcode(28)-实现strStr()

    实现 strStr() 函数. 给定一个 haystack 字符串和一个 needle 字符串,在 haystack 字符串中找出 needle 字符串出现的第一个位置 (从0开始).如果不存在,则返 ...

  7. C++ part6

    C++源文件从文本到可执行文件经历的过程 references: 一个C++源文件从文本到可执行文件经历的过程 C++源文件从文本到可执行文件经历的过程 gcc程序编译的静态链接和动态链接 保留中间过 ...

  8. springboot项目打war包

    spring官方教程地址(包含打war包和打jar包的):https://docs.spring.io/spring-boot/docs/current/reference/htmlsingle/#b ...

  9. CSS & SASS & SCSS & less

    CSS & SASS & SCSS & less less vs scss https://github.com/vecerek/less2sass/wiki/Less-vs. ...

  10. flex layout & demos

    flex layout & demos https://codepen.io/xgqfrms/pen/jjLPKN https://css-tricks.com/snippets/css/a- ...