IM 即时通讯系统-51-MPush开源实时消息推送系统
IM 开源系列
IM 即时通讯系统-41-开源 野火IM 专注于即时通讯实时音视频技术,提供优质可控的IM+RTC能力
IM 即时通讯系统-42-基于netty实现的IM服务端,提供客户端jar包,可集成自己的登录系统
IM 即时通讯系统-43-简单的仿QQ聊天安卓APP
IM 即时通讯系统-44-仿QQ即时通讯系统服务端
IM 即时通讯系统-45-merua0oo0 IM 分布式聊天系统
IM 即时通讯系统-46-OpenIM 提供了专为开发者设计的开源即时通讯解决方案
IM 即时通讯系统-47-beardlessCat IM 使用netty开发分布式Im,提供分布netty集群解决方案
IM 即时通讯系统-48-aurora-imui 是个通用的即时通讯(IM)UI 库,不特定于任何 IM SDK
IM 即时通讯系统-49-云信 IM UIKit 是基于 NIM SDK(网易云信 IM SDK)开发的一款即时通讯 UI 组件库,包括聊天、会话、圈组、搜索、群管理等组件
IM 即时通讯系统-50-📲cim(cross IM) 适用于开发者的分布式即时通讯系统
IM 即时通讯系统-51-MPush开源实时消息推送系统
IM 即时通讯系统-52-leo-im 服务端
IM 即时通讯系统-53-im system server
IM
https://github.com/mpusher/mpush
mpush
详细教程
-
官网:https://mpusher.github.io
-
文档:http://mpush.mydoc.io
源码
-
group https://github.com/mpusher/ 源代码空间
-
server https://github.com/mpusher/mpush 服务端源码
-
alloc https://github.com/mpusher/alloc 调度器源码
-
mpns https://github.com/mpusher/mpns 个性化推送中心源码
-
java-client https://github.com/mpusher/mpush-client-java 纯java客户端源码
-
android sdk&demo https://github.com/mpusher/mpush-android 安卓SDK和DEMO源码
-
IOS sdk(swift) https://github.com/mpusher/mpush-client-swift swift版客户端源码
-
IOS sdk(OC) https://github.com/mpusher/mpush-client-oc Object C 客户端源码
ps:由于源码分别在github和码云有两份,最新的代码以github为主
服务调用关系

