flask项目实现自动化部署

2019-03-21  本文已影响0人  风居住的街道_83df

Flask的优点:

1.简单。flask是主要应对小型或者快速构建的项目,故没有像Django那样大而全,集成了很多的组件,不管你是否用没用得到。如果说Django是一个精装的房子,那么flask就是毛培房。使用Django的项目,大部分的布局等都是相似的,因为已经装修完毕了,大同小异。而使用flask的话,如何装修,如何设计都是自己搞定的,所以每个flask项目的相异性较大。

2.使用简单。官方的使用指南清晰的介绍了Flask的运行过程。官方指南(中文版)

3.部署简单。本地运行不需要安装其他的软件,只需要python基本的环境(一般来说:本地测试直接运行即可)。如需要在服务器上运行,以支撑起整个项目,则需要配置uwsgi+nginx。因为需要考虑到并发性、异步性(尽管可以在启动run()里加入一些参数实现异步)。

Flask的安装

Flask安装教程(包含多种安装方式),建议不要直接pip,而是先安装:虚拟环境创建工具virtualenv,为每一个项目创建一个虚拟环境,这样不会引起版本冲突。

pip install virtualenv  ---安装虚拟环境

cd your_project_dir  ---进入你的项目目录

virtualenv  venv---创建目录名(自定义),在venv文件夹中,包含了python的可执行文件,以及pip库的拷贝,这样就可以安装flask包了,前提是激活该项目的虚拟环境,否则还是会安装在系统环境下

source venv/bin/activate   ---激活虚拟环境

服务器上配置:

uwsgi+nginx配置,如果不使用Nginx也是可以实现项目的运行支撑的,但是Nginx可以保证负载均衡(如果有多个运行项目的话)以及安全性。一般配置nginx作为前端代理,uwsgi作为后端代理,其实这样称呼并不准确,但只是相对的。nginx用来处理静态请求,若是动态请求由nginx转发至uwsgi进行处理。具体作用见:NgInx的作用

先安装uwsgi,可直接pip系统安装,或者在虚拟环境中安装;

pip install uwsgi 

        在你的项目根目录下创建一个uwsgiconfig.ini(uwsgi支持多种配置文件格式:ini、xml、json等),其实不是必须在根目录下创建,只要能找到该文件并启动即可,在根目录下创建是方便修改。

Nginx安装:参考:nginx安装及基本操作语法

        nginx的配置文件:可能存在大量的注释,我们需要放开注释并且可能进行修改;这里就不全部显示了,仅介绍主要的配置:

        只要我们把代码上传到服务器上,运行uwsgiconfig.ini文件,即可让我们的flask项目运行,并能向前提供服务。但在开发过程中,我们每次修改代码或者新增功能并且在本地测试好了之后,想要通过公网访问我们的修改的或者新增的功能,就得把当前改变上传到服务器上,并且重新启动uwsgi服务器。这样每次代码有改动,都得先上传到服务器,再重新启动uwsgiconfig.ini文件,很是麻烦,所以我们期望找到一种自动化的工具,能帮我们自动上传代码,重新启动uwsgi服务器,jenkins就是我们所需要的工具。

代码托管平台:github、coding、Bitbucket等:

       也就是将你的项目放在托管平台上进行托管,方便协作开发,代码集成。这里是用了coding做说明,后面将说明coding的一些配置。

jenkins持续集成:

 jenkins安装配置

注意jenkins是基于java的,所以需要jdk环境并且在jenkins配置文件中设置。

service jenkins start   ---启动jenkins 

在浏览器输入  http://公网ip: 8080 (默认)访问jenkins页面(php界面)。

1.安装jenkins需要的插件: 系统管理->插件管理->可选插件->右上角搜索:

    coding_webhook插件通过与coding上的项目的hook建立链接,当coding上代码有更新时,jenkins也会进行更新;publish_over_ssh插件是用来实现远程部署。

2.系统配置:

          首先,在服务器上生成公钥:ssh-keygen -t rsa  ;按3个回车,密码为空。默认会在 ~/.ssh目录生成两个文件: id_rsa私钥,id_rsa.pub公钥。known_hosts文件会记录ssh密钥登陆的主机列表。

          接着,在系统管理->系统配置的publish_over_ssh中:

       在remote_directory下面的高级中:

然后保存即完后ssh的配置;

构建项目:

新建任务->:

基础设置:

源码管理:

触发器构建:

触发器构建时,需要配置coding上的webhook:

触发器设置:

构建环境:不做任何改变

构建:

选择增加构建后操作,方式选择SSH,目的是为了让服务器重启uwsgiconfig.ini文件,实现自动化部署。

最后保存即可;

run.sh脚本说明:

到此,你的代码在托管工具coding上更新之后,会通知绑定的jenkins,jenkins一并更新,并上传到服务器指定目录,最后通过执行脚本重启uwsgi服务器,实现自动化部署。

注意事项:

        flask项目的启动文件的应用变量中的参数应该设置0.0.0.0或者不设置,也不要设置成调试模式,否则公网可能访问不到;(这里没有去了解参数设置,仅仅是随便看了网上的一些解决方法照搬的);

        服务器上也要安装git,同时在jenkins全局工具管理中配置;

        首次登录jenkins之后密码可能会消失,如果你记不得了的话,按照这个方法进行重新配置;管理员密码重置

        如果自动化部署没问题,代码在本地也没问题,上传上去发现项目运行报错,排除bug等原因。那么可能是py包的问题,我就遇到了包的版本问题,最后发现是pymongo的2.8之前不兼容;

        在uwsgi配置中你指定的运行日志文件中,可以看到报错的信息,shift+g可以跳转到底部查错;

        时间过得有点久了,所以可能一些细节没解释清楚或者错了,但总体方向还是对的,希望大家不要建议。


上一篇下一篇

猜你喜欢

热点阅读