python电商系统_python-django框架-电商项目-项目部署_20191127

python-django框架-电商项目-项目部署:

uwsgi作为web服务器:

在pycharm中启动项目:使用python manage.py runserver

这个runserver是django提供的开发的时候的web服务器,这个服务器只在开发的时候使用,部署的时候不会,部署的时候使用uwsgi,

uwsgi

这是一个遵循wsgi协议的web服务器,

################### 报错 ###########################

安装:pip install uwsgi,这个转入自己的虚拟环境,

报错:AttributeError: module 'os' has no attribute 'uname'

解决:

定位到uwsgiconfig.py文件中,首先import platform后,将os.unam()都改为platform.uname()即可。

os.uname()是不支持windows系统的。platform模块是支持任何系统。

2.下载uwsgi离线安装

https://pypi.python.org/pypi/uWSGI/

解压后,进入目录下

python setup.py install

报错:Exception: you need a C compiler to builduWSGI

安装了MinGW的c编译器,但是还是不行,

################################################################

下面我尝试在Linux系统部署项目

安装:pip install uwsgi,这个转入自己的虚拟环境,

Ubuntu pip3安装uwsgi报错

Running setup.py install for uwsgi ... error

解决方法:sudo apt-get install -y python3-dev

测试uwsgi是否安装成功完成:uwsgi --version

安装成功了,

uwsgi这个安装好了,怎么用它启动我们的项目?

uwsgi的配置:

项目部署的时候,一定要把settings下面的DEBUG改为FALSE

DEBUG = False

ALLOWED_HOSTS = ['*']

使用uwsgi还需要进行一个配置,

在项目目录下,新建一个文件uwsgi.ini,这个ini就是配置文件的后缀

uwsgi的启动和停止,

启动:uwsgi --ini uwsgi.ini (后面是配置文件的路径) #不加--ini也可以

停止:uwsgi --stop uwsgi.pid

重启:uwsgi --reload uwsgi.pid

启动的时候报错:

uwsgi: option ‘–http’ is ambiguous

getopt_long() error

解决:sudo apt-get install uwsgi uwsgi-core uwsgi-plugin-python#uwsgi-plugin-python一定要安装

但是还是不行,

又找到一个解决方案:Ubuntu 安装 libxml*

然后我找到了方法:sudo apt-get install libxml*

但是又报错了:报错:无法安装XXX, 需要依赖于XXX,那就先去安装这个依赖的XXX

然后开始找这个报错的解决方案:

首先需要安装 aptitude:sudo apt-get install aptitude

然后使用 aptitude 安装包:sudo aptitude install libxml*

发现这个方法也不对,!!!!!!

不对,还是要理清思路 !!!!!!!!!!!!!!

#############################################################

重新理清思路:

第一步:安装uwsgi

进入虚拟环境:

pip install uwsgi

uwsgi --version,看到版本就安装好了,

第二步:uwsgi的配置

1,项目部署的时候,一定要把settings下面的DEBUG改为FALSE

DEBUG = False

ALLOWED_HOSTS = ['*']

2,在项目目录下,新建一个文件uwsgi.ini,这个ini就是配置文件的后缀

ContractedBlock.gif

ExpandedBlockStart.gif

#添加配置选择

[uwsgi]

#配置和nginx连接的socket连接

#socket=127.0.0.1:8080#直接做web服务器使用 python manage.py runserver ip:port

http=127.0.0.1:8080#配置项目路径,项目的所在目录

chdir=/home/andy/bj18/dailyfresh

#配置wsgi接口模块文件路径

wsgi-file=dailyfresh/wsgi.py

#配置启动的进程数

processes=4#配置每个进程的线程数

threads=2#配置启动管理主进程

master=True

#配置存放主进程的进程号文件

pidfile=uwsgi.pid

#配置dump日志记录

daemonize=uwsgi.log

#设置虚拟环境的路径

virtualenv=/home/andy/.virtualenvs/lq_py3

View Code

第三步:配置完了之后启动:

启动:uwsgi --ini uwsgi.ini (后面是配置文件的路径)

出现这一句就对了:[uWSGI] getting INI configuration from uwsgi.ini

ps aux | grep uwsgi,查看启动的服务,会发现有很多的uwsgi的服务都启动了,

执行了这些服务之后,就相当于执行了runserver,我们的服务就启动了,

我们就可以通过监听的ip和端口号访问我们的网站了,

停止:uwsgi --stop uwsgi.pid (后面是文件的路径)

报错了:ImportError: No module named 'haystack'

安装了之后不报错了,

但是还需要配置,

现在还有几个模块没有在Linux上面安装的,现在都安装一下,

然后再进行,在Linux上面运行,python manage.py runserver,不报错了,就对了,

经过了痛苦的一天的时间,终于搞定了这个服务的问题!!!!!还是非常的喜悦的心情的,哈哈哈哈!!!!!

