其他分享
首页 > 其他分享> > uwsgi

uwsgi

作者:互联网

目录

LNMP是一套技术的组合,L=Linux、N=Nginx、M~=MySQL、P~=Python
首先Nginx服务是不能处理动态请求,那么当用户发起动态请求时, Nginx又是如何进行处理的。
    1.静态请求:请求的内容是静态文件就是静态请求
        1)静态文件:文件上传到服务器,永远不会改变的文件就是静态文件
        2)html就是一个标准的静态文件
    2.动态请求:请求的内容是动态的就是动态请求
        1)不是真实存在服务器上的内容,是通过数据库或者其他服务拼凑成的数据
 
当用户发起http请求,请求会被Nginx处理,如果是静态资源请求Nginx则直接返回,如果是动态请求Nginx则通过uwsgi协议转交给后端的Python程序处理

uwsgi

因为nginx不支持wsgi协议,无法直接调用py开发的webApp。
在nginx+uWsgi+Django的框架里,nginx代理+webServer,uWsgi是wsgiServer,Django是webApp。
nginx通过uwdsgi来代理python程序
nginx接收用户请求,并判定哪些转发到uWsgi,uWsgi再去调用pyWebApp。

uwsgi服务部署

1、创建用户
[root@web01 opt]# groupadd django -g 888
[root@web01 opt]# useradd django -u 888 -g 888 -r -M -s /bin/sh

2、安装依赖软件
[root@web01 opt]# yum install python3 libxml* python-devel gcc* pcre-devel openssl-devel python3-devel -y

3、安装Django和uwsgi
[root@web01 opt]# pip3 install django
[root@web01 opt]# pip3 install uwsgi

4、创建项目
[root@web01 opt]# cd /opt
# 创建一个linux项目
[root@web01 opt]# django-admin startproject linux
[root@web01 opt]# cd linux
# 创建django
[root@web01 opt]# django-admin startapp app01
# 修改配置文件
[root@web01 linux]# vim linux/settings.py
ALLOWED_HOSTS = ['*'] '允许所有IP都能访问的意思'
DATABASES = {} '数据库清空'

# 启动测试
[root@web01 linux]# python3 manage.py runserver 0.0.0.0:8000

如图所示成功

**由于python的多线程性能不是很好,如果网站遇到的流量很大,服务的承载能力不强,为了django的稳定性,提供了uwsgi,uwsgi是由C语言编写。 uwsgi配合python时,不启用python服务,uwsgi调用pthon代码,绕过python自启的服务,有效提高性能 **

编辑项目配置文件

[root@web01 linux]# pwd
/opt/linux
[root@web01 linux]# vim myweb_uwsgi.ini 
[uwsgi]
# 端口号
socket            = :8000
# 指定项目的目录
chdir           = /opt/linux
# wsgi文件路径
wsgi-file       = linux/wsgi.py
# 模块wsgi路径
module          = linux.wsgi
# 是否开启master进程
master          = true
# 工作进程的最大数目
processes       = 4
# 结束后是否清理文件
vacuum          = true

启动uwsgi

不推荐使用root用户启动,创建uid
[root@web01 linux]# groupadd www -g 666
[root@web01 linux]# useradd www -u 666 -g 666 -M -s /sbin/nologin -r
[root@web01 linux]# uwsgi  --ini myweb_uwsgi.ini --uid 666

出现上图所示,运行成功,如果不想将信息显示前台加入参数 -d

[root@web01 linux]# uwsgi -d --ini myweb_uwsgi.ini --uid 666

参数介绍

-d 	  : 以守护进程方式运行
--ini : 指定配置文件路径
--uid : 指定uid

此时是无法访问192.168.15.7:8000,因为uwsgi是一个TCP服务,TCP服务包含HTTP服务,但HTTP服务不包含TCP,192.168.15.7:8000访问的是HTPP服务,所以无法访问,那么如何使192.168.15.7:8000访问呢?

编辑Nginx配置文件即可访问,Nginx的作用就是将uwsgi转换成HTTP服务

每个源都有各自的配置

