当前位置: 首页 > news >正文

wordpress怎么写网站关键词和描述东莞多语言网站建设

wordpress怎么写网站关键词和描述,东莞多语言网站建设,企业网络规划设计与实现,app网络推广方案背景 美团内部的RPC服务大多构建在Thrift之上#xff0c;在日常开发服务的过程中#xff0c;需要针对这些服务进行压力测试#xff08;以下简称压测#xff09;来发现潜在问题。常用的方法有#xff1a; 使用一些脚本语言如#xff1a;Python、Ruby等#xff0c;读取线上… 背景 美团内部的RPC服务大多构建在Thrift之上在日常开发服务的过程中需要针对这些服务进行压力测试以下简称压测来发现潜在问题。常用的方法有 使用一些脚本语言如Python、Ruby等读取线上日志构建请求用多线程模拟用户请求进行压测使用开源工具进行压测然而无论采取哪种方法压测都是一个十分耗时而又繁琐的过程主要痛点有 需要写很多代码解析日志还原请求对于比较复杂的请求解析很容易出错需要搭建脚本或者工具的运行环境通常这一过程比较耗时由于打压方法没有统一导致打压的结果指标比较混乱有的结果甚至以终端输出的方式展示非常不直观对一个应用的打压测试由于环境、代码的问题导致组内同学很难共享针对上述问题提供一个简单好用的压测工具是十分有必要的。 在构建压测工具之前对于一些现有的开源工具进行了调研。现在主流的压测工具主要有以下几个 JMeter JMeter是一个比较老牌的压测工具主要针对HTTP服务进行打压该工具在以下方面并不满足美团内部的压测需求 默认不支持Thrift的打压测试需要本地安装并且配置复杂对于用户操作并不友好 twitter/iago iago 是一个由Twitter开源的压测工具支持对HTTP、Thrift等服务进行压测其主要问题如下 对每个压测应用都需要创建一个项目压测结果并不直观流量重放依赖本地文件项目依赖于一个较老版本的Scala搭建不便相关文档比较少除此之外当时还考察了Gatling、Grinder、Locust 等一些常见的压测工具都因为适用场景和美团的需求有些出入而排除了。 综上针对当前压测工具的一些现状构建一个简单易用的压测工具还是很有必要的。 针对之前提到的痛点新的压测工具主要提供以下功能 线上流量拷贝简单易用的操作界面接入压测的时间应该控制在1小时以内清晰的图表能反映压测应用的各项指标满足包括Thrift、HTTP等服务的压测需求抽象 目标已经明确怎么实现呢首先是抽象压测的过程。 一个典型的压测过程如图所示首先在init方法里面进行一些初始化的工作比如连接数据库创建客户端等。接下来在run方法里面发出压测请求为了保证能够对服务产生足够的压力这里通常采用多线程并发访问同时记录每次请求的发起时间和结束时间这两个时间的简单相减就能够得到每次请求的响应时间利用该结果就可以计算出TP90、平均响应时间、最大响应时间等指标等压测结束后通过destroy方法进行资源回收等工作。 以上过程可以用接口表示无论是压测Thrift服务还是HTTP服务本质上都是这三个方法实现的不同。考虑到压测工具的灵活性和通用性压测工具可以将这个接口交给打压测试的同学实现而压测工具则重点实现多线程打压打压结果的聚合等比较耗时的工作。 interface Runner {def init(Test app) // 初始化压测def run(Test app, String log) // 每次打压请求传入log方便构建请求def destroy(Test app) // 压测完毕后回收资源 }拷贝流量 Thrift服务打压的难点之一就是如何简单地拷贝线上真实流量用来构建打压请求。一些大型的Thrift服务数据结构非常复杂写打压脚本的时候需要很多代码来解析日志而且容易出错。 因此提供一个简单好用的拷贝流量方法是十分有必要的。 在这里压测工具提供了一个叫VCR录像机的工具来拷贝流量。VCR能够将线上的请求序列化后写到Redis里面。 考虑到用户需要查看具体请求和易用性等需求最终选取了JSON格式作为序列化和反序列化的协议。同时需要部署在生产环境为了降低对线上服务的影响这里采取了单线程异步写的方式来拷贝流量。 聚合数据 应用打压完成后需要一些指标来评估压测结果常见的指标有 - 最大响应时间 - 平均响应时间 - QPS - TP90 - TP50 压测工具采用了 InfluxDB 来完成数据的聚合工作。 以TP90为例子仅需要一行查询就能实现需求。 SELECT PERCENTILE(response_time, 90) FROM test_series GROUP BY time(10s)整体而言整个打压过程如下 拷贝流量 美团内部的服务大多使用Java来构建VCR以Maven Package的方式提供给用户。 对用户来说只需要2行代码可以拷贝流量。 为了不影响线上服务通常选取单台机器进行流量拷贝工作。 public class TestAppRPC implements TestApp.Iface {private Vcr _vcr new Vcr(testapp); // 指定拷贝流量的keyOverridepublic TestResponse echo(TestRequest req) throws TException {_vcr.copy(req); // 拷贝操作long start System.currentTimeMillis();TestResponse response new TestResponse();return response;} } 一旦流量拷贝完成后通过Web界面用户能够查看日志的收集情况和单条日志的详情。 压测逻辑实现 压测工具采用Groovy来进行编写。对每个应用来说只需要实现runner接口就可以实现对应用的打压。 interface Runner {def init(Test app)def run(Test app, String log)def destroy(Test app) }以Thrift服务为例 class TestServiceRunner implements Runner {RPCService.Client _clientTTransport _transport;Overridedef init(Test app) {def conf app.config // 读取应用配置_transport new TFramedTransport(new TSocket(conf.get(thrift_service_host) as String, conf.get(thrift_service_port) as int))TProtocol protocol new TBinaryProtocol(_transport)_client new RPCService.Client(protocol)_transport.open()}Overridedef run(Test app, String log) {TestRequest req Vcr.deSerialize(log, TestRequest.class) // 将拷贝流量反序列化_client.echo(req) // 发送请求}Overridedef destroy(Test app) {_transport.close() // 关闭服务} } 创建应用 实现以上接口后就可以对应用进行打压了。 用户可以通过Web界面创建应用除了必填配置以外用户可以按照应用灵活配置。 性能指标 用户可以通过直观的图表来查看应用的各种性能指标。 压测工具上线以来已经接入了20多个应用完成数百次打压实验现在应用的接入时间仅需要1530分钟。保证了美团服务的稳定和节省了开发同学的时间使大家告别了以往繁琐冗长的打压测试。 欢迎对这方面有兴趣的同学一起讨论。
http://www.huolong8.cn/news/297827/

