杭州网站建设公司电话微信公众号可以做微网站

张小明 2026/3/2 18:19:04
杭州网站建设公司电话,微信公众号可以做微网站,徐州市政工程招标信息,个人养老保险怎么买文章目录 《MongoDB实战入门》第12章 测试与部署:从开发到生产(python实战完善版) 12.1 MongoDB单元测试 12.1.1 环境准备 12.1.2 核心代码实现(覆盖CRUD+聚合+事务) 第一步:编写待测试的MongoDB业务操作类 第二步:编写单元测试用例 第三步:运行单元测试 12.2 生产环境…文章目录《MongoDB实战入门》第12章 测试与部署:从开发到生产(python实战完善版)12.1 MongoDB单元测试12.1.1 环境准备12.1.2 核心代码实现(覆盖CRUD+聚合+事务)第一步:编写待测试的MongoDB业务操作类第二步:编写单元测试用例第三步:运行单元测试12.2 生产环境部署最佳实践12.2.1 环境变量配置(区分开发/测试/生产)方案1:本地开发/测试环境(使用.env文件)方案2:生产环境(系统环境变量配置)12.2.2 安全配置实操1. 开启MongoDB认证模式(服务端配置)2. 创建权限隔离的MongoDB用户3. 限制IP访问(防火墙层面)12.2.3 数据备份与恢复实战(python+Shell)1. 定时备份脚本(python实现)2. 设置定时备份(crontab)3. 数据恢复脚本(python实现)4. 恢复命令使用示例12.3 基础监控12.3.1 MongoDB内置监控工具(mongostat/mongotop)1. mongostat:实时监控全局运行状态基本使用命令(生产环境带认证)核心指标解读(重点关注)2. mongotop:实时监控集合级读写耗时基本使用命令(生产环境带认证)12.3.2 python自定义监控脚本(采集核心指标)后台运行监控脚本总结《MongoDB实战入门》第12章 测试与部署:从开发到生产(python实战完善版)本章聚焦MongoDB从开发测试到生产落地的全流程python实操,补充可直接复用的代码示例,确保每个技术点都能落地执行,核心围绕单元测试、生产部署、监控运维三大模块展开。12.1 MongoDB单元测试单元测试的核心目标是脱离真实MongoDB服务依赖,通过模拟环境验证数据操作逻辑的正确性,避免测试污染真实业务数据,python生态中常用pytest(测试框架)+mongomock(MongoDB模拟工具)实现该需求。12.1.1 环境准备首先安装所需依赖包:pipinstallpytest mongomock pymongo python-dotenv12.1.2 核心代码实现(覆盖CRUD+聚合+事务)第一步:编写待测试的MongoDB业务操作类创建mongodb_service.py,封装核心业务操作:# mongodb_service.pyfrompymongoimportMongoClientfromdatetimeimportdatetimefromtypingimportList,Dict,Optional,UnionclassMongoDBBusinessService:"""MongoDB业务操作封装类,包含CRUD、聚合、事务等核心操作"""def__init__(self,mongo_client:MongoClient,db_name:str="business_db"):self.db=mongo_client[db_name]self.collection=self.db["user_orders"]# 订单业务集合# 新增数据(C):创建订单defcreate_order(self,order_info:Dict)-str:""" 创建订单 :param order_info: 订单信息字典,必须包含user_id、order_amount字段 :return: 新增订单的ID字符串 :raises ValueError: 缺少必填字段时抛出异常 """required_fields=["user_id","order_amount"]ifnotall(fieldinorder_infoforfieldinrequired_fields):raiseValueError("订单信息缺少必填字段(user_id/order_amount)")# 补充默认字段order_info.update({"create_time":datetime.now(),"order_status":"pending","update_time":datetime.now()})result=self.collection.insert_one(order_info)returnstr(result.inserted_id)# 查询数据(R):按用户ID查询订单defget_orders_by_user(self,user_id:str,limit:int=10)-List[Dict]:""" 按用户ID查询订单列表 :param user_id: 用户唯一标识 :param limit: 返回订单数量上限 :return: 订单列表(去除_id字段) """query={"user_id":user_id}projection={"_id":0}# 不返回_id字段orders=list(self.collection.find(query,projection).limit(limit).sort("create_time",-1))returnorders# 更新数据(U):更新订单状态defupdate_order_status(self,order_id:str,new_status:str)-int:""" 更新订单状态 :param order_id: 订单ID :param new_status: 新状态(pending/paid/shipped/completed) :return: 受影响的记录数 """query={"_id":order_id}update_data={"$set":{"order_status":new_status,"update_time":datetime.now()}}result=self.collection.update_one(query,update_data)returnresult.modified_count# 删除数据(D):删除过期无效订单defdelete_invalid_orders(self,user_id:str)-int:""" 删除用户的无效订单(状态为pending且创建时间超过24小时,仅示例) :param user_id: 用户唯一标识 :return: 删除的记录数 """# 模拟24小时前的时间(实际可根据业务调整)expire_time=datetime.now()-timedelta(hours=24)query={"user_id":user_id,"order_status":"pending","create_time":{"$lt":expire_time}}result=self.collection.delete_many(query)returnresult.deleted_count# 聚合查询:按用户统计订单总金额defstat_user_order_total(self)-List[Dict]:""" 聚合查询:统计每个用户的订单总金额、订单数量 :return: 聚合结果列表 """pipeline=[{"$group":{"_id":"$user_id","total_amount":{"$sum":"$order_amount"},"order_count":{"$sum":1}}},{"$sort":{"total_amount":-1}},{"$limit":20# 仅返回前20名用户}]returnlist(self.collection.aggregate(pipeline))# 事务操作:批量创建订单(需MongoDB 4.0+支持,mongomock兼容事务模拟)defbatch_create_orders(self,order_list:List[Dict])-bool:""" 事务批量创建订单,要么全部成功,要么全部回滚 :param order_list: 订单列表 :return: 批量创建是否成功 """ifnotorder_list:returnFalsewithself.db.client.start_session()assession:session.start_transaction()try:fororderinorder_list:self.create_order(order)session.commit_transaction()returnTrueexceptExceptionase:session.abort_transaction()raiseException(f"批量创建订单失败:{str(e)}")第二步:编写单元测试用例创建test_mongodb_service.py,使用pytest+mongomock实现无依赖测试:# test_mongodb_service.pyimportpytestimportmongomockfrompymongoimportMongoClientfromdatetimeimporttimedelta,datetimefrommongodb_serviceimportMongoDBBusinessService# 测试夹具1:创建模拟MongoDB客户端(无需真实服务,全局复用)@pytest.fixture(scope="function")defmock_mongo_client():"""创建模拟MongoDB客户端,测试完成后自动清理数据"""client=mongomock.MongoClient()# 完全兼容pymongo APIyieldclient# 测试结束后删除测试数据库,避免数据残留client.drop_database("business_db")# 测试夹具2:初始化业务服务实例@pytest.fixture(scope="function")deforder_service(mock_mongo_client):"""初始化MongoDB业务服务,依赖模拟客户端"""returnMongoDBBusinessService(mock_mongo_client)# -------------- 测试用例:覆盖CRUD核心操作 --------------deftest_create_order_success(order_service):"""测试创建订单(正常场景)"""order_data={"use
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

