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为主

服务调用关系

源码测试

  1. git clone https://github.com/mpusher/mpush.git

  2. 导入到eclipse或Intellij IDEA

  3. 打开mpush-test模块,所有的测试代码都在该模块下

  4. 修改配置文件src/test/resource/application.conf文件修改方式参照 服务部署第6点

  5. 运行com.mpush.test.sever.ServerTestMain.java启动长链接服务

  6. 运行com.mpush.test.client.ConnClientTestMain.java模拟一个客户端

  7. 运行com.mpush.test.push.PushClientTestMain模拟给用户下发消息

  8. 可以在控制台观察日志看服务是否正常运行,消息是否下发成功

服务部署

说明:mpush 服务只依赖于zookeeper和redis,当然还有JDK>=1.8
  1. 安装jdk 1.8以上版本并设置%JAVA_HOME%

  2. 安装zookeeper(安装配置步骤略)

  3. 安装Redis(安装配置步骤略)

  4. 下载mpush server 最新的正式包https://github.com/mpusher/mpush/releases

  5. 解压下载的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
    
  6. 修改 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文件

  7. 给bin目录下的脚本增加执行权限chmod u+x *.sh

  8. 执行./mp.sh start启动服务, 查看帮助./mp.sh目前支持的命令:

    Usage: ./mp.sh {start|start-foreground|stop|restart|status|upgrade|print-cmd}

    set-env.sh用于增加和修改jvm启动参数,比如堆内存、开启远程调试端口、开启jmx等

  9. cd logs目录,cat mpush.out查看服务是否启动成功

  10. 集成部署,比如集成到现有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"}
}
  1. 未完待续…

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/68887.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C#面试常考随笔7:什么是匿名⽅法?还有Lambda表达式?

匿名方法本质上是一种没有显式名称的方法&#xff0c;它可以作为参数传递给需要委托类型的方法&#xff0c;常用于事件处理、回调函数等场景&#xff0c;能够让代码更加简洁和紧凑。 使用场景 事件处理&#xff1a;在处理事件时&#xff0c;不需要为每个事件处理程序单独定义…

第二篇:多模态技术突破——DeepSeek如何重构AI的感知与认知边界

——从跨模态对齐到因果推理的工程化实践 在AI技术从单一模态向多模态跃迁的关键阶段&#xff0c;DeepSeek通过自研的多模态融合框架&#xff0c;在视觉-语言-语音的联合理解与生成领域实现系统性突破。本文将从技术实现层面&#xff0c;解构其跨模态表征学习、动态融合机制与…

AlexNet论文代码阅读

论文标题&#xff1a; ImageNet Classification with Deep Convolutional Neural Networks 论文链接&#xff1a; https://volctracer.com/w/BX18q92F 代码链接&#xff1a; https://github.com/dansuh17/alexnet-pytorch 内容概述 训练了一个大型的深度卷积神经网络&#xf…

扩散模型(三)

相关阅读&#xff1a; 扩散模型&#xff08;一&#xff09; 扩散模型&#xff08;二&#xff09; Latent Variable Space 潜在扩散模型&#xff08;LDM&#xff1b;龙巴赫、布拉特曼等人&#xff0c;2022 年&#xff09;在潜在空间而非像素空间中运行扩散过程&#xff0c;这…

git基础使用--4---git分支和使用

文章目录 git基础使用--4---git分支和使用1. 按顺序看2. 什么是分支3. 分支的基本操作4. 分支的基本操作4.1 查看分支4.2 创建分支4.3 切换分支4.4 合并冲突 git基础使用–4—git分支和使用 1. 按顺序看 -git基础使用–1–版本控制的基本概念 -git基础使用–2–gti的基本概念…

8.攻防世界Web_php_wrong_nginx_config

进入题目页面如下 尝试弱口令密码登录 一直显示网站建设中&#xff0c;尝试无果&#xff0c;查看源码也没有什么特别漏洞存在 用Kali中的dirsearch扫描根目录试试 命令&#xff1a; dirsearch -u http://61.147.171.105:53736/ -e* 登录文件便是刚才登录的界面打开robots.txt…

【漫话机器学习系列】076.合页损失函数(Hinge Loss)

Hinge Loss损失函数 Hinge Loss&#xff08;合页损失&#xff09;&#xff0c;也叫做合页损失函数&#xff0c;广泛用于支持向量机&#xff08;SVM&#xff09;等分类模型的训练过程中。它主要用于二分类问题&#xff0c;尤其是支持向量机中的优化目标函数。 定义与公式 对于…

Vue.js 使用 `teleport` 实现全局挂载

Vue.js 使用 teleport 实现全局挂载 今天我们来聊聊 Vue 3 中的一个实用功能&#xff1a;<Teleport> 组件。如果你曾在项目中需要将组件的部分内容渲染到全局位置&#xff0c;比如将模态框、通知等元素挂载到 body 下&#xff0c;那么 <Teleport> 将是你的好帮手。…

