flask环境布署--废弃不用,只留作备份
【前置条件】
创建1个flask-demo,生成requirement.txt文件(下载好gunicorn),上传至git。创建demo参照:创建一个flask api-demo(响应体显示中文)
git地址:https://github.com/wangju003/flaskDemo.git
先在本地试试用gunicorn启动falsk
在terminal中执行gunicorn命令通过wsgi文件启动flask:
gunicorn -w 4 -b 127.0.0.1:5000 wsgi:application
启动效果:
通过git将demo clone至centOS,项目目录建议放在 /home/www/(放在哪里不必纠结,因为最终会通过jenkins自动布署Job,所以项目会存放在/.jenkins目录下。这里只做测试gunicorn+nginx启动falsk)
【正式配置】
环境:centOS7
tips:如果安装其它环境,需要java环境,不需要特别安装jdk,使用自带的openJDK就可以。openJDK不能满足条件时,再安装jdk,且无须自自己配置环境变量(配置过,有印象是这样的)
step1:安装python3,pip3,python虚拟环境,我这些在之前环境布署之已经安装好,这里不再缀述。
具体搭建过程,参照:
centOS安装python3 以及解决 导入ssl包出错的问题
step2:
- 创建虚拟环境flaskApi
- 安装requirement.txt依赖(注意先切换到requirement.txt文件所在的目录)
- 安装gunicorn(之前在本地中已经安装,并导入到requirement.txt文件中,所以上面1小步已经完成gunicorn的安装了)
[root@67 flaskDemo]# mkvirtualenv flaskApi #创建虚拟环境
(flaskApi) [root@67 flaskDemo]# pip install -r requirements.txt#安装依赖
里程碑,通过gunicorn运行flask:
首先查看一下服务器的ip地址,记录下来:10.2.1.92
(flaskApi) [root@67 flaskDemo]# ifconfig
ens160: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 10.2.1.92 netmask 255.255.255.0 broadcast 10.2.1.255
通过gunicorn运行wsgi.py文件启动flask,ip地址用上一步查询得到的10.2.1.92,端口号指定为5000(自定义)
(flaskApi) [root@67 flaskDemo]# ls
app manage.py requirements.txt settings.py wsgi.py
(flaskApi) [root@67 flaskDemo]# gunicorn -w 4 -b 10.2.1.92:5000 wsgi:application
启动后:
(flaskApi) [root@67 flaskDemo]# gunicorn -w 4 -b 10.2.1.92:5000 wsgi:application
[2019-09-17 14:18:31 +0800] [8945] [INFO] Starting gunicorn 19.9.0
[2019-09-17 14:18:31 +0800] [8945] [INFO] Listening at: http://10.2.1.92:5000 (8945)
[2019-09-17 14:18:31 +0800] [8945] [INFO] Using worker: sync
[2019-09-17 14:18:31 +0800] [8948] [INFO] Booting worker with pid: 8948
[2019-09-17 14:18:31 +0800] [8949] [INFO] Booting worker with pid: 8949
[2019-09-17 14:18:31 +0800] [8950] [INFO] Booting worker with pid: 8950
[2019-09-17 14:18:31 +0800] [8952] [INFO] Booting worker with pid: 8952
打开网址验证一下:此时应该可以展示响应内容了:
step3:安装nginx
yum -y install nginx
遇到的问题:
提示没有可用的软件包
解决办法:
Centos 7下安装nginx,使用yum install nginx,提示没有可用的软件包
启动nginx
(flaskApi) [root@67 flaskDemo]# systemctl start nginx
遇到的问题:
1 Redirecting to /bin/systemctl start nginx.service
2 Job for nginx.service failed because the control process exited with error code. See "systemctl status nginx.service" and "journalctl -xe" for details.
解决办法:
centos7 ngxin启动失败:Job for nginx.service failed(80端口被占用的解决办法)
停止 nginx 服务
(flaskApi) [root@67 flaskDemo]# systemctl stop nginx
重启 nginx 服务
systemctl restart nginx
平滑启动:
nginx配置改动了,可以重新加载而不用先关闭再打开
nginx -s reload
启动后 ,在浏览器中 输入服务器的 ip 地址,就可以看到--记得加上指定nginx启动的端口号(我修改了nginx启动端口为8001)
http://10.2.1.92:8001
到这里 yum
安装 nginx
就完成了
step4:配置nginx
server {
listen 80 default_server;
listen [::]:80 default_server;
server_name gogotest.com;
root /usr/share/nginx/html; # Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf; location / {
proxy_pass http:/http://10.2.1.92:5000;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
里程碑:
配置好后打开本地浏览器,输入域名,应该就能访问了
step5:安装superversion
step6:配置superversion,注意command后的参数是,虚拟环境xxx,gunicorn的启动命令
里程碑:使用superversion启动gunicorn,输入配置地址可以正常访问
step7:安装fabric(不一定要配置吧?是不是可以用jenkins-webhoo提交代码就自动布署呢)可以体验一下看看
里程碑:
首先修改respone内容,然后在本地执行命令:fab deploy
然后访问测试网址,查看响应内容是不是更新了
明天从这里开始吧
https://pdf-lib.org/Home/Details/8536
现在的问题是在centos上通过gunicorn启动服务后,外网不能访问
现在试一下uwsgi的方式
https://www.jianshu.com/p/be2b587a900e
问题:
Failed to stop iptalbes.service: Unit iptalbes.service not loaded.
https://blog.csdn.net/c233728461/article/details/52679558
参考文档:
https://www.jianshu.com/p/da28ec28ef4b
https://www.cnblogs.com/mqxs/p/8706665.html(ip地址要写服务器地址的坑我踩过了)
[root@67 nginx]# nginx -t
nginx: [emerg] unexpected "}" in /etc/nginx/nginx.conf:51
nginx: configuration file /etc/nginx/nginx.conf test failed
[root@67 nginx]#
linux什么编辑器可以显示行号
Linux随笔 - vi/vim 编辑器显示行号
再次测试:
[root@67 nginx]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
flask环境布署--废弃不用,只留作备份的更多相关文章
- centOS7 flask项目布署
先用1张图表示centOS布署flask的关键点,以及可能遇到的问题,及解决办法. 图片看不清,可以[下载]下来看,清晰度能够看清字 [目标] 局域网内,通过url可以访问flask编写的api 更新 ...
- Docker集群实验环境布署--swarm【1 架构说明】
在读完<Docker技术入门与实践>这本书后,基本上已对Docker了有一些入门的理解,以及我们为什么要使用Docker 答:我们发现在实际工作中,通过openstack一旦把一个VM创建 ...
- Ubuntu 16.04环境布署小记
本系列文章记录了升级Ubuntu 16.04的布署过程 回到目录 10. 安装Mono, Xsp 当前版本16.04.1的系统源的Mono版本为4.2.1,如需使用最新版本(本文书写时稳定版本为4.6 ...
- Docker集群实验环境布署--swarm【5 容器启动组件--node】
10.40.100.143 docker-node0.venic.com 10.40.100.144 docker-node1.venic.com 原用swarm镜像 直接启动 1 ...
- Docker集群实验环境布署--swarm【7 让docker客户端支持docker-compose】
Docker-Compose是一个部署多个容器的简单但是非常必要的工具. 登录Docker客户端的服务器(默认是安装了docker-engine的服务器),再安装compose插件 # yum i ...
- Docker集群实验环境布署--swarm【6 配置上层Nginx代理,让任意Docker client访问得到高可用的管理API】
10.40.42.10上,也就是对应的VRRP中的10.40.42.1和2上,配置nginx tcp代理 # cat 4000_manager.venic.com_10.40.100.141-14 ...
- Docker集群实验环境布署--swarm【4 管理组件--manager】
主机分配如下,支持双活,中断其中1台,primary会通过consul自动重新选举 10.40.100.141 docker-manager0.venic.com 10.40.100.142 do ...
- Docker集群实验环境布署--swarm【3 注册服务监控与自动发现组件--consul】
参考官网集群配置方式 https://hub.docker.com/r/progrium/consul/ 集群中需要manager与node能通信consul的发现服务,不然,管理节点选举不了,无 ...
- Docker集群实验环境布署--swarm【2 搭建本地镜像仓库】
在10.40.100.148上 # docker run -d -p 5000:5000 --restart=always --name docker-registry.venic.com - ...
随机推荐
- Delphi上机步骤
- python之同步IO和异步IO
linux操作系统基础知识 用户空间和内核空间 操作系统的核心是内核,独立于普通的应用程序,可以访问受保护的内存空间,也有访问底层硬件设备的所有权限.为了保证用户进程不能直接操作内核保证内核的安全,操 ...
- c语言获取系统时间并格式化
// #include <time.h> int GetAndFormatSystemTime(char* timeBuff) { if (timeBuff == NULL) { retu ...
- ip addr详解
Windows上查看IP地址是ipconfig, Linux上是ifconfig,但是Linux上还有一个命令叫ip addr可以查看IP地址. ip addr : lo: <LOOPBACK, ...
- ESP8266---TCP Client
ESP8266WiFi库里面还有其他重要内容,比如跟http相关的 WiFiClient.WiFiServer,跟https相关的 WiFiClientSecure.WiFiServerSecure ...
- 基于gtid复制主要操作记录
基于gtid复制主要操作记录 一.安装系统依赖包 在主从上都要安装该依赖包. yum -y install perl-DBI yum -y install perl-DBD-MySQL yum -y ...
- 【NOIP2016提高A组模拟8.17】(雅礼联考day1)Value
题目 分析 易证,最优的答案一定是按\(w_i\)从小到大放. 我们考虑dp, 先将w从小到大排个序,再设\(f_{i,j}\)表示当前做到第i个物品,已选择了j个物品的最大值.转移就是\[f_{i, ...
- nodejs中 require 方法的加载规则
require参数类型 http.fs.path等,原生模块 ./mod或../mod,相对路径的文件模块 /pathtomodule/mod,绝对路径的文件模块 mod,非原生模块的文件模块 在进 ...
- scipy.sparse 稀疏矩阵
from 博客园(华夏35度)http://www.cnblogs.com/zhangchaoyang 作者:Orisun 本文主要围绕scipy中的稀疏矩阵展开,也会介绍几种scipy之外的稀疏矩阵 ...
- less中的for循环
.loop(@count) when (@counter > 0) { .loop((@counter - 1)); // 递归调用自身 width: (10px * @count ...