[root@localhost ~]# cat /etc/nginx/conf.d/python.conf 
server {
    listen 80;
    server_name py.test.com;
    location / { 
        include uwsgi_params; # /etc/nginx 需要有这个配置
        uwsgi_pass 127.0.0.1:8000;
        uwsgi_read_timeout 2; # 超时时间
        uwsgi_param UWSGI_SCRIPT linux.wsgi; # 定义一个变量
        uwsgi_param UWSGI_CHDIR /opt/linux; # 创建项目的路径
        index  index.html index.htm;
        client_max_body_size 35m;
    }
}

现在操作压测,python服务和使用uwsgi之后的区别

首先python使用8001端口访问
[root@web01 linux]# python3 manage.py runserver 0.0.0.0:8001

    listen 80;
    server_name py.test.com;
    location / { 
        include uwsgi_params;
        uwsgi_pass 127.0.0.1:8000;
        uwsgi_read_timeout 2;
        uwsgi_param UWSGI_SCRIPT linux.wsgi;
        uwsgi_param UWSGI_CHDIR /opt/linux;
        index  index.html index.htm;
        client_max_body_size 35m;
    }
}

server {
     listen 80;
     server_name py1.test.com;
     location / {
          proxy_pass http://127.0.0.1:8001;
     }
}

此时两个域名均能访问

# 添加域名解析
[root@web01 conf.d]# vim /etc/hosts
172.16.1.7  py.test.com py1.test.com
测试
[root@web01 conf.d]# curl -I -H 'Host: py.test.com' 172.16.1.7
[root@web01 conf.d]# curl -I -H 'Host: py1.test.com' 172.16.1.7

开始压力测试

[root@web01 conf.d]# ab -n 10000 -c 10 http://py.test.com/

部署BBS项目

1、部署数据库
[root@db01 ~]# yum install mariadb* -y

2、启动数据库
[root@db01 ~]# systemctl start mariadb 

3、远程连接MySQL数据
[root@web01 conf.d]# mysql
MariaDB [(none)]> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> CREATE DATABASE `bbs` DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;
Query OK, 1 row affected (0.00 sec)

远程连接MySQL数据

部署BBS

上传代码至/opt
[root@web01 migrations]# pwd
/opt/bbs/app01/migrations
[root@web01 migrations]# rm -rf 00*
[root@web01 migrations]# rm -rf __pycache__/

[root@web01 migrations]# cd /opt/bbs/
[root@web01 bbs]# pwd
/opt/bbs

# 修改Django版本
[root@web01 bbs]# pip3 uninstall django
[root@web01 bbs]# pip3 install django==1.11

查看django版本
[root@web01 bbs]# pip3 list
DEPRECATION: The default format will switch to columns in the future. You can use --format=(legacy|columns) (or define a format=(legacy|columns) in your pip.conf under the [list] section) to disable this warning.
asgiref (3.4.1)
Django (1.11)
pip (9.0.3)
PyMySQL (1.0.2)
pytz (2021.3)
setuptools (39.2.0)
sqlparse (0.4.2)
typing-extensions (4.0.1)
uWSGI (2.0.20)
[root@web01 bbs]# 

修改数据链接


# 修改数据连接
[root@web01 bbs]# vim bbs/settings.py
ALLOWED_HOSTS = ['*']
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'bbs',
        'USER': 'root',
        'PASSWORD': '123456',
        'HOST': '172.16.1.61',
        'PORT': 3306,
        'CHARSET': 'utf8'
    }
}
测试

[root@web01 bbs]# uwsgi -d --ini myweb_uwsgi.ini --uid 666

配置nginx

[root@localhost ~]# cat /etc/nginx/conf.d/python.conf 
[root@localhost ~]# vim /etc/nginx/conf.d/python.conf 
server {
    listen 80;
    server_name bbs.test.com;
    location / { 
        include uwsgi_params;
        uwsgi_pass 127.0.0.1:8002;
        uwsgi_read_timeout 2;
        uwsgi_param UWSGI_SCRIPT bbs.wsgi;
        uwsgi_param UWSGI_CHDIR /opt/bbs;
        index  index.html index.htm;
        client_max_body_size 35m;
    }
}
[root@web01 bbs]# uwsgi -d --ini myweb_uwsgi.ini --uid 666
[root@web01 bbs]# systemctl restart nginx

标签:opt,root,web01,linux,bbs,uwsgi
来源: https://www.cnblogs.com/xiejunjie8888/p/15769343.html