源码测试
-
git clone https://github.com/mpusher/mpush.git -
导入到eclipse或Intellij IDEA
-
打开
mpush-test模块,所有的测试代码都在该模块下 -
修改配置文件
src/test/resource/application.conf文件修改方式参照 服务部署第6点 -
运行
com.mpush.test.sever.ServerTestMain.java启动长链接服务 -
运行
com.mpush.test.client.ConnClientTestMain.java模拟一个客户端 -
运行
com.mpush.test.push.PushClientTestMain模拟给用户下发消息 -
可以在控制台观察日志看服务是否正常运行,消息是否下发成功
服务部署
说明:mpush 服务只依赖于zookeeper和redis,当然还有JDK>=1.8
-
安装
jdk 1.8以上版本并设置%JAVA_HOME% -
安装
zookeeper(安装配置步骤略) -
安装
Redis(安装配置步骤略) -
下载mpush server 最新的正式包https://github.com/mpusher/mpush/releases
-
解压下载的tar包
tar -zvxf mpush-release-0.0.2.tar.gz到 mpush 目录, 结构如下drwxrwxr-x 2 shinemo shinemo 4096 Aug 20 09:30 bin —> 启动脚本 drwxrwxr-x 2 shinemo shinemo 4096 Aug 20 09:52 conf —> 配置文件 drwxrwxr-x 2 shinemo shinemo 4096 Aug 20 09:29 lib —> 核心类库 -rw-rw-r-- 1 shinemo shinemo 11357 May 31 11:07 LICENSE drwxrwxr-x 2 shinemo shinemo 4096 Aug 20 09:32 logs —> 日志目录 -rw-rw-r-- 1 shinemo shinemo 21 May 31 11:07 README.md drwxrwxr-x 2 shinemo shinemo 4096 Aug 20 09:52 tmp
-
修改 conf 目录下的
vi mpush.conf文件,mpush.conf里的配置项会覆盖同目录下的reference.conf文件#主要修改以下配置mp.net.connect-server-port=3000//长链接服务对外端口, 公网端口mp.zk.server-address="127.0.0.1:2181"//zk 机器的地址mp.redis={//redis 相关配置nodes:["127.0.0.1:6379"] //格式是ip:portcluster-model:single //single, cluster}//还有用于安全加密的RSA mp.security.private-key 和 mp.security.public-key 等...如果要修改其他配置请参照reference.conf文件
-
给bin目录下的脚本增加执行权限
chmod u+x *.sh -
执行
./mp.sh start启动服务, 查看帮助./mp.sh目前支持的命令:Usage: ./mp.sh {start|start-foreground|stop|restart|status|upgrade|print-cmd}set-env.sh用于增加和修改jvm启动参数,比如堆内存、开启远程调试端口、开启jmx等 -
cd logs目录,cat mpush.out查看服务是否启动成功 -
集成部署,比如集成到现有web工程一起部署到tomcat,可以添加如下依赖
<dependency><groupId>com.github.mpusher</groupId><artifactId>mpush-boot</artifactId><version>0.0.2</version>
</dependency>
启动入口com.mpush.bootstrap.ServerLauncher.java
配置文件详解
##################################################################################################################
#
# NOTICE:
#
# 系统配置文件,所有列出的项是系统所支持全部配置项
# 如果要覆盖某项的值可以添加到mpush.conf中。
#
# 配置文件格式采用HOCON格式。解析库由https://github.com/typesafehub/config提供。
# 具体可参照说明文档,比如含有特殊字符的字符串必须用双引号包起来。
#
##################################################################################################################mp {#基础配置home=${user.dir} //程序工作目录#日志配置log-level=warnlog-dir=${mp.home}/logslog-conf-path=${mp.home}/conf/logback.xml#核心配置core {max-packet-size=10k //系统允许传输的最大包的大小compress-threshold=10k //数据包启用压缩的临界值,超过该值后对数据进行压缩min-heartbeat=3m //最小心跳间隔max-heartbeat=3m //最大心跳间隔max-hb-timeout-times=2 //允许的心跳连续超时的最大次数session-expired-time=1d //用于快速重连的session 过期时间默认1天epoll-provider=netty //nio:jdk自带,netty:由netty实现}#安全配置security {#rsa 私钥、公钥key长度为1024;可以使用脚本bin/rsa.sh生成, @see com.mpush.tools.crypto.RSAUtils#mainprivate-key="MIIBNgIBADANBgkqhkiG9w0BAQEFAASCASAwggEcAgEAAoGBAKCE8JYKhsbydMPbiO7BJVq1pbuJWJHFxOR7L8Hv3ZVkSG4eNC8DdwAmDHYu/wadfw0ihKFm2gKDcLHp5yz5UQ8PZ8FyDYvgkrvGV0ak4nc40QDJWws621dm01e/INlGKOIStAAsxOityCLv0zm5Vf3+My/YaBvZcB5mGUsPbx8fAgEAAoGAAy0+WanRqwRHXUzt89OsupPXuNNqBlCEqgTqGAt4Nimq6Ur9u2R1KXKXUotxjp71Ubw6JbuUWvJg+5Rmd9RjT0HOUEQF3rvzEepKtaraPhV5ejEIrB+nJWNfGye4yzLdfEXJBGUQzrG+wNe13izfRNXI4dN/6Q5npzqaqv0E1CkCAQACAQACAQACAQACAQA="public-key="MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCghPCWCobG8nTD24juwSVataW7iViRxcTkey/B792VZEhuHjQvA3cAJgx2Lv8GnX8NIoShZtoCg3Cx6ecs+VEPD2fBcg2L4JK7xldGpOJ3ONEAyVsLOttXZtNXvyDZRijiErQALMTorcgi79M5uVX9/jMv2Ggb2XAeZhlLD28fHwIDAQAB"aes-key-length=16 //AES key 长度}#网络配置net {local-ip="" //本地ip, 默认取第一个网卡的本地IPpublic-ip="" //外网ip, 默认取第一个网卡的外网IPconnect-server-bind-ip="" //connSrv 绑定的本地ip (默认anyLocalAddress 0.0.0.0 or ::0)connect-server-register-ip=${mp.net.public-ip} //公网ip, 注册到zk中的ip, 默认是public-ipconnect-server-port=3000 //长链接服务对外端口, 公网端口connect-server-register-attr { //注册到zk里的额外属性,比如配置权重,可在alloc里排序weight:1}gateway-server-bind-ip="" //gatewaySrv 绑定的本地ip (默认anyLocalAddress 0.0.0.0 or ::0)gateway-server-register-ip=${mp.net.local-ip} //本地ip, 注册到zk中的ip, 默认是local-ipgateway-server-port=3001 //网关服务端口, 内部端口gateway-server-net=tcp //网关服务使用的网络类型tcp/udp/sctp/udtgateway-client-port=4000 //UDP 客户端端口gateway-server-multicast="239.239.239.88" //239.0.0.0~239.255.255.255为本地管理组播地址,仅在特定的本地范围内有效gateway-client-multicast="239.239.239.99" //239.0.0.0~239.255.255.255为本地管理组播地址,仅在特定的本地范围内有效gateway-client-num=1 //网关客户端连接数admin-server-port=3002 //控制台服务端口, 内部端口ws-server-port=0 //websocket对外端口, 公网端口, 0表示禁用websocketws-path="/" //websocket pathpublic-host-mapping { //本机局域网IP和公网IP的映射关系, 该配置后续会被废弃//"10.0.10.156":"111.1.32.137"//"10.0.10.166":"111.1.33.138"}snd_buf { //tcp/udp 发送缓冲区大小connect-server=32kgateway-server=0gateway-client=0 //0表示使用操作系统默认值}rcv_buf { //tcp/udp 接收缓冲区大小connect-server=32kgateway-server=0gateway-client=0 //0表示使用操作系统默认值}write-buffer-water-mark { //netty 写保护connect-server-low=32kconnect-server-high=64kgateway-server-low=10mgateway-server-high=20m}traffic-shaping { //流量整形配置gateway-client {enabled:falsecheck-interval:100mswrite-global-limit:30kread-global-limit:0write-channel-limit:3kread-channel-limit:0}gateway-server {enabled:falsecheck-interval:100mswrite-global-limit:0read-global-limit:30kwrite-channel-limit:0read-channel-limit:3k}connect-server {enabled:falsecheck-interval:100mswrite-global-limit:0read-global-limit:100kwrite-channel-limit:3kread-channel-limit:3k}}}#Zookeeper配置zk {server-address="127.0.0.1:2181" //多台机器使用","分隔如:"10.0.10.44:2181,10.0.10.49:2181" @see org.apache.zookeeper.ZooKeeper#ZooKeeper()namespace=mpushdigest=mpush //zkCli.sh acl 命令 addauth digest mpushwatch-path=/retry {#initial amount of time to wait between retriesbaseSleepTimeMs=3s#max number of times to retrymaxRetries=3#max time in ms to sleep on each retrymaxSleepMs=5s}connectionTimeoutMs=5ssessionTimeoutMs=5s}#Redis集群配置redis {cluster-model=single //single,cluster,sentinelsentinel-master:""nodes:[] s//["127.0.0.1:6379"]格式ip:portpassword="" //your passwordconfig {maxTotal:8,maxIdle:4,minIdle:1,lifo:true,fairness:false,maxWaitMillis:5000,minEvictableIdleTimeMillis:300000,softMinEvictableIdleTimeMillis:1800000,numTestsPerEvictionRun:3,testOnCreate:false,testOnBorrow:false,testOnReturn:false,testWhileIdle:false,timeBetweenEvictionRunsMillis:60000,blockWhenExhausted:true,jmxEnabled:false,jmxNamePrefix:pool,jmxNameBase:pool}}#HTTP代理配置http {proxy-enabled=false //启用Http代理max-conn-per-host=5 //每个域名的最大链接数, 建议web服务nginx超时时间设长一点, 以便保持长链接default-read-timeout=10s //请求超时时间max-content-length=5m //response body 最大大小dns-mapping { //域名映射外网地址转内部IP, 域名部分不包含端口号//"mpush.com":["127.0.0.1:8080", "127.0.0.1:8081"]}}#线程池配置thread {pool {conn-work:0 //接入服务线程池大小,0表示线程数根据cpu核数动态调整(2*cpu)gateway-server-work:0 //网关服务线程池大小,0表示线程数根据cpu核数动态调整(2*cpu)http-work:0 //http proxy netty client work pool size,0表示线程数根据cpu核数动态调整(2*cpu)ack-timer:1 //处理ACK消息超时push-task:0 //消息推送中心,推送任务线程池大小, 如果为0表示使用Gateway Server的work线程池,tcp下推荐0gateway-client-work:0 //网关客户端线程池大小,0表示线程数根据cpu核数动态调整(2*cpu),该线程池在客户端运行push-client:2 //消息推送回调处理,该线程池在客户端运行event-bus { //用户处理内部事件分发min:1max:16queue-size:10000 //大量的online,offline}mq { //用户上下线消息, 踢人等min:1max:4queue-size:10000}}}#推送消息流控push {flow-control { //qps = limit/(duration)global:{ //针对非广播推送的流控,全局有效limit:5000 //qps = 5000max:0 //UN limitduration:1s //1s}broadcast:{ //针对广播消息的流控,单次任务有效limit:3000 //qps = 3000max:100000 //10wduration:1s //1s}}}#系统监控配置monitor {dump-dir=${mp.home}/tmpdump-stack=false //是否定时dump堆栈dump-period=1m //多久监控一次print-log=true //是否打印监控日志profile-enabled=false //开启性能监控profile-slowly-duration=10ms //耗时超过10ms打印日志}#SPI扩展配置spi {thread-pool-factory:"com.mpush.tools.thread.pool.DefaultThreadPoolFactory"dns-mapping-manager:"com.mpush.common.net.HttpProxyDnsMappingManager"}
}
- 未完待续…
相关文章:
IM 即时通讯系统-51-MPush开源实时消息推送系统
IM 开源系列 IM 即时通讯系统-41-开源 野火IM 专注于即时通讯实时音视频技术,提供优质可控的IMRTC能力 IM 即时通讯系统-42-基于netty实现的IM服务端,提供客户端jar包,可集成自己的登录系统 IM 即时通讯系统-43-简单的仿QQ聊天安卓APP IM 即时通讯系统-44-仿QQ即…...
前端 | JavaScript中的reduce方法
1. 什么是reduce reduce 方法是 JavaScript 中数组的重要方法之一,用于对数组中的元素进行累积计算。它接收一个回调函数作为参数,并返回一个最终计算结果。reduce 在许多场景下都非常有用,比如求和、数组扁平化、对象计数、数据转换等。 2…...
【Linux】从硬件到软件了解进程
个人主页~ 从硬件到软件了解进程 一、冯诺依曼体系结构二、操作系统三、操作系统进程管理1、概念2、PCB和task_struct3、查看进程4、通过系统调用fork创建进程(1)简述(2)系统调用生成子进程的过程〇提出问题①fork函数②父子进程关…...
2024-我的学习成长之路
因为热爱,无畏山海...
机试题——到邻国目标城市的最短距离
题目描述 A国与B国是相邻的两个国家,每个国家都有很多城市。国家内部有很多连接城市的公路,国家之间也有很多跨国公路,连接两个国家的边界城市。两个国家一共有N个城市,编号从1到N,一共有M条公路,包括国内…...
连续预测、
一、连续预测 调用模型遍历需要预测文件夹中的图片: image_ids open(‘VOCdevkit/VOC2007/ImageSets/Main/test.txt’).read().strip().split() for image_id in tqdm(image_ids): # 遍历测试图像 image_path “./VOCdevkit/VOC2007/JPEGImages/” image_id …...
Kamailio 不通过 dmq 实现注册复制功能
春节期间找到一篇文章,需要 fg 才能看到: https://medium.com/tumalevich/kamailio-registration-replication-without-dmq-65e225f9a8a7 kamailio1 192.168.56.115 kamailio2 192.168.56.116 kamailio3 192.168.56.117 route[HANDLE_REPLICATION] {i…...
002 mapper代理开发方式-xml方式
文章目录 代理xml方式UserMapper.javaUser.javadb.propertiesSqlMapConfig.xmlUserMapper.xmlUserMapperTest.javapom.xml 代理 此处使用的是JDK的动态代理方式,延迟加载使用的cglib动态代理方式 代理分为静态代理和动态代理。此处先不说静态代理,因为…...
大模型系列21-AI聊天机器人
聊天机器人 背景机器学习基础监督学习(Supervised Learning)概念应用场景主要问题 无监督学习(Unsupervised Learning)概念常见方法应用场景 强化学习(Reinforcement Learning)概念关键要素应用场景 模型优…...
Apache Iceberg数据湖技术在海量实时数据处理、实时特征工程和模型训练的应用技术方案和具体实施步骤及代码
Apache Iceberg在处理海量实时数据、支持实时特征工程和模型训练方面的强大能力。Iceberg支持实时特征工程和模型训练,特别适用于需要处理海量实时数据的机器学习工作流。 Iceberg作为数据湖,以支持其机器学习平台中的特征存储。Iceberg的分层结构、快照…...
25.2.3 【洛谷】作为栈的复习不错(学习记录)
今天学习的东西不算多,放了一个星期假,感觉不少东西都没那么清楚,得复习一下才行。今天搞个栈题写,把栈复习一下,明天进入正轨,边复习边学习新东西,应该会有二叉树的学习等等... 【洛谷】P1449 …...
Windows 中的 WSL:开启你的 Linux 之旅
今天在安装windows上安装Docker Desktop的时候,遇到了WSL。下面咱们就学习下。 欢迎来到涛涛聊AI 一、什么是 WSL? WSL,全称为 Windows Subsystem for Linux,是微软为 Windows 系统开发的一个兼容层,它允许用户在 Win…...
二维前缀和:高效求解矩阵区域和问题
在处理二维矩阵时,频繁计算某一子矩阵的和是一个常见的操作。传统的做法是直接遍历该子矩阵,时间复杂度较高。当矩阵非常大且有大量的查询时,直接计算将变得低效。为了提高效率,我们可以通过 二维前缀和 技巧在常数时间内解决这个…...
音视频入门基础:RTP专题(5)——FFmpeg源码中,解析SDP的实现
一、引言 FFmpeg源码中通过ff_sdp_parse函数解析SDP。该函数定义在libavformat/rtsp.c中: int ff_sdp_parse(AVFormatContext *s, const char *content) {const char *p;int letter, i;char buf[SDP_MAX_SIZE], *q;SDPParseState sdp_parse_state { { 0 } }, *s1…...
Android开发工作经历整理
一.无人机应用软件开发 集成大疆官网的DJIMobileSDK到AS中编写软件,操控无人机执行多个航点任务。集成OpenCV库进行图像识别,通过获取参数,根据算法执行sdk,使无人机降落到机库,并执行后续的换电操作。待无人机就绪后…...
C++中常用的十大排序方法之4——希尔排序
成长路上不孤单😊😊😊😊😊😊 【😊///计算机爱好者😊///持续分享所学😊///如有需要欢迎收藏转发///😊】 今日分享关于C中常用的排序方法之4——希尔排序的相…...
解决注入线程池的栈溢出问题
文章目录 1.问题产生2.问题解决 1.问题产生 在使用sleuth的时候,需要注入线程池,他才会自动包装,实现traceId的传递,但是突然启动时出现了栈溢出的问题 2.问题解决 根据报错,发现是Gson序列化相关的问题,…...
自动驾驶---两轮自行车的自主导航
1 背景 无人驾驶汽车最早出现在DARPA的比赛中,从那个时刻开始,逐渐引起全球学者的注意,于是从上个世纪开始各大高校院所开始了无人汽车的研发。直到这两年,无人驾驶汽车才开始走进寻常百姓家,虽然目前市面上的乘用车还…...
哈夫曼树并查集
(1)哈夫曼树 特殊概念: 1.结点的权:表示结点树的重要性 2.带权路径长度:从树的根到该节点的路径长度(经过的边数)与该节点上权值的乘积 2.树的带权路径长度:该树的所有叶子节点的…...
PyTorch数据建模
回归分析 import torch import numpy as np import pandas as pd from torch.utils.data import DataLoader,TensorDataset import time strat = time.perf_counter()...
在 Ubuntu 上安装 Node.js 23.x
在 Ubuntu 上安装 Node.js 23.x 前提条件安装步骤1. 下载设置脚本2. 运行设置脚本3. 安装 Node.js4. 验证安装 参考链接总结 在现代 web 开发中,Node.js 是一个不可或缺的工具。它提供了一个强大的 JavaScript 运行时环境,使得开发人员可以在服务器端使用…...
SQL范式与反范式_优化数据库性能
1. 引言 什么是SQL范式 SQL范式是指数据库设计中的一系列规则和标准,旨在减少数据冗余、提高数据完整性和一致性。常见的范式包括第一范式(1NF)、第二范式(2NF)、第三范式(3NF)和BCNF(Boyce-Codd范式)。 什么是SQL反范式 SQL反范式是指在满足范式要求的基础上,有…...
hunyuan 混元学习
使用了5个subset,也是用了text-image和text-video进行训练的 也是进行了复杂的视频选择。同movie gen. 也进行了模型切断,用拉普拉斯算子找到最清晰的一帧作为训练的起始 训练了不同的模型去选择数据,比如用Dover去选择美观度比较好的数据,…...
四、GPIO中断实现按键功能
4.1 GPIO简介 输入输出(I/O)是一个非常重要的概念。I/O泛指所有类型的输入输出端口,包括单向的端口如逻辑门电路的输入输出管脚和双向的GPIO端口。而GPIO(General-Purpose Input/Output)则是一个常见的术语,…...
.Net / C# 繁体中文 与 简体中文 互相转换, 支持地方特色词汇
版本号 Nuget 搜索 “OpenCCNET”, 注意别找错, 好多库的名字都差不多 支持 “繁,简” 的互相转换, 支持多个地区常用词汇的转换, 还支持 日文的新旧转换. OpenCC 在 .Net 中的实现 https://github.com/CosineG/OpenCC.NET <PackageReference Include"OpenCCNET"…...
一元函数微积分的几何应用:二维平面光滑曲线的曲率公式
文章目录 前言曲率和曲率半径的定义曲率计算公式参数方程形式直角坐标显式方程形式极坐标形式向量形式 前言 本文将介绍二维平面光滑曲线的曲率定义以及不同形式的曲率及曲率半径公式的推导。 曲率和曲率半径的定义 (关于二维平面光滑曲线的定义以及弧长公式请参…...
数据结构与算法之异步: LeetCode 1114. 按序打印 (Ts版)
按序打印 https://leetcode.cn/problems/print-in-order/description/ 描述 给你一个类: public class Foo {public void first() { print("first"); }public void second() { print("second"); }public void third() { print("third&qu…...
python:求解爱因斯坦场方程
在物理学中,爱因斯坦的广义相对论(General Relativity)是描述引力如何作用于时空的理论。广义相对论由爱因斯坦在1915年提出,并被阿尔伯特爱因斯坦、纳森罗森和纳尔逊曼德尔斯塔姆共同发展。广义相对论的核心方程是爱因斯坦场方程…...
PostgreSQL 数据备份与恢复:掌握 pg_dump 和 pg_restore 的最佳实践
title: PostgreSQL 数据备份与恢复:掌握 pg_dump 和 pg_restore 的最佳实践 date: 2025/1/28 updated: 2025/1/28 author: cmdragon excerpt: 在数据库管理中,备份与恢复是确保数据安全和业务连续性的关键措施。PostgreSQL 提供了一系列工具,以便于数据库管理员对数据进行…...
位运算的概念
文章目录 整数在计算机中的表示二进制表示有符号类型和无符号类型机器数和真值原码、反码和补码原码、反码和补码的表示方法计算机中的表示 位运算与、或、异或和取反移位运算移位运算与乘除法的关系位运算的性质 目录 整数在计算机中的表示 二进制表示 程序中的所有数在计算…...
