centos6.5下配置django+uwsgi+nginx

2024-08-29 08:08

本文主要是介绍centos6.5下配置django+uwsgi+nginx,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

安装django

可利用如下命令行安装

pip install django
  • 1

默认会安装到python目录下的bin文件夹下,如下图所示 
这里写图片描述

  • 如果已经设置了python3.5环境变量可直接使用django-admin来创建项目
  • 如果没有可利用如下命令来创建软连接使django-admin任何目录下均可使用,注意:本人的python3.5目录为/usr/local/python3.5/,请对照自己的目录进行更换
ln -s /usr/local/python3.5/bin/django-admin.py /usr/bin/django-admin
  • 1

测试安装是否正确:

本人在自己的/root/django目录下面采用如下命令创建了django的项目

django-admin startproject hello
  • 1

此时在本目录我们会发现一个hello的项目已经创建 
这里写图片描述

执行如下命令来启动django项目

cd hello
python manage.py runserver 0.0.0.0:8002
  • 1
  • 2

打开浏览器输入http://localhost:8002/,如果显示如下界面,则表示django安装成功 
这里写图片描述

安装uwsgi

可以执行如下命令进行安装

pip install uwsgi
  • 1
  • 如果已经设置了python3.5环境变量可直接使用uwsgi命令来部署服务
  • 如果没有可利用如下命令来创建软连接使uwsgi命令在任何目录下均可使用,注意:本人的python3.5目录为/usr/local/python3.5/,请对照自己的目录进行更换
ln -s /usr/local/python3.5/bin/uwsgi /usr/bin/uwsgi
  • 1

测试安装是否正确

在家目录中创建test.py文件,写入如下内容:

def application(env, start_response):start_response('200 OK', [('Content-Type','text/html')])return [b"Hello World"]
  • 1
  • 2
  • 3

通过如下命令来运行该文件

uwsgi --http :8002 --wsgi-file test.py
  • 1

这里写图片描述 
在浏览器中输入http://localhost:8002/,如果出现如下结果,表示安装成功 
这里写图片描述

将uwsgi与django结合

刚刚我们创建的django项目位于/root/django/hello 
执行如下命令来检验uwsgi是否能与django项目成功结合

uwsgi --http :8008 --chdir /root/django/hello --wsgi-file hello/wsgi.py --master --processes 4 --threads 2 --stats 127.0.0.1:9192
  • 1

常用选项如下所示:

  • http : 协议类型和端口号

  • processes : 开启的进程数量

  • workers : 开启的进程数量,等同于processes(官网的说法是spawn the specified number ofworkers / processes)

  • chdir : 指定运行目录(chdir to specified directory before apps loading)

  • wsgi-file : 载入wsgi-file(load .wsgi file)

  • stats : 在指定的地址上,开启状态服务(enable the stats server on the specified 
    address)

  • threads : 运行线程。由于GIL的存在,我觉得这个真心没啥用。(run each worker in prethreaded

  • mode with the specified number of threads)

  • master : 允许主进程存在(enable master process)

  • daemonize : 使进程在后台运行,并将日志打到指定的日志文件或者udp服务器(daemonize uWSGI)。实际上最常用的,还是把运行记录输出到一个本地文件上。

  • pidfile : 指定pid文件的位置,记录主进程的pid号。

  • vacuum : 当服务器退出的时候自动清理环境,删除unix socket文件和pid文件(try to remove all of the generated file/sockets)

注意:–wsgi-file后面跟的是相对目录

此时在浏览器中输入:http://localhost:8008/,出现如下界面,表示两者结合成功 
这里写图片描述

鉴于后面跟的参数较多,我们可以将这些参数放在一个ini文件中,当然,uwsgi支持多种类型的配置文件,如xml,ini等。此处,使用ini类型的配置。 
在hello项目目录下创建hello_uwsgi.ini文件,文件内容如下:

# hello_uwsgi.ini file
[uwsgi]# Django-related settingshttp = :8008# the base directory (full path)
chdir           = /root/django/hello# Django s wsgi file
module          = hello.wsgi# process-related settings
# master
master          = true# maximum number of worker processes
processes       = 4# ... with appropriate permissions - may be needed
# chmod-socket    = 664
# clear environment on exit
vacuum          = true
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24

此时执行如下命令:

uwsgi --ini myweb_uwsgi.ini 
  • 1

此时在浏览器中输入:http://localhost:8008/,出现如下界面,表示使用ini文件成功 
这里写图片描述

安装nginx