第四步:访问Linux上面的http://127.0.0.1:8080/index

访问这个网址可以显示网页,就说明你配置的是对的了,

现在有一个问题,是不能显示样式的问题,

django配置中setting,有一个debug=True,那时候django自动帮你处理静态文件,现在部署的时候,把这个debug改成了False,所以django也不能帮你处理静态文件了,

所以静态文件没有显示,

怎么处理?

需要用到Nginx,使用Nginx帮我们提供静态文件,

现在我们已经知道uwsgi可以作为一个服务器,来访问,不需要使用启动django的方式了。

#####################

基本的部署框架解析

刚刚我们使用uwsgi作为服务器的流程:

用户浏览器,web服务器uwsgi,django代码

这是三层,

这3层怎么交互的,

用户请求网站,首先是请求uwsgi这个web服务器,然后uwsgi调用django框架的入口,然后django处理,处理完成之后,会返回给uwsgi服务器,然后uwsgi返回给用户的浏览器,

这就是刚刚搭建的过程,

这是部署项目最简单的模型,

下载这个模型有一个问题,就是我的静态文件不能显示,

在uwsgi的前面加上一个Nginx服务器,这个Nginx服务器就是放在用户和uwsgi之间的,这就是四层了,

#########################

用户浏览器,Nginx服务器,uwsgi服务器,django代码

Nginx也可以作为web服务器,用户浏览器请求,先去请求Nginx,Nginx里面配置,

1,如果是动态请求,转交给uwsgi服务器,后面的过程不需要管, 只需要转交,然后uwsgi再到django代码,返回的时候,django把处理的信息给uwsgi,然后uwsgi给Nginx,然后Nginx给web浏览器,

2,如果不是一个动态请求,是一个静态的请求,提前把项目用到的静态文件,放到Nginx所在电脑的某一个目录中,然后Nginx做一个配置,它会根据配置到目录下方,找到这个静态文件,然后直接返回给用户的浏览器,就不经过uwsgi了,

这就是我们搭建Nginx的作用,

到底是动态请求还是动态请求,都是根据url的配置,根据Nginx里面的location地址的配置,比如在Nginx里面配置一个/,一个/static,凡是static开头的就是一个静态的请求,其他的就是一个动态的请求,所以主要看Nginx的配置,

我们这就是对之前3层的一个升级,

Nginx转交给uwsgi的部署:

现在的问题就是怎么通过Nginx和uwsgi进行一个对接,

第一步:要对接,我们uwsgi的文件需要做一个更改,找到配置文件,

后面的操作,我只在我的Linux上面进行修改,

进入我的Linux上面的项目目录:cd /home/andy/bj18/dailyfresh

#配置和nginx连接的socket连接

socket=127.0.0.1:8080 #把这一行放出来,

#直接做web服务器使用 python manage.py runserver ip:port

#http=127.0.0.1:8080

第二步:Nginx也要配置

进入Nginx目录:cd /usr/local/nginx/conf

修改配置文件,

location / {

# 包含uwsgi的请求参数

include uwsgi_params;

#转交请求给uwsgi

uwsgi_pass 127.0.0.1:8080

}

配置完了,增加了一个配置项,这个时候还没有配置静态和动态的区分,

现在分别启动Nginx和uwsgi,

现在就可以直接访问Nginx了,

#####################################

Nginx的ip和端口号是多少?

127.0.0.1端口是80,你访问127.0.0.1,就是默认访问80,

你想要访问首页,就是127.0.0.1/index

好了这样访问这个地址就对了,

Nginx配置处理静态文件:

继续配置Nginx,

新建一个目录用户存放静态文件

cd /var/

mkdir -p /var/www/dailyfresh/static,没有父级目录,就新建,

这就是我们的目录:/var/www/dailyfresh/static

location /static {

# 指定静态文件存放的目录

alias /var/www/dailyfresh/static/;

}

配置好了,

下一步要把静态文件收集过来,放到我们的这个目录下面,

不能把项目中static整个的文件夹全部copy过去,这只是你看到的静态文件,实际上比这还要多,

那怎么把所有的静态文件找出来呢?

django提供了怎么收集项目所用到的静态文件,

django的settings中配置收集静态文件的路径,

#指定收集静态文件的路径

STATIC_ROOT='/var/www/dailyfresh/static'

然后修改文件夹的权限,

sudo chmod 777 /var/www/dailyfresh/static

然后进入虚拟工作区,workon lq_py3

进入项目目录:cd /home/andy/bj18/dailyfresh

执行命令:python manage.py collectstatic

这样就收集完了,

重启Nginx,sudo /usr/local/nginx/sbin/nginx -s reload

再次在Linux上面,访问这个页面,127.0.0.1/index

发现这个页面就是有静态页面的好看的页面了,哈哈哈!!!!

