1、先下载 uwsgi

指定豆瓣源下载

pip install -i https://pypi.douban.com/simple uwsgi

2、查看你的uwsgi基于那个python解释器运行的

uwsgi --python-version

运行简单的uWSGI

先建立一个测试的文件

eg:  test_uwsgi.py

   def application(env, start_response):
start_response('200 OK', [('Content-Type','text/html')])
return [b"Hello World"] # python3
return ["Hello World"] # python2 然后运行你的文件:
uwsgi --http :8000 --wsgi-file +文件名 uwsgi --http :8000 --wsgi-file test_uesgi.py

这个时候就可以看到我们的uwsgi已经启动了的

这个时候我们访问的时候  就可以通过8000端口看到 我们测试文件的内容

上面是通过追加file来访问文件,我们可以通过追加model 来访问文件夹(就是我们的python程序)

uwsgi 启动命令

uwsgi启动文件
uwsgi --http : --wsgi-file |文件名 uwsgi启动文件夹(其实就是我们的python程序) uwsgi --http : --wsgi-module +项目名字 wsgi.py

首先 进入我们的django程序中  创建一个app:django-admin startapp  +app名字

eg:

  我们进入我们django项目下的url中写上响应信息

  

然后退出保存

然后 切换到上一级目录  就是切换到uwsgi.py和url.py保存的上一级别

 然后使用uwsgi命令启动(切记这个时候我们使用的是http请求链接的下面与nginx的结合的时候就是socket链接了)

uwsgi --htpp :启动端口 --module +项目.wsgi    # 指定其项目下的wsgi.py文件启动

uwsgi --http : --module mysite15.wsgi

可以后面加上参数 --py-autoreload = 1 自动加载 就相当于我们的denug = True 模式 修改完之后自动生效
uwsgi --http :8088 --module mysite15.wsgi --py-autoreload=1  

eg: 这是一个启动的额命令并且后面是指向的uwsgi的日志信息
  /data/server/pyenv/easyops/bin/uwsgi -s :9090 -p 2 -d       /data/logs/uwsgi/easyops/uwsgi.log -w index --py-autoreload=1

nginx + uwsgi+django:

静态文件的丢失:

然后下面我们来看看我们的admin界面

访问之后就是这样的了  没有样式了 ,这说明uwsgi是不会杜读取我们的静态界面的 就是我们的样式

第一种使用命令方式:

 然后我们通过nginx来分配寻找静态资源

先说一种 我们可以直接通过nginx来直接分发到我们的 项目上的,运用ngin的proxy_pass 参数

django的静态文件和nginx的配置:

使用nginx和uwsgi结合的配置信息

首先进入nginx的conf目录中看到很重要的自带的配置文件:uwsgi_params 这个文件就是专门做nginx和uwsgi结合的

然后进入nginx.conf中进行配置  在http中的server下进行配置

如果我们创建的 查找静态资源的路径没有的话就需要去创建一个

然后进入我们的django程序中的setting中把我们刚才指定nginx寻找静态文件的目录给告诉django程序 然后把它的静态文件给那个文件夹 nginx就能找到了

要在settings加上一个  :STATIC_ROOT= nginx指定寻找静态文件的目录

mysite/settings.py

STATIC_ROOT='/opt/nginx1-12/static'
STATIC_URL = '/static/'
STATICFILES_DIRS=[
os.path.join(BASE_DIR,"static"),
]

上述的参数STATIC_ROOT用在哪?

通过python manage.py collectstatic 收集所有你使用的静态文件保存到STATIC_ROOT!

STATIC_ROOT 文件夹 是用来将所有STATICFILES_DIRS中所有文件夹中的文件,以及各app中static中的文件都复制过来
# 把这些文件放到一起是为了用nginx等部署的时候更方便

mysite/settings.py

STATIC_ROOT='/opt/nginx1-12/static'
STATIC_URL = '/static/'
STATICFILES_DIRS=[
os.path.join(BASE_DIR,"static"),
]

