当前位置:   article > 正文

python的flask微服务-flask微服务框架的初步接触

python flask微服务

测试2个关联的系统接口时,经常会遇到被测试系统或被测app的处理内部处理流程会依赖另一个系统的接口返回结果,这时,

常用的做法就是写一个模拟测试桩,用作返回请求时的结果。java可以用servicelet来实现,而python可以使用flask这个框架来实现,

并且,实现起来也比java相对简单一些。

编程语言的永远第一个示例,hello world

from flask import Flask, request    #安装 flask和flask_restful 包

from flask_restful import Api, Resource

app=Flask(__name__) #实例化,__name__为系统变量

api=Api(app) #restful API的固定写法

class HiWorld(Resource): #创建一个类,并继承flask_restful.Resource;定义为一个资源

def get(self):

return {"Hello":"World"}

api.add_resource(HiWorld,"/Hello_World/a") #将HiWorld类作为数据资源加入到api,"/Hello_World’为请求资源地址

if __name__=="__main__":

app.run(host="0.0.0.0",port="8585",debug=True) #host="0.0.0.0"表示开放其他机器访问权限,debug=True表示打印调试日志,port为访问端口号

#请求默认地址http://127.0.0.1:5000

示例二:多个请求资源

from flask import Flask

from flask_restful import Api,Resource,reqparse,abort

app=Flask(__name__)

api=Api(app)

todos={

"todo1":{"task":"welcome"},

"todo2":{"task":"to"},

"todo3":{"task":"school"}

}

def abort_if_todo_unexist(todo_id): #请求的资源不在todos变量中,返回404

if todo_id not in todos:

abort(http_status_code=404,message="todo{}doesn"t exsit".format(todo_id)) #abort提前退出请求,并返回http状态码404

parser=reqparse.RequestParser() #解析url中参数

parser.add_argument("task",type=str)

#todo

class Todo(Resource):

def get(self,todo_id): #请求时get的方法,根据url中参数获取资源

abort_if_todo_unexist(todo_id)

return todos[todo_id]

def delete(self,todo_id): #请求时delete的方法,根据url中参数删除资源

abort_if_todo_unexist(todo_id)

del todos[todo_id]

return "",204

def put(self,todo_id): #请求时put的方法,根据url中参数修改资源

args=parser.parse_args()

task={"task":args["task"]}

todos[todo_id]=task

return task,201

#todolist

class Todolist(Resource):

def get(self): #请求时get的方法,url没有带参数时,返回所有变量todos的值

return todos

def post(self): #请求时post的方法,url没有带参数时,新增todos[todo_id]的值

args=parser.parse_args()

todo_id=int(max(todos.keys()).lstrip("todo"))+1

todo_id="todo%i"%todo_id

todos[todo_id]={"task":args["task"]}

return todos[todo_id],201

api.add_resource(Todolist,"/todos/")

api.add_resource(Todo,"/todos/") #为传入的参数

if __name__=="__main__":

app.run(host="0.0.0.0",port="8585",debug=True)

基于.NET CORE微服务框架 -谈谈surging API网关

1.前言 对于最近surging更新的API 网关大家也有所关注,也收到了不少反馈提出是否能介绍下Api网关,那么我们将在此篇文章中剥析下surging的Api 网关 开源地址:https://git ...

spring cloud 入门,看一个微服务框架的「五脏六腑」

Spring Cloud 是一个基于 Spring Boot 实现的微服务框架,它包含了实现微服务架构所需的各种组件. 注:Spring Boot 简单理解就是简化 Spring 项目的搭建.配置.组 ...

从 Spring Cloud 看一个微服务框架的「五脏六腑」

原文:https://webfe.kujiale.com/spring-could-heart/ Spring Cloud 是一个基于 Spring Boot 实现的微服务框架,它包含了实现微服务架构 ...

go微服务框架go-micro深度学习(一) 整体架构介绍

产品嘴里的一个小项目,从立项到开发上线,随着时间和需求的不断激增,会越来越复杂,变成一个大项目,如果前期项目架构没设计的不好,代码会越来越臃肿,难以维护,后期的每次产品迭代上线都会牵一发而动全身.项目 ...

微服务框架go-micro

微服务框架go-micro https://www.cnblogs.com/li-peng/p/9558421.html 产品嘴里的一个小项目,从立项到开发上线,随着时间和需求的不断激增,会越来越复杂 ...

Dubbo Ecosystem - 从微服务框架到微服务生态

从微服务框架到微服务生态,这是微服务发展的必然趋势,也是Dubbo社区满足开发者更高效的构建微服务体系期望的使命和担当. 近期,Apache Dubbo PPMC 望陶(社区昵称:ralf0131)做 ...

# go微服务框架kratos学习笔记六(kratos 服务发现 discovery)

目录 go微服务框架kratos学习笔记六(kratos 服务发现 discovery) http api register 服务注册 fetch 获取实例 fetchs 批量获取实例 polls 批 ...

微服务框架Demo.MicroServer运行手册

一.背景说明: 之前分享过一个微服务开发框架, "享一个集成.NET Core+Swagger+Consul+Polly+Ocelot+IdentityServer4+Exceptionle ...

基于thrift的微服务框架

前一阵开源过一个基于spring-boot的rest微服务框架,今天再来一篇基于thrift的微服务加框,thrift是啥就不多了,大家自行百度或参考我之前介绍thrift的文章, thrift不仅支 ...

随机推荐

JavaScript toFixed function Not Rouding

JavaScript库函数toFixed用来将给定的数字四舍五入为指定的小数位数,W3school上有详细的介绍.众所周知,在处理小数位四舍五入的时候存在两种方式:一种是逢五进一,如5.885保留两位 ...

centos下的mysql安装

卸载mysql yum remove mysql mysql-server mysql-libs compat-mysql51 rm -rf /var/lib/mysql rm /etc/my.cnf ...

《Android开发艺术探索》读书笔记 (4) 第4章 View的工作原理

本节和中的第3章Android控件架构与自定义控件详解有关系,建议先阅读该章的总结 第4章 View的工作原理 4.1 初始ViewRoot和DecorView ( ...

Find a way (BFS)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2612 BFS搜索  目标地  并记录下来  之后再判断两段路程之和 代码: #include < ...

秒懂ASP.NET中的内置对象

上篇博客,小编主要简单的介绍了一下ASP.NET中的控件,这篇博客,小编主要简单总结一下ASP.NET中的内置对象,七个内置对象分别是:Request.Response.Application.Coo ...

C#程序代码中常用的快捷键

C#中的快捷键,可以更方便的编写代码 //CTRL + SHIFT + B 生成解决方案 //CTRL + F7 生成编译 //CTRL + O 打开文件 //CTRL + SHIFT + O 打开项 ...

python 中间件

中间件一.什么是中间件 中间件是一个用来处理Django的请求和响应的框架级别的钩子.它是一个轻量.低级别的插件系统,用于在全局范围内改变Django 的输入和输出.每个中间件组件都负责做一些特定的功 ...

分布式监控系统Zabbix--完整安装记录-批量添加主机和自动发现端口

一.Zabbix-3.0.3批量添加主机的配置如下: 0)被监控机上要安装zabbix_agent,并配置好zabbix_agentd.conf (如下172.29.8.50是zabbix_serve ...

python3 asyncio官方文档中文版

事件循环基类 事件循环基类 事件循环是由asyncio提供的核心执行装置.它提供了多种服务,包括: 注册.执行和关闭延时调用(超时) 为各种通信创建客户端和服务端传输 为一个外部程序通信启动子进程和相 ...

Carte作为Windows服务

有一些用例将Carte作为Windows服务运行: 当使用命令窗口运行Carte实例时,任何人都会错误地关闭实例并且Carte将关闭. Carte.bat命令窗口与调用批处理文件的用户会话相关联,需要 ...

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家小花儿/article/detail/185746?site
推荐阅读
相关标签
  

闽ICP备14008679号