这样,我们的静态文件都是/static开头的,根据Nginx里面的配置,就能找到静态文件了,

到了这一步,基本的部署基本就可以了,

这就是整个的部署架构了,

在这个基础上,还有,

之前有把首页生成静态文件,用户是访问我们的静态的首页,还是django的首页,我们需要做一个区分,如果访问包含/index的话,就交给django,如果访问的地址只有一个/,我们就交给celery上面的Nginx,让他产生一个静态页面,返回回来,

怎么实现这个区分?

我们需要在用户后面,django项目前面加入一个调度的Nginx,我就用刚刚的Nginx来做,

流程图再次梳理一下:

用户去访问我的网站,在网站的最前面会有一个调度的Nginx,后面就是我们的django项目(uwsgi+django),还有一个产生静态页面的电脑,静态页面服务器,在服务器上回生成静态的首页,静态页面是使用的celery,怎么生成提供这个页面?就需要在这个静态页面的服务器配置一个Nginx,

整个网站部署完了之后,用户只会知道我们Nginx的ip或者域名,根据请求,我们的Nginx可以做一个区分,如果访问的是一个/,就是找静态的首页,如果是访问的/index,就是访问django去了,

刚刚已经配置好了,可以实现如果是访问的/index,就是转交访问django去了,可以实现这个转交,现在关键的一点是,如果访问的是/,怎么找静态的首页,

所以Nginx在这个项目承担了两个角色,一个是调度,转交给uwsgi处理,转交给静态服务器,还有一个功能就是处理静态文件,

我们可以给Nginx的ip绑定一个域名,用户访问我们的网站, 输入域名,就是访问我们的Nginx,用户不知道其他内容,

当访问的是/的时候,怎么去访问静态页面?

我们之前做的静态页面在哪里?

在我们的fastdfs,

我们在进入Nginx的配置文件:sudo vi /usr/local/nginx/conf/nginx.conf

我们之前配置的,80端口是提供我们的静态页面,8888端口是提供我们的图片的,

现在Linux的配置,80端口是用来,作为调度的,如果是/就是访问django,如果是/static就是访问静态文件,

配置Nginx的配置文件,

sudo vi /usr/local/nginx/conf/nginx.conf

难道我要两台Nginx服务器????

看来是的,这个问题不影响大局,我后面再看,

# 等于号是精确匹配,上面都是模糊匹配,

location = / {

#传递请求给静态文件服务器上的Nginx,

proxy_pass http://192.168.100.128;

}

这个proxy,就是在满足这个条件的时候,转发给另外一个服务器,让它提供我们的静态首页,,

Nginx配置upstream思想实现均衡,

django项目后面是

1,我们的数据库,,

2,还有我们的fastdfs(里面有两个角色,tracker和storage,),

3,还使用到了redis(承担了很多的功能,承担了缓存的作用,session的缓存存储,celery异步中承担broker的角色,购物车和浏览记录)

后面的东西,就是我们的django和这些有一个交互的过程,

django项目可能在一台电脑上,mysql在另外一台电脑上,fastdfs也可能在另外一台电脑,我们看到的所有的东西都可以在不同的电脑上,

比如redis的几个功能都可以放到不同的电脑上,

但是Nginx是跟着fastdfs走的,因为要提供图片,Nginx也要跟着静态页面服务器走的,

这样的一个过程,

Nginx我们一般叫做调度服务器,或者叫做负载均衡服务器,

怎么叫负载均衡服务器,我一个网站, 在做好了之后去部署的时候,服务的代码可能启动的不只是一套,我们的代码可以运行多份,每跑一个,就是一个进程,就可以提供服务,用户的请求过来之后,我们就可以进行配置,Nginx可以转交给不同的代码服务器上去,这样就可以实现我们的负载的均衡了,

比如用户的请求过来,Nginx做一个转交,可能转交到了代码服务器1,用户来了第二个请求,我可能就转交给代码服务器2,这种就是叫做负载均衡,

这一点我们怎么配置?

找到我们的项目配置文件,

把uwsgi的配置文件复制一份,改动一下端口为8081,然后改名字为uwsgi2,

然后启动这个uwsgi2,我们就会看到两个了uwsgi,uwsgi2,我们就是启动了两个服务器,我们通常叫做应用服务器,或者叫做业务处理的服务器,

我现在需要在Nginx中做一个配置,在转发请求的时候,可以转发给这两个,实现一个负载均衡,

配置:

sudo vi /usr/local/nginx/conf/nginx.conf

至于怎么配置,我现在先不考虑,

实际工作中,我们可以使用很多台的服务器,来做这个负载均衡,

代码层面的优化是有极限的,所以要靠硬件来解决了,

这个部署也不是我们部署的,是运维部署的,

项目总结:

部署之后,项目就结束了,

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值