上述的参数STATIC_ROOT用在哪?

通过python3 manage.py collectstatic 收集所有你使用的静态文件保存到STATIC_ROOT!

STATIC_ROOT 文件夹 是用来将所有STATICFILES_DIRS中所有文件夹中的文件,以及各app中static中的文件都复制过来
# 把这些文件放到一起是为了用nginx等部署的时候更方便

下面这个提醒我们没有manage.py是因为我们要去项目根目录

有时候会提醒我们没有这个文件夹  那我们就自己手动mkdir一个

然后执行

python manage.py collectstatic

会告诉我们都已经完成了

然后查看我们指定的文件夹内

这个时候我们就要启动我们的uwsgi了  这时候有个坑,uwsgi和nginx的结合的时候不可以使用

 uwsgi指明http协议,浏览器可以直接访问,走的是http协议,  然而nginx的uwsgi_pass 不认识http协议,必须要用socket连接 

所以使用nginx和uwsgi分发的命令应该是socket启动的

uwsgi --socket :9000 --module 项目.wsgi --py-autoreload=1

uwsgi --socket :9000 --module mysite15.wsgi --py-autoreload=1

第二种使用ini配置文件:

随意在任意一处创建一个uwsgi.ini结尾的文件 但是最好在我们的项目目录下:

[uwsgi]
#使用nginx连接时使用
socket=0.0.0.0:9000
#不用nginx直接当做web服务器使用
#http=0.0.0.0:9000
#项目目录绝对路径
chdir=/data/opt/Myproject/venv/mysite15
#wsgi文件路径,在项目底下
wsgi-file=mysite15/wsgi.py
#指定解释器目录
home=/data/opt/Myproject/venv # which python 找一下你的项目用的python解释器的位置 我用的虚拟环境所以就是这个位置
processes=4
threads=2
master=True
pidfile=uwsgi.pid
#daemonize=uwsgi.log

然后退出看下当前位置如果有uwsgi.ini文件就直接启动

启动:

uwsgi --ini uwsgi.ini 

如果没有的话就指定位置启动不然会进行报错找不到的

uwsgi --ini  uwsgi.ini文件存放的目录/uwsgi.ini

supervisor:

supervisor 是一个基于python的任务管理工具,在python3下无法下载只能通过python2 去下载

easy_install supervisor

2、将你的supervisor重定向到一个指定文件方便查看

echo_supervisord_conf  > 你要指定的文件目录
echo_supervisord_conf > /etc/supervisord.conf

3、

找到我们的当前的环境下的uwsgi

然后进入你重定向的这个文件内  在配置文件的最后面加上两行配置


[program:随意设置的名字]
command=python解释器下的bin目录下的 uwsgi 然后加载你的uwsgi.ini文件


[program:my_django15]
command=/data/opt/Myproject/venv/bin/uwsgi --ini /data/opt/Myproject/venv/mysite15/uwsgi.ini

然后启动:

supervisord -c /etc/supervisord.conf 

然后进入任务界面:

supervisorctl

这个时候看到我们的uwsgi还在执行

我们停止这个自定的项目名字试试

再看看就没有了:

然后再启动

