当项目开发完毕后,需要上线。此时,需创建从从uwsgi、nginx、静态文件三个方面处理。(当然,本文只是在Django下的部署,可作参考。)
服务器介绍
- 服务器:私有服务器、公有服务器
- 私有服务器:公司自己购买、自己维护,只布署自己的应用,可供公司内部或外网访问
- 公有服务器:集成好运营环境,销售空间或主机,供其布署自己的应用 私有服务器成本高,需要专业人员维护,适合大公司使用 公有服务器适合初创公司使用,成本低
- 常用的公有服务器,如阿里云、青云等,可根据需要,按流量收费或按时间收费
- 此处的服务器是物理上的一台非常高、线路全、运行稳定的机器
服务器环境配置
一般个人配置服务器,是在虚拟机下的Ubuntu下设置的。
安装pip
Ubuntu 默认自带了 python2和python3
默认python代表使用python2,
想使用python3 则需要用python3来进入交互命令行
Ubuntu没有自带pip需要使用
sudo apt install python-pip 安装python2 pip
sudo apt install python3-pip 安装python3 pip
- 在本地的虚拟环境中,项目根目录下,执行命令收集所有包
pip freeze > plist.txt
-
通过ftp软件将开发好的项目上传到此服务器的某个目录
-
安装并创建虚拟环境,如果已有则跳过此步
#Ubuntu下的虚拟环境配置 sudo apt install virtualenv sudo apt install virtualenvwrapper ''' 默认virtualenvwrapper安装在/usr/local/bin下面, 需要运行virtualenvwrapper.sh文件才行;所以需要先进行配置一下环境变量: ''' #首先创建虚拟环境管理目录: mkdir $HOME/.local/virtualenvs #进入后,按i进入编译模式,末尾添加: export WORKON_HOME=$HOME/.virtualenvs source ~/.local/bin/virtualenvwrapper.sh #随后按esc进入命令模式,再按:进入底部命令行模式 #输入wq后敲回车,保存并退出。 #随后刷新环境变量 source ~/.bashrc #1.创建并激活虚拟环境 : mkvirtualenv 虚拟环境名称 (默认创建python2.7) #2.创建指定语言版本的虚拟环境 mkvirtualenv -p python语言版本的路径 虚拟环境的名称 mkvirtualenv -p /usr/bin/python3.5 虚拟环境的名称 #3、退出虚拟环境 : deactivate #4、继续使用之前的虚拟环境: workon 虚拟环境名称 #删除虚拟环境:rmvirtualenv 虚拟环境名称 #列出所有环境:workon 或者 lsvirtualenv –b
-
安装vsftpd
sudo apt install vsftpd #创建ftp用户 useradd -m ftpuser #设置密码 password ftpuser #修改ftpuser用户主目录设置读写权限 sudo chmod -R 777 /home/ftpuser #设置配置文件 vsftpd.conf local_enable=YES write_enable=YES local_umask=022 pam_service_name=ftp #此处不改会导致530登录失败 userlist_file=/etc/vsftpd.user_list userlist_enable=YES userlist_deny=NO
项目上传到Ubuntu/Linux服务器,客户端可以使用可视化软件 FlashFxp
-
WSGI
1.python manage.py runserver:这是一款适合开发阶段使用的服务器,不适合运行在真实的生产环境中 2.在生产环境中使用WSGI 3.WSGI:Web服务器网关接口,英文为Python Web Server Gateway Interface,缩写为WSGI,是Python应用程序或框 架和Web服务器之间的一种接口,被广泛接受 4.WSGI没有官方的实现, 因为WSGI更像一个协议,只要遵照这些协议,WSGI应用(Application)都可以在任何服务器 (Server)上运行 5.命令django-admin startproject会生成一个简单的wsgi.py文件,确定了settings、application对象 application对象:在Python模块中使用application对象与应用服务器交互 settings模块:Django需要导入settings模块,这里是应用定义的地方 6.此处的服务器是一个软件,可以监听网卡端口、遵从网络层传输协议,收发http协议级别的数
- uWSGI服务器,nginx服务器及静态文件的设置
1.uWSGI实现了WSGI的所有接口,是一个快速、自我修复、开发人员和系统管理员友好的服务器 2.uWSGI代码完全用C编写 #安装uWSGI pip install uwsgi #配置uWSGI,在项目中新建文件uwsgi.ini,编写如下配置 [uwsgi] socket=0.0.0.0:7000 #(使用nginx连接时,使用socket) http=0.0.0.0:7000 #(直接做web服务器,使用http) chdir=项目根目录(如:/home/ftpuser/demo2) wsgi-file=项目中wsgi.py文件的目录,相对于项目根目录(如:demo2/wsgi.py) processes=4 threads=2 master=True pidfile=uwsgi.pid daemonize=uswgi.log #启动: uwsgi --ini uwsgi.ini #停止: uwsgi --stop uwsgi.pid #重启: uwsgi --reload uwsgi.pid #使用http协议查看网站运行情况,运行正常,但是静态文件无法加载 # 启动Uwsgi服务器 #在uwsgi.ini 同级目录 uwsgi –ini uwsgi.ini 启动服务 ''' nginx 使用nginx的作用 负载均衡:多台服务器轮流处理请求 反射代理:隐藏真实服务器 实现构架:客户端请求nginx,再由nginx请求uwsgi,运行django框架下的python代码 nginx+uwsgi也可以用于其它框架的python web代码,不限于django 到官网下载nginx压缩文件或通过命令安装 ''' sudo apt install nginx #查看版本: sudo nginx -v #启动:sudo nginx #停止: sudo nginx -s stop #重启: sudo nginx -s reload #通过浏览器查看nginx运行结果 #指向uwsgi项目:编辑/etc/nginx/nginx.conf文件 1.在http目录下添加 server { listen 0.0.0.0:9000; location / { include uwsgi_params; uwsgi_pass 0.0.0.0:7000; } } 2.在server下添加新的location项,指向uwsgi的ip与端口 location /static { alias /home/ftpuser/demo2/staticfolder; } #修改完文件后重启uwsgi,nginx服务器 sudo nginx -s reload uwsgi --reload uwsgi.pid #但是 在uwsgi中关闭时,需要将文件 uwsgi.pid 中的进程号更改为uwsgi第一个进程的进程号,方便杀死该进程重启uwsgi,如果能正常关闭就不用这样。 #查看当前进程 ps -ef|grep uwsgi
-
静态文件
1. 静态文件一直都找不到,现在终于可以解决了
2. 所有的静态文件都会由nginx处理,不会将请求转到uwsgi
3. 配置nginx的静态项,打开nginx/nginx.conf文件,找到server,添加新location
location /static {
alias /home/ftpdir/test2/staticroot;
}
#在服务器上创建目录结构“/home/ftpdir/test2/staticroot”
#修改目录权限
sudo chmod 777 /home/ftpdir/test2/staticroot
#修改settings.py文件
STATIC_ROOT='/home/ftpdir/test2/staticroot'
STATIC_URL='/static/'
#收集所有静态文件到static_root指定目录:python manage.py collectstatic
#重启nginx、uwsgi
最后在Ubuntu系统下重启uwsgi和nginx,然后通过Windows客户端测试该网站,URL为Ubuntu的IP地址加入口路由。