ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

uwsgi

2022-01-05 23:33:32  阅读:280  来源: 互联网

标签:opt root web01 linux bbs 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

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有