使用uwsgi发布项目的更多相关文章

  1. 【无私分享:ASP.NET CORE 项目实战(第十章)】发布项目到 Linux 上运行 Core 项目

    目录索引 [无私分享:ASP.NET CORE 项目实战]目录索引 简介 ASP.Net Core 给我们带来的最大的亮点就是跨平台,我在我电脑(win7)上用虚拟机建了个 CentOS7 ,来演示下 ...

  2. Android 急速发布项目到 JitPack

    转载请标明出处: http://www.cnblogs.com/zhaoyanjun/p/5942616.html 出自[赵彦军博客] 2016/10/09 前言:以前写过一篇 Android stu ...

  3. Visual Studio 使用Web Deploy 3.6发布项目

    工具:Web Deploy 3.6 点击下载 (强烈推荐使用独立的Web Deploy 安装包安装) 配置: 1.安装web deploy,安装好之后,点击IIS根目录,此处应有如下图标 另外,需要注 ...

  4. maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令

    maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令 在日常的工作中由于各种原因,会出现这样一种情况,某些项目并没有打包至mvnrepository. ...

  5. VS2016 发布项目提示 CS0006 C# Metadata file 'xxxxxxx.dll' could not be found

    生成的时候没有问题,发布项目的时候提示 CS0006 C# Metadata file 'xxxxxxx.dll' could not be found 解决方案,找到 xxxxxxx.dll 这个项 ...

  6. 异常之Tomcat7.0服务器无法发布项目

    今天突然就不能发布tomcat 7.0服务器了,并弹出对话框,报出如下错误: Cannot acquire J2EEFlexProjDeployable object for module test ...

  7. Tomcat下使用war包发布项目

    Tomcat下使用war包发布项目 转自<Tomcat下使用war包发布项目 >,地址:http://blog.csdn.net/wy818/article/details/7240294 ...

  8. tomcat通过conf-Catalina-localhost目录发布项目详解 摘自:http://www.cnblogs.com/iyangyuan/archive/2013/09/12/3316444.html

    Tomcat发布项目的方式大致有三种,但小菜认为通过在tomcat的conf/Catalina/localhost目录下添加配置文件,来发布项目,是最佳选择. 因为这样对tomcat的入侵性最小,只需 ...

  9. tomcat通过conf-Catalina-localhost目录发布项目详解

    Tomcat发布项目的方式大致有三种,但小菜认为通过在tomcat的conf/Catalina/localhost目录下添加配置文件,来发布项目,是最佳选择. 因为这样对tomcat的入侵性最小,只需 ...

随机推荐

  1. nginx的gzip模块

    gzip模块是我们在nginx里面经常用到的,压缩响应的数据,这通常有助于将传输数据的大小减少一半甚至更多.可以让我们访问网站更为流畅. Syntax Default Context gzip on ...

  2. 将已有Git库代码推送到新建库中

    cd /path/to/your/git/repo/ git remote -v git remote rm origin git remote add origin ssh://abc@gmail. ...

  3. 基于json-lib-2.2.2-jdk15.jar的JSON解析工具类大集合

    json解析之前的必备工作:导入json解析必须的六个包 资源链接:百度云:链接:https://pan.baidu.com/s/1dAEQQy 密码:1v1z 代码示例: package com.s ...

  4. Java接口调用工具类

    package com.qiyuan.util; import java.io.BufferedReader; import java.io.IOException; import java.io.I ...

  5. PHP初级篇

    PHP初级篇 PHP环境搭建: 企业中常用到的环境是:Linux+Apache+MySQL+PHP 学习环境是:Windows+Apache+MySQL+PHP 工具 Apache 2.4.4 MyS ...

  6. 使用gitlab, jenkins搭建CI(持续集成)系统(2) -- 配置webhook触发构建

    1. 在gitlab上配置192.168.1.30的ssh秘钥,使jenkins可以操作gitlab上的project 进入gitlab,点击右上角 点击 Settings -> SSH key ...

  7. FineUI表格、窗体、按钮组及事件

    //表格 @(F.Grid().IsFluid(true).CssClass("blockpanel").Title("表格").ShowHeader(true ...

  8. [日常] nginx与location规则

    =========================================================================2018年3月28日 记录: location = / ...

  9. SpringBoot(三) Core Features: External Configuration(配置文件)

    码云: external-configuration 可以使用属性文件,YAML文件,环境变量和命令行参数来外部化配置 一.属性值可以直接注入到bean 系统属性值不可以 // application ...

  10. JVM原理自总结

    一.成熟的系统调优1.一定要绝对避免循环查数据库和缓存(PS:循环里面就不能有查询缓存,更不能有查询数据库的操作,因为循环的次数没法控制) 2.对于API接口的话,一般都是直接查缓存的,没有查数据库的 ...