zoukankan      html  css  js  c++  java
  • 质量体系

    1、对于一个系统而言,常有的组成部分有,服务器、基础服务、业务逻辑和第三方服务。而我们要保障整个系统的质量,就需要在这几个方面着手。

     

    2、流量预估

    在系统构建初期,也就是需求阶段,除了理解需求之外,还需要知道系统的受众是谁,将来大概会有多大的流量,根据估算的数值,采取相应的措施:

    1. 服务器分布式部署,根据流量大小选择几台服务器
    2. 根据业务实际情况选择基础服务
    3. 是否需要缓存方案,以及方案的选择
    4. 数据库的选择和设计,是否需要分库分表

     

    3、由于以上措施均针对系统流量,故系统的流量、性能监控,对我们而言也是非常重要。在服务器和基础服务层面,我们可以如下做:(以PHP + Nginx + Redis + Mongo 为例)

    1. 机器硬件指标监控及报警。监控机器CPU、内存、硬盘的使用率
    2. 基础服务的监控与报警。监控PHP、Nginx的错误日志和慢查询日志;监控Redis、Mongo服务器的使用情况
    3. 定时清理系统日志,保持硬盘空间可用
    4. 创建Mongo表的查询索引

     

    4、在业务层面,最主要的是保障业务逻辑正常。在这期间通过设计测试方案(深度、广度)多轮线下测试、自动化回归测试、小流量测试以及灰度发布的方式来减少我们系统的问题。

    1. 一个好的测试方案可以帮助我们发现80%的问题。测试方案中至少包括测试方法、测试策略以及测试用例
    2. 线下测试可以是代码的单元测试、接口的测试、系统的整体测试。对后端而言,接口测试就可以发现大部分的问题,而前端除了接口联调外,mock测试可以发现大部分APP的crash和ANR
    3. 自动化测试在成熟稳定的系统中作用较大。接口的全自动化应该是可以达到90%的代码覆盖率的。它可以在系统更新时,自动检测之前的功能是否受影响。多用于预发布环境
    4. 小流量和灰度发布是在用线上的真实流量来测试我们的系统功能,只让一小部分人可以看到新功能,即使有问题,影响面也不会太大

     

    5、当然我们有了上面的一些措施,仍然不可避免线上出现问题,所以我们需要业务监控

    1. 系统级错误监控
    2. 业务异常逻辑监控
    3. 接口超时监控
    4. 主要业务指标监控
    5. 系统只要接口流量监控

     

    6、在系统中往往存在一些第三方服务,在测试时,碰到第三方服务不可用时,可以使用mock server代替。第三方服务一般不需要我们测试,但是我们仍需要关注调用时的处理

    1. 查询服务的超时处理
    2. 订单类服务的订单唯一性

     

    7、上面的措施会将问题暴露出来,这时候就需要快速定位问题,来有效止损(日志快排)

    1. 构建日志规范化标准
    2. 日志统一管理
    3. 构建日志一键查询平台
  • 相关阅读:
    同异步调用、shutdown参数
    python学习笔记
    《深入浅出WPF》学习笔记之绘图和动画
    《深入浅出WPF》学习笔记之深入浅出话命令
    《深入浅出WPF》学习笔记之深入浅出话事件
    《深入浅出WPF》学习笔记之深入浅出话属性
    《深入浅出WPF》学习笔记之深入浅出话Binding
    《深入浅出WPF》学习笔记之控件与布局
    《深入浅出WPF》学习笔记之x名称空间详解
    《深入浅出WPF》学习笔记之系统学习XAML语法
  • 原文地址:https://www.cnblogs.com/by170628/p/14529598.html
Copyright © 2011-2022 走看看