开发指南090-使用python做微服务

平台的后台涉及到业务部分的使用java开发,基于springcloud。

涉及到大数据、AI、网页爬虫等领域的使用python开发。

使用python开发微服务过程如下:

1、读取bootstrap.yaml配置

def read_yaml(file):

'''读取配置文件'''

with open(file, 'r', encoding='utf-8') as f:

return yaml.load(f.read(), Loader=yaml.FullLoader)

2、从nacos中获取配置

def get_conf(config_dict):

'''

从naocs上获取配置信息,将配置变量声明为全局变量,供调用

:return: dict配置信息

'''

global nacos_conf

config_server = config_dict['server']

client = nacos.NacosClient(config_server['address'], namespace=config_server['namespace'])

nacos_conf = client.get_config(data_id=config_server['dataid'], group=config_server['group'])

nacos_conf = yaml.load(nacos_conf, Loader=yaml.FullLoader)

return nacos_conf

3、启动后注册服务

def regis_server_to_nacos(config_dict):

'''注册服务到nacos'''

config_server = config_dict['server']

client = nacos.NacosClient(config_server['address'], namespace=config_server['namespace'])

client.add_naming_instance(config_server['name'], ip=IOUtil.getHost(), port=config_server['port'], cluster_name=None, weight=1, metadata=None, enable=True, healthy=True, ephemeral=False, group_name=config_server['group'])

4、接口服务(引入swagger)

from flask import Flask, request, jsonify

app = Flask(name)

swagger = Swagger(app)

@app.route('/QLM-Scrapping/scrapSingleTask/<task_id>', methods=['POST', 'GET'])

@swag_from('scrapSingleTask.yaml')

def get_scrape_single_task(task_id):

5、访问数据库

import pymysql

config = nacos_conf['mysql']

conn = pymysql.connect(

host=config['host'],

port=config['port'],

user=config['user'],

password=config['password'],

db=config['db'],

charset='utf8',

autocommit=True, # 如果插入数据,, 是否自动提交? 和conn.commit()功能一致。

)

cur = conn.cursor()

cur.execute(sql)

相关推荐
礼拜天没时间.1 小时前
Docker与Harbor迁移实战:从入门到生产级完整指南
linux·运维·docker·容器·架构·centos
黄俊懿2 小时前
【架构师从入门到进阶】第一章:架构设计基础——第二节:架构设计原则
分布式·后端·中间件·架构
技术传感器2 小时前
赋能智慧空间:看本体论如何破解城市更新运营难题
人工智能·深度学习·架构
小冷coding2 小时前
【项目】医疗数字化升级:基于Spring生态的合规化微服务架构实践
spring·微服务·架构
wzqllwy3 小时前
深入剖析微服务架构与 Spring Cloud
spring cloud·微服务·架构
蚂蚁百宝箱4 小时前
首个混合线性架构的万亿参数思考模型Ring-2.5-1T上线,百宝箱 Tbox 邀您体验!
架构
匀泪4 小时前
云原生(nginx实验(1))
nginx·云原生
利刃大大5 小时前
【SpringCloud】Nacos简介 && 安装 && 快速入手 && 负载均衡
spring·spring cloud·微服务·nacos·负载均衡
乾元5 小时前
提示词注入:针对 LLM 的 SQL 注入式攻击分析
运维·人工智能·安全·网络安全·架构·系统架构·自动化
一个骇客5 小时前
单领导者复制:数据库里的“只有一个话事人”
架构