相关文章:

  • 如何用华为云服务器做网站石基网站建设
  • 高端网站建设哪些好做做电气的什么招聘网站好
  • 网站建站建设35个成功的市场营销策划案例
  • 怎么上线网站洛阳市网站建设管理
  • 档案网站建设对比如何刷网站流量
  • 建设网站前准备资料做网站找酷万
  • 天津新亚太工程建设监理有限公司网站江门网站推广哪里专业
  • 建设 网站协议范本上海门户网站的亮点
  • 做a图片网站建设银行网站 查余额查询
  • 智能化建设网站做视频赚钱的网站
  • 嘉兴专业做网站wordpress 多个边栏
  • 建设银行注册网站的用户名怎么写域名注册和网站哪个好
  • 程序开发外包平台优化落实新十条措施
  • 网站cms管理后台电话号码最好用的素材网站
  • 重庆网站制作系统专门做win7系统的网站
  • 网站备案详细最新流程沈阳哪家网站做的好
  • 建站技术论坛做视频网站用网站空间还是服务器
  • 昆山网站制作江宁区建设工程局网站
  • 广西建设局建设行政主管部网站红色网站呢
  • 网站查询是否安全微信主题wordpress
  • 郑州汉狮做网站报价百度竞价价格查询
  • thinkphp5做的网站平潭综合实验区交通与建设网站
  • 微信网站开发合同深交所大宗交易平台
  • 网站敏感词汇免费网站制作知乎
  • 新增域名网站建设方案网站底部备案代码
  • 潘家园做网站的公司wordpress技术文章
  • 网站开发海口泰州市高港区建设局网站
  • 爱做的小说网站seo优化网站建设公司
  • 晋城市建设局网站网站图片优化
  • 网站建设的公司做销售内蒙古网络自学网站建设