Flask实战第68天:项目上线部署
在开发机上的准备工作
1、确认项目没有bug
2、用pip freeze >requirements.txt将当前环境的包导出到requirements.txt文件中,方便部署的时候安装

3、将dysms_python文件准备好。因为短信验证码的这个带服务器需要手动安装
4、在https://git-scm.com/downloads下载Windows版本的客户端。然后双击一顿点击下一步安装即可
5、然后使用码云或者自己搭建gitlab,创建一个仓库
6、进入项目,使用以下命令做代码提交
git init
git remote add origin xxx.git
git add .
git commit -m 'first commit'
git pull origin master --allow-unrelated-histories
git push origin master
服务器上的准备工作
安装好项目用到的Python
sudo apt install python3
sudo apt install python3-pip
pip3 install --upgrade pip
安装virtualenv以及virutalenvwrapper。并创建虚拟环境
pip3 install virtualenv
pip3 install virtualenvwrapper
sudo apt install vim
vim ~/.bashrc 进入文件中,填入以下两行代码
export WORKON_HOME=$HOME/.virtualenvs
source /usr/local/bin/virtualenvwrapper.sh
创建虚拟环境
mkvirtualenv --python=/usr/bin/python3 zlbbs-env
安装git
sudo apt install git
安装MySQL服务器和客户端
> sudo apt install mysql-server mysql-client
> sudo apt-get install libmysqld-dev
进入虚拟环境中,然后进入到项目所在目录,执行命令:pip install -r requirements.txt,安装好相应的包
在mysql数据库中,创建相应的数据库。
执行python manage.py db upgrade命令,将迁移文件,映射到数据库中,创建相应的表。
执行python zlbbs.py,然后在你自己电脑上,在浏览器中输入http://你的服务器的ip地址:8000/,访问下网站所有页 面,确保所有页面都没有错误。
设置DEBUG=False,避免如果你的网站产生错误,而将错误信息暴漏给用户
安装uwsgi
uwsgi是一个应用服务器,非静态文件的网络请求就必须通过他完成,他也可以充当静态文件服务器,但不是他的强项。uwsgi是使用python编写的,因此通过pip install uwsgi就可以了。(uwsgi必须安装在系统级别的Python环境中,不要安装到虚拟环境中)。
使用命令uwsgi --http :8000 --wsgi-file /opt/zlbbs/zlbbs.py -callable app -H /root/.virtualenvs/zlbbs-env。用uwsgi启动项目,如果能够在浏览器中访问到这个页面,说明uwsgi可以加载项目了
编写uwsgi配置文件
[uwsgi] # Django相关的配置
# 必须全部为绝对路径
# 项目的路径
chdir = /srv/zlbbs
# 模块
module = zlbbs
# Python虚拟环境的路径
home = /root/.virtualenvs/zlbbs-env # 进程相关的设置
# 主进程
master = true
# 最大数量的工作进程
processes =
# socket文件路径,绝对路径
socket = /srv/zlbbs/zlbbs.sock
# wsgi文件
wsgi-file = /srv/zlbbs/wsgi.py
# wsgi文件的app变量
callable = app
# 设置socket的权限
chmod-socket =
# 退出的时候是否清理环境
vacuum = true
然后使用命令uwsgi --ini zlbbs_uwsgi.ini,看下是否还能启动这个项目
安装nginx
nginx是一个web服务器。用来加载静态文件和接收http请求的。通过命令sudo apt install nginx即可安装。
nginx常用命令:
启动nginx:service nginx start
关闭nginx:service nginx stop
重启nginx:service nginx restart
编写nginx配置文件
在/etc/nginx/conf.d目录下,新建一个文件,叫做zlbbs.conf,然后将以下代码粘贴进去:
upstream zlbbs {
server unix:///srv/zlbbs/zlbbs.sock;
}
# 配置服务器
server {
# 监听的端口号
listen ;
# 域名
server_name 192.168.0.101;
charset utf-;
# 最大的文件上传尺寸
client_max_body_size 75M;
# 静态文件访问的url
location /static {
# 静态文件地址
alias /srv/zlbbs/static;
}
# 最后,发送所有非静态文件请求到django服务器
location / {
uwsgi_pass zlbbs;
# uwsgi_params文件地址
include /etc/nginx/uwsgi_params;
}
}
写完配置文件后,为了测试配置文件是否设置成功,运行命令:service nginx configtest,如果不报错,说明成功。
每次修改完了配置文件,都要记得运行service nginx restart
使用supervisor配置
让supervisor管理uwsgi,可以在uwsgi发生意外的情况下,会自动的重启
supervisor的安装:在系统级别的python环境下pip install supervisor。
在项目的根目录下创建一个文件叫做zlbbs_supervisor.conf。内容如下
# supervisor的程序名字
[program:zlbbs]
# supervisor执行的命令
command=uwsgi --ini zlbbs_uwsgi.ini
# 项目的目录
directory = /srv/zlbbs
# 开始的时候等待多少秒
startsecs=
# 停止的时候等待多少秒
stopwaitsecs=
# 自动开始
autostart=true
# 程序挂了后自动重启
autorestart=true
# 输出的log文件
stdout_logfile=/srv/zlbbs/log/supervisord.log
# 输出的错误文件
stderr_logfile=/srv/zlbbs/log/supervisord.err [supervisord]
# log的级别
loglevel=info # 使用supervisorctl的配置
[supervisorctl]
# 使用supervisorctl登录的地址和端口号
serverurl = http://127.0.0.1:9001 # 登录supervisorctl的用户名和密码
username = admin
password = [inet_http_server]
# supervisor的服务器
port = :
# 用户名和密码
username = admin
password = [rpcinterface:supervisor]
supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface
然后使用命令supervisord -c zlbbs_supervisor.conf运行就可以了。
以后如果想要启动uwsgi,就可以通过命令supervisorctl -c supervisor.conf进入到管理控制台,然后可以执行相关的命令进行管理:
status # 查看状态
start program_name #启动程序
restart program_name #重新启动程序
stop program_name # 关闭程序
reload # 重新加载配置文件
quit # 退出控制台
Flask实战第68天:项目上线部署的更多相关文章
- 玩转Django2.0---Django笔记建站基础十二(Django项目上线部署)
第十二章 Django项目上线部署 目前部署Django项目有两种主流方案:Nginx+uWsGI+Django或者Apache+uWSGI+Django.Nginx作为服务器最前端,负责接收浏览器的 ...
- 如何将java web项目上线/部署到公网
关于如何将java web上线,部署到公网,让全世界的人都可以访问的问题. 1.在myeclipse中开发好项目,打包成war格式,不会的同学参考以下 http://zhidao.baidu.com/ ...
- 记录一次java项目上线部署
环境 操作系统:CentOS Linux release 8.0.1905 数据库:mariadb10.3.17 安装数据库 yum install -y mariadb mariadb-server ...
- java项目上线的流程(将web项目部署到公网)
本博文来源于网络,原文的地址在本篇博文最下方. 如何将java web项目上线/部署到公网 关于如何将Java Web上线,部署到公网,让全世界的人都可以访问的问题.小编将作出系列化,完整的流程介绍. ...
- Jenkins持续集成企业实战系列之两种网站部署的流程-----01
注:原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任. 最初接触Jenkins也是由于公司需求,根据公司需求Java代码项目升级的.(公司是 ...
- Flask实战-留言板-安装虚拟环境、使用包组织代码
Flask实战 留言板 创建项目目录messageboard,从GreyLi的代码中把Pipfile和Pipfile.lock文件拷贝过来,这两个文件中定义了虚拟环境中需要安装的包的信息和位置,进入m ...
- django项目上线环境部署
django项目上线环境部署 第一步 安装python虚拟环境 1 安装虚拟环境virtualenv 2 安装virtualenvwrapper工具 3 确认virtualenvwrapper.sh脚 ...
- Yum项目上线实战 (网站运维)-Linux从入门到精通第十一天(非原创)
文章大纲 一.编译安装与卸载Nginx二.关于LAMP三.LAMP环境部署四.学习资料下载五.参考文章 一.编译安装与卸载Nginx Nginx:是一款比较流行的web服务器软件,类似于Apach ...
- Vue项目上线环境部署,项目优化策略,生成打包报告,及上线相关配置
Node.js简介 Node.js是一个基于Chrome V8引擎的JavaScript运行环境,用来方便快速地搭建易于扩展的网络应用.Node.js使用了一个事件驱动.非阻塞式I/O的模型,使其轻量 ...
随机推荐
- Gulp、Grunt构建工具
在Gulp中创建一个库从磁盘gulp.src读取源文件并通过磁盘管道写回内容到gulp.dest,可以理解成只是将文件复制到另一个目录. var gulp = require('gulp'); gul ...
- Python 对象的深拷贝与浅拷贝 -- (转)
本文内容是在<Python核心编程2>上看到的,感觉很有用便写出来,给大家参考参考! 浅拷贝 首先我们使用两种方式来拷贝对象,一种是切片,另外一种是工厂方法.然后使用id函数来看看它们的标 ...
- adb端口被占用解决
解决ADB端口占用问题 方式一5037为adb默认端口,若5037端口被占用,查看占用端口的进程PIDC:\Users\wwx229495>netstat -aon|findstr 5037 ...
- Ubuntu 14.04 ThinkPad E431无线网卡驱动安装
Ubuntu 14.04下安装无线网卡驱动. sudo apt-get install linux-headers-generic build-essential dkms sudo apt-get ...
- java===编译引用第三方文件的类(原创)
http://blog.csdn.net/m53931422/article/details/42174609 http://blog.csdn.net/u012450329/article/deta ...
- MVC使用Newtonsoft无需实体类,实现JSON数据返回给前端页面使用
//引用using Newtonsoft.Json; using Newtonsoft.Json.Linq; public ActionResult JsonSample() { ResponseRe ...
- yii2 一对多关系的对分页造成的影响
下面代码中关联descies时,匹配较多,造成分页数不对,需要加条件限制: $model = User::find() ->joinWith('app') ->joinWith(['des ...
- position:fixed部分版本的浏览器不支持
ie6-ie8浏览器不支持这个属性 .fixed{ position:fixed; /*对于火狐等其他浏览器需要设置的*/ top:700px; /*同上*/ ...
- MYSQL表中向SET类型的字段插入值时值之间不能有空格
MYSQL 中有一种数据类型是 SET,首先我们查看一个包含 SET 类型字段的表结构: 接下来我们向表中插入数据: 按照上面的语句插入数据发现报错了,于是去掉了插入值之间的空格,然后插入成功:
- MiCode 40: 找小“3”
题目链接 这道题真的是zjb恶心, 看其起来像是个数位dp, 然而我并不会数位dp.然后就xjb乱写了个雷类似于动态规划的玩意, 然后调出了\(9\times 9 = 81\)种Bug, 终于过了. ...