酷店

AlibcMonitorUtil.h 3.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /*
  2. * AlibcMonitorUtil.h
  3. *
  4. * 阿里百川电商
  5. * 项目名称:阿里巴巴电商 AlibcTradeCommon
  6. * 版本号:3.1.1.93
  7. * 发布时间:2017-03-06
  8. * 开发团队:阿里巴巴百川商业化团队
  9. * 阿里巴巴电商SDK答疑群号:1229144682(阿里旺旺)
  10. * Copyright (c) 2016-2019 阿里巴巴-移动事业群-百川. All rights reserved.
  11. */
  12. #ifndef ALiMonitorUtil_h
  13. #define ALiMonitorUtil_h
  14. #define MONITOR_MODULE @"BCTradeSDK"
  15. @interface AlibcMonitorUtil : NSObject
  16. + (instancetype)shareInstance;
  17. /**
  18. * 注册性能监控点
  19. @param monitor 监控点,例:@"init"
  20. */
  21. //-(void)registMonitorPoint:(ALiMonitor*)monitor;
  22. /**
  23. * 记录业务操作成功接口
  24. *
  25. * @param module 模块名称,安卓iOS要相同. 命名规范:若之前埋点有页面名,则用原来的; 否则用"业务名_页面名"(无页面则"业务名"); 采用首字母大写驼峰方式. 如Shop_Detail, Shop_List
  26. * @param monitorPoint 监控点名称,安卓iOS要相同,从@雷曼 获取
  27. * @arg 附加参数,用于做横向扩展
  28. */
  29. - (void)commitSuccessWithModule:(NSString *)module monitorPoint:(NSString *)monitorPoint arg:(NSString *)arg;
  30. /**
  31. * 记录业务操作失败接口
  32. *
  33. * @param module 模块名称,安卓iOS要相同. 命名规范:若之前埋点有页面名,则用原来的; 否则用"业务名_页面名"(无页面则"业务名"); 采用首字母大写驼峰方式. 如Shop_Detail, Shop_List
  34. * @param monitorPoint 监控点名称,安卓iOS要相同,从@雷曼 获取
  35. * @param errorCode 错误码,若为MTOP请求则传MTOP的错误码,否则请业务方对错误进行分类编码,方便统计错误类型占比
  36. * @param errorMsg 错误信息,若位MTOP请求则传MTOP的错误信息, 否则请业务方自己描述错误, 方便自己查找原因
  37. * @arg 附加参数,用于做横向扩展
  38. */
  39. - (void)commitFailWithModule:(NSString *)module monitorPoint:(NSString *)monitorPoint errorCode:(NSString *)errorCode errorMsg:(NSString *)errorMsg arg:(NSString *)arg;
  40. /**
  41. * 提交多维度,多指标
  42. * @param monitor 监控模块
  43. */
  44. //-(void)commitWithMonitor:(ALiMonitor*)monitor;
  45. /**
  46. * 开始监控
  47. * @param key 计算时间的标示符,不能重复
  48. * @return 是否加入监控,key重复,会覆盖
  49. */
  50. //-(BOOL)beginTimeMonitor:(NSString*)key;
  51. /**
  52. * 结束监控,清楚监控key
  53. * @param key ,计算时间的标示符,必须有begin,否则返回0
  54. * @return 返回耗时,毫秒数
  55. */
  56. //-(NSString*)endTimeMonitor:(NSString*)key;
  57. /**
  58. * 清除所有监控key
  59. */
  60. //-(void)clearAllTimeMonitor;
  61. /**
  62. * 清除指定监控key
  63. */
  64. //-(void)clearTimeMonitor:(NSString*)key;
  65. @end
  66. @class AlibcTradeMonitor;
  67. @protocol AlibcTradeAppMonitorAdapter <NSObject>
  68. - (void)commit:(AlibcTradeMonitor *)monitor;
  69. - (void)commitSuccessWithModule:(NSString *)module monitorPoint:(NSString *)monitorPoint arg:(NSString *)arg;
  70. - (void)commitFailWithModule:(NSString *)module monitorPoint:(NSString *)monitorPoint errorCode:(NSString *)errorCode errorMsg:(NSString *)errorMsg arg:(NSString *)arg;
  71. - (void)registerMonitor:(AlibcTradeMonitor *)monitor;
  72. @end
  73. #endif /* ALiMonitorUtil_h */