企业网站建设的收获企业网站大图

面试官:Vision-Language 模型中是如何实现跨模态特征对齐的?CLIP 和 BLIP 有什么区别? 这道题表面上问“特征对齐”,其实考察的是你对多模态表示学习(Multimodal Representation Learning)的理解深度。 所…

张小明 2026/1/21 0:00:57 网站建设

阜阳网站建设电话医院网站怎么做

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

张小明 2026/1/21 0:00:26 网站建设

网站建设找好景科技成都网站搜索优化

📝 博客主页:jaxzheng的CSDN主页 目录医疗数据科学:当咖啡因遇上基因组 一、我的血泪史:从拿铁到核磁共振 二、医疗数据的"鸡肋"现状 三、AI医生的"成长烦恼" 四、数据隐私的魔幻现实 五、未来已来的那些事 六…

张小明 2026/1/20 23:59:55 网站建设

专业的无锡网站建设咸宁制作网站

Typst排版难题:三步解决内容溢出与裁剪问题 【免费下载链接】typst A new markup-based typesetting system that is powerful and easy to learn. 项目地址: https://gitcode.com/GitHub_Trending/ty/typst 你是否曾经遇到过这样的困境:精心设计…

张小明 2026/1/20 23:59:24 网站建设

微网站开发 mui框架软文是指什么

还在为找不到合适的歌词而苦恼吗?每次听歌都要手动搜索歌词,既浪费时间又影响听歌体验?别担心,ZonyLrcToolsX 就是你一直在寻找的歌词下载神器!这款基于 .NET Core 开发的跨平台工具,能够帮你从网易云音乐、…

张小明 2026/1/20 23:58:22 网站建设