可以执行如下命令进行安装

cd /usr/local/
wget http://nginx.org/download/nginx-1.5.6.tar.gz
tar xf nginx-1.5.6.tar.gz
cd nginx-1.5.6
./configure 
make && make install
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

执行完之后我们会发现在/usr/local目录会多出一个nginx目录 
这里写图片描述


测试安装是否正确

由于80端口较容易被别的程序占用,需执行如下命令来修改nginx配置文件中的端口号

vim nginx/conf/nginx.conf
  • 1

如下图所示将listen对应的80改成8088,并保存退出 
这里写图片描述 
执行如下命令来启动nginx服务

nginx/sbin/nginx
  • 1

这里写图片描述

打开浏览器输入http://127.0.0.1:8088/,如果出现如下界面则表示nginx安装正确 
这里写图片描述

将nginx与uwsgi以及django结合

执行如下命令来修改nginx.conf文件

vim /usr/local/nginx/conf/nginx.conf
  • 1

这里写图片描述 
主要修改如上图所示: 
listen端口改为8092 
在location中添加:

include uwsgi_params; 
uwsgi_pass 127.0.0.1:8008;(端口要与ini中的端口一致)

执行如下命令来启动:

uwsgi --ini /root/django/hello/hello_uwsgi.ini & /usr/local/nginx/sbin/nginx
  • 1

打开浏览器输入http://localhost:8008/,显示如下结果表示成功 
这里写图片描述

这篇关于centos6.5下配置django+uwsgi+nginx的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1117314

相关文章

Spring Boot配置和使用两个数据源的实现步骤

《SpringBoot配置和使用两个数据源的实现步骤》本文详解SpringBoot配置双数据源方法,包含配置文件设置、Bean创建、事务管理器配置及@Qualifier注解使用,强调主数据源标记、代... 目录Spring Boot配置和使用两个数据源技术背景实现步骤1. 配置数据源信息2. 创建数据源Be

Spring Boot Maven 插件如何构建可执行 JAR 的核心配置

《SpringBootMaven插件如何构建可执行JAR的核心配置》SpringBoot核心Maven插件,用于生成可执行JAR/WAR,内置服务器简化部署,支持热部署、多环境配置及依赖管理... 目录前言一、插件的核心功能与目标1.1 插件的定位1.2 插件的 Goals(目标)1.3 插件定位1.4 核

RabbitMQ消息总线方式刷新配置服务全过程

《RabbitMQ消息总线方式刷新配置服务全过程》SpringCloudBus通过消息总线与MQ实现微服务配置统一刷新,结合GitWebhooks自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,

Nginx安全防护的多种方法

《Nginx安全防护的多种方法》在生产环境中,需要隐藏Nginx的版本号,以避免泄漏Nginx的版本,使攻击者不能针对特定版本进行攻击,下面就来介绍一下Nginx安全防护的方法,感兴趣的可以了解一下... 目录核心安全配置1.编译安装 Nginx2.隐藏版本号3.限制危险请求方法4.请求限制(CC攻击防御)

nginx中端口无权限的问题解决

《nginx中端口无权限的问题解决》当Nginx日志报错bind()to80failed(13:Permissiondenied)时,这通常是由于权限不足导致Nginx无法绑定到80端口,下面就来... 目录一、问题原因分析二、解决方案1. 以 root 权限运行 Nginx(不推荐)2. 为 Nginx

nginx 负载均衡配置及如何解决重复登录问题

《nginx负载均衡配置及如何解决重复登录问题》文章详解Nginx源码安装与Docker部署,介绍四层/七层代理区别及负载均衡策略,通过ip_hash解决重复登录问题,对nginx负载均衡配置及如何... 目录一:源码安装:1.配置编译参数2.编译3.编译安装 二,四层代理和七层代理区别1.二者混合使用举例

Java JDK1.8 安装和环境配置教程详解

《JavaJDK1.8安装和环境配置教程详解》文章简要介绍了JDK1.8的安装流程,包括官网下载对应系统版本、安装时选择非系统盘路径、配置JAVA_HOME、CLASSPATH和Path环境变量,... 目录1.下载JDK2.安装JDK3.配置环境变量4.检验JDK官网下载地址:Java Downloads

nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析(结合应用场景)

《nginx-t、nginx-sstop和nginx-sreload命令的详细解析(结合应用场景)》本文解析Nginx的-t、-sstop、-sreload命令,分别用于配置语法检... 以下是关于 nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析,结合实际应

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用