python算法和数据结构刷题[5]:动态规划

动态规划&#xff08;Dynamic Programming, DP&#xff09;是一种算法思想&#xff0c;用于解决具有最优子结构的问题。它通过将大问题分解为小问题&#xff0c;并找到这些小问题的最优解&#xff0c;从而得到整个问题的最优解。动态规划与分治法相似&#xff0c;但区别在于动态…

本地Deepseek添加个人知识库(Page Assist/AnythingLLM)

本地Deepseek两种方法建立知识库 前言 &#xff08;及个人测试结论&#xff09;法一、在Page Assist建立知识库step1 下载nomic-embed-textstep2 加载进Page Assiststep3 添加知识step4 对话框添加知识库 法二、在AnythingLLM建立知识库准备工作1.下载nomic-embed-text2.下载An…

Node.js 全局对象

Node.js 全局对象 引言 在Node.js中,全局对象是JavaScript环境中的一部分,它提供了对Node.js运行时环境的访问。全局对象在Node.js中扮演着重要的角色,它使得开发者能够访问和操作Node.js的许多核心功能。本文将详细介绍Node.js的全局对象,包括其特点、常用方法和应用场景…

记8(高级API实现手写数字识别

目录 1、Keras&#xff1a;2、Sequential模型&#xff1a;2.1、建立Sequential模型&#xff1a;modeltf.keras.Sequential()2.2、添加层&#xff1a;model.add(tf.keras.layers.层)2.3、查看摘要&#xff1a;model.summary()2.4、配置训练方法&#xff1a;model.compile(loss,o…

Android 音视频 --- EGL介绍和使用

EGL的功能 EGL API作为一套与OpenGL ES各个版本相互独立的API&#xff0c;其作用主要是管理绘图表面。EGL提供以下机制&#xff1a; 与设备的原生窗口系统通信查询绘图表面的可用类型和配置创建绘图表面在OpenGL ES3.0或其他渲染API之间同步渲染管理纹理贴图等渲染资源

【Proteus】NE555纯硬件实现LED呼吸灯效果,附源文件,效果展示

本文通过NE555定时器芯片和简单的电容充放电电路,设计了一种纯硬件实现的呼吸灯方案,并借助Proteus仿真软件验证其功能。方案无需编程,成本低且易于实现,适合电子爱好者学习PWM(脉宽调制)和定时器电路原理。 一、呼吸灯原理与NE555功能分析 1. 呼吸灯核心原理 呼吸灯的…

grpc 和 http 的区别---二进制vsJSON编码

gRPC 和 HTTP 是两种广泛使用的通信协议&#xff0c;各自适用于不同的场景。以下是它们的详细对比与优势分析&#xff1a; 一、核心特性对比 特性gRPCHTTP协议基础基于 HTTP/2基于 HTTP/1.1 或 HTTP/2数据格式默认使用 Protobuf&#xff08;二进制&#xff09;通常使用 JSON/…

文字投影效果

大家好&#xff0c;我是喝西瓜汁的兔叽&#xff0c;今天给大家分享一个常见的文字投影效果。 效果展示 我们来实现一个这样的文字效果。 思路分析 这样的效果如何实现的呢? 实际上是两组相同的文字&#xff0c;叠合在一块&#xff0c;只不过对应的css不同罢了。 首先&…

deepseek使用教程

一、准备工作 注册账号 访问 DeepSeek 官网&#xff08;如 https://www.deepseek.com/&#xff09;或对应平台。完成注册并登录&#xff0c;部分服务可能需要企业认证或申请权限。 获取 API 密钥&#xff08;如使用 API&#xff09; 进入控制台或开发者页面&#xff0c;创建 A…

Hutool工具类

Hutool 是一个非常流行的 Java 工具类库&#xff0c;它提供了丰富的功能来简化开发中的常见任务&#xff0c;比如文件操作、加密、日期处理、字符串操作、数据库工具等。它是一个轻量级的工具库&#xff0c;可以减少开发者编写常用代码的工作量&#xff0c;提高开发效率。 主要…

正态分布与柯西分布的线性组合与副本随机变量同分布

正态分布与柯西分布的线性组合与副本随机变量同分布 对于标准差为 σ \sigma σ&#xff0c;期望为0的正态分布&#xff0c;其概率密度函数为 f ( x ) 1 2 π σ exp ⁡ − x 2 2 σ 2 f(x) \frac{1}{\sqrt{2\pi}\sigma}\exp^{-\frac{x^2}{2\sigma^2}} f(x)2π ​σ1​exp−…

【C++语言】卡码网语言基础课系列----13. 链表的基础操作I

文章目录 背景知识链表1、虚拟头节点(dummyNode)2、定义链表节点3、链表的插入 练习题目链表的基础操作I具体代码实现 小白寄语诗词共勉 背景知识 链表 与数组不同&#xff0c;链表的元素存储可以是连续的&#xff0c;也可以是不连续的&#xff0c;每个数据除了存储本身的信息…