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的模型,使其轻量 ...
随机推荐
- Bzoj4873 [SXOI2017]寿司餐厅
Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 64 Solved: 45 Description Kiana最近喜欢到一家非常美味的寿司餐厅用餐.每 ...
- 【BZOJ】1954: Pku3764 The xor-longest Path
[算法]trie树+xor路径 [题解] 套路1:统计从根到每个点的xor路径和,由于xor的自反性,两个点到根的xor路径和异或起来就得到两点间路径和. 然后问题就是找到n个值中异或值最大的两个值, ...
- 【BZOJ】1486 [HNOI2009]最小圈
[算法]二分+spfa [题解]据说这个叫分数规划? 0-1分数规划 二分答案a,则对于任意的环有w/k≤a即w-ak≤0,若满足条件则a变小,否则a变大. 因为w=w1+w2+...+wk,所以变形 ...
- sumblime快捷键
原文地址:https://blog.csdn.net/shutfuckingup/article/details/23846603 Ctrl+D 选词 (反复按快捷键,即可继续向下同时选中下一个相同的 ...
- 跨域iframe高度计算
一.同域获取iframe内容 这里有两个细节: 1. 取iframe内的文档对象,标准浏览器使用contentDocument属性,IE低版本(IE6,7,8)使用document属性. 2. cal ...
- Linking code for an enhanced application binary interface (ABI) with decode time instruction optimization
A code sequence made up multiple instructions and specifying an offset from a base address is identi ...
- device tree 負值 property 寫法
倘若你要設定 負值的property, 可能需要括符才會 build 過. 正確 decidegc = <(-10)>; 錯誤 decidegc = <-10>;
- mysql utf8改utf8mb4
由于需要用到utf8mb4,之前是utf8现在给改成utf8mb4 查看当前环境 SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' ...
- [How to] 真机调试
1.简介 真机调试介绍. 在xcode7之前需要每年99刀的代价才能活着开发者权限并能够在真机上调试,现在如果单纯的想在真机上调是就不必花这个钱了. 2.步骤 完毕.
- IE11中实现颜色渐变
background: -ms-linear-gradient(left,#daa23e,#ad7f27); 下面是css3中颜色渐变对各个浏览器的写法:background: -webkit-lin ...