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的模型,使其轻量 ...
随机推荐
- 大聊Python----Select解析
1.首先列一下,sellect.poll.epoll三者的区别 select select最早于1983年出现在4.2BSD中,它通过一个select()系统调用来监视多个文件描述符的数组,当sele ...
- vue清空input file
input file是只读的,给form一个id,用form.reset()干掉里面input的值 document.getElementById("uploadForm")&am ...
- js_判断当前url是否合法http(s)
alert(checkURL('http:555')); //false function checkURL(URL) { var str = URL, Expression = /http(s)?: ...
- android CVE 漏洞汇总
arm exploits 技术教程: Learning Pentesting for Android Devices CVE-2015-1530 ,CVE-2015-1474 两个android整数溢 ...
- WEB前端之HTML5~HTML5与HTML4的区别
推出的理由及目标 WEB浏览器存在的问题包括以下三点 世界知名浏览器厂商对HTML5的支持 语法的改变 DOCTYPE的声明 XHTML的DOCTYPE声明方式 HTML4的DOCTYPE声明方式 H ...
- JS实现全选与取消 Jquery判断checkbox是否被选中
1.JS实现checkbox全选与取消 <body> <input type="checkbox" name="select_all"/> ...
- P1968
题目背景 此处省略maxint+1个数 题目描述 在以后的若干天里戴维将学习美元与德国马克的汇率.编写程序帮助戴维何时应买或卖马克或美元,使他从100美元开始,最后能获得最高可能的价值. 输入输出格式 ...
- 阿里云Centos等更新源设置成阿里源方法。
https://help.aliyun.com/knowledge_detail/5974184.html ---------------------------------------------- ...
- js错误类型链接
https://my.oschina.net/u/1040928/blog/384318
- mysql:视图、触发器、事务、存储、函数、流程控制
阅读目录 一 视图 二 触发器 三 事务 四 存储过程 五 函数 六 流程控制 回到顶部 一 视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只 ...