NewLife.Remoting 3.0.2024.806-beta0146

This is a prerelease version of NewLife.Remoting.
There is a newer version of this package available.
See the version list below for details.
dotnet add package NewLife.Remoting --version 3.0.2024.806-beta0146                
NuGet\Install-Package NewLife.Remoting -Version 3.0.2024.806-beta0146                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="NewLife.Remoting" Version="3.0.2024.806-beta0146" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add NewLife.Remoting --version 3.0.2024.806-beta0146                
#r "nuget: NewLife.Remoting, 3.0.2024.806-beta0146"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install NewLife.Remoting as a Cake Addin
#addin nuget:?package=NewLife.Remoting&version=3.0.2024.806-beta0146&prerelease

// Install NewLife.Remoting as a Cake Tool
#tool nuget:?package=NewLife.Remoting&version=3.0.2024.806-beta0146&prerelease                

NewLife.Remoting - 协议通信库

GitHub top language GitHub License Nuget Downloads Nuget Nuget (with prereleases)

Nuget Downloads Nuget Nuget (with prereleases)

协议通信库,包含RPC架构和HTTP架构,提供客户端服务端通信的基础框架,内置SRMP协议实现,并支持实现各种自定义协议。

源码: https://github.com/NewLifeX/NewLife.Remoting
Nuget:NewLife.Remoting / NewLife.Remoting.Extensions

参考目录:

RPC架构

客户端:ApiClient

服务端:ApiServer

应用客户端:ClientBase

特点:

  1. 服务端根据Action把请求转发给各个Controller,用法跟WebApi一致。
  2. 简单高性能,通信报文使用二进制序列化,中间没有任何损耗
  3. 接口出入参支持灵活的Json序列化(常规接口),同时也支持高效的二进制序列化(图片视频)
  4. TCP/UDP长会话,支持服务端主动下发消息
  5. 典型连接数,单机1万TCP长连接,最高400万
  6. 典型吞吐数,单机10万TPS,最高2266万TPS
  7. 服务端可寄宿于控制台、Web项目、桌面应用、IoT嵌入式应用
  8. 支持集群部署横向扩展,每个客户端跟其中一个服务端维持长连接,所有请求落到该服务器

代表性应用(蚂蚁调度AntJob):

  1. 客户端AntClient继承自ClientBase,通过Tcp/Udp等协议连接服务端ApiServer,进行登录、心跳等操作。
  2. 客户端使用应用AppId和AppSecret登录,获得令牌,后续无需携带或验证令牌,直到令牌过期重新登录。

HTTP架构

客户端:ApiHttpClient

服务端:ASP.NET WebApi

应用客户端:ClientBase

应用服务端:BaseDeviceController

特点:

  1. 标准ASP.NET WebApi作为服务端,重用现有技术栈,包括接口测试和集群部署管理。
  2. 客户端ApiHttpClient是标准HttpClient的进一步封装,支持多服务端地址负载均衡。
  3. 默认通信使用Json序列化,不适合传输文件、图片和视频等二进制数据。
  4. 服务端提供BaseController基类,封装了令牌验证等鉴权机制
  5. 服务端提供BaseDeviceController基类,封装常见的登录、心跳和更新等接口
  6. 通过WebSocket长连接实现指令下发,心跳保活
  7. 典型连接数,单机1000并发连接
  8. 典型吞吐数,单机1万TPS
  9. 服务端仅寄宿于 Kestrel和IIS
  10. 支持集群部署横向扩展,客户端每次请求都可能分流到不同应用服务器

代表性应用(轻量级IoT平台ZeroIoT):

  1. 客户端HttpDevice继承自ClientBase,通过Http/Https协议连接服务端WebApi,进行登录、注销、心跳和更新等操作。
  2. 客户端使用设备DeviceCode和DeviceSecret登录,获得令牌,后续每次请求头都需要带上令牌。
  3. 在心跳时检测并维持WebSocket长连接。

新生命项目矩阵

各项目默认支持net8.0/net7.0/netstandard2.1/netstandard2.0/net4.5,旧版(2022.1225)支持net4.5/net4.0/net2.0

项目 年份 说明
基础组件 支撑其它中间件以及产品项目
NewLife.Core 2002 核心库,日志、配置、缓存、网络、序列化、APM性能追踪
NewLife.XCode 2005 大数据中间件,单表百亿级,MySql/SQLite/SqlServer/Oracle/TDengine/达梦,自动分表
NewLife.Net 2005 网络库,单机千万级吞吐率(2266万tps),单机百万级连接(400万Tcp)
NewLife.Remoting 2011 RPC通信框架,内网高吞吐或物联网硬件设备场景
NewLife.Cube 2010 魔方快速开发平台,集成了用户权限、SSO登录、OAuth服务端等,单表100亿级项目验证
NewLife.Agent 2008 服务管理组件,把应用安装成为操作系统守护进程,Windows服务、Linux的Systemd
NewLife.Zero 2020 Zero零代脚手架,基于NewLife组件生态的项目模板,Web、WebApi、Service
中间件 对接知名中间件平台
NewLife.Redis 2017 Redis客户端,微秒级延迟,百万级吞吐,丰富的消息队列,百亿级数据量项目验证
NewLife.RocketMQ 2018 RocketMQ纯托管客户端,支持Apache RocketMQ和阿里云消息队列,十亿级项目验
NewLife.MQTT 2019 物联网消息协议,MqttClient/MqttServer,客户端支持阿里云物联网
NewLife.IoT 2022 IoT标准库,定义物联网领域的各种通信协议标准规范
NewLife.Modbus 2022 ModbusTcp/ModbusRTU/ModbusASCII,基于IoT标准库实现,支持IoT平台和IoTEdge
NewLife.Siemens 2022 西门子PLC协议,基于IoT标准库实现,支持IoT平台和IoTEdge
NewLife.Map 2022 地图组件库,封装百度地图、高德地图和腾讯地图
NewLife.IP 2022 IP地址库,IP地址转物理地址
产品平台 产品平台级,编译部署即用,个性化自定义
AntJob 2019 蚂蚁调度,分布式大数据计算平台(实时/离线),蚂蚁搬家分片思想,万亿级数据量项目验证
Stardust 2018 星尘,分布式服务平台,节点管理、APM监控中心、配置中心、注册中心、发布中心
NewLife.ERP 2021 企业ERP,产品管理、客户管理、销售管理、供应商管理
CrazyCoder 2006 码神工具,众多开发者工具,网络、串口、加解密、正则表达式、Modbus
XProxy 2005 产品级反向代理,NAT代理、Http代理
HttpMeter 2022 Http压力测试工具
GitCandy 2015 Git源代码管理系统
SmartOS 2014 嵌入式操作系统,完全独立自主,支持ARM Cortex-M芯片架构
SmartA2 2019 嵌入式工业计算机,物联网边缘网关,高性能.NET6主机,应用于工业、农业、交通、医疗
菲凡物联FIoT 2020 物联网整体解决方案,建筑、环保、农业,软硬件及大数据分析一体化,单机十万级点位项目验证
NewLife.UWB 2020 厘米级(10~20cm)高精度室内定位,软硬件一体化,与其它系统联动,大型展厅项目验证

新生命开发团队

XCode

新生命团队(NewLife)成立于2002年,是新时代物联网行业解决方案提供者,致力于提供软硬件应用方案咨询、系统架构规划与开发服务。
团队主导的开源NewLife系列组件已被广泛应用于各行业,Nuget累计下载量高达60余万次。
团队开发的大数据核心组件NewLife.XCode、蚂蚁调度计算平台AntJob、星尘分布式平台Stardust、缓存队列组件NewLife.Redis以及物联网平台NewLife.IoT,均成功应用于电力、高校、互联网、电信、交通、物流、工控、医疗、文博等行业,为客户提供了大量先进、可靠、安全、高质量、易扩展的产品和系统集成服务。

我们将不断通过服务的持续改进,成为客户长期信赖的合作伙伴,通过不断的创新和发展,成为国内优秀的IT服务供应商。

新生命团队始于2002年,部分开源项目具有20年以上漫长历史,源码库保留有2010年以来所有修改记录
网站:https://newlifex.com
开源:https://github.com/newlifex
QQ群:1600800/1600838
微信公众号:(智能大石头)
智能大石头

Product Compatible and additional computed target framework versions.
.NET net5.0 is compatible.  net5.0-windows was computed.  net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 is compatible.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 is compatible. 
.NET Framework net40 is compatible.  net403 was computed.  net45 is compatible.  net451 was computed.  net452 was computed.  net46 was computed.  net461 is compatible.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (5)

Showing the top 5 NuGet packages that depend on NewLife.Remoting:

Package Downloads
NewLife.Stardust

星尘,分布式服务框架。节点管理,监控中心,配置中心,发布中心,注册中心

NewLife.Net

网络通讯基础框架及各种协议实现。

NewLife.MQTT

流行的物联网通信协议MQTT,包括客户端、服务端

NewLife.AntJob

分布式任务调度系统,纯NET打造的重量级大数据实时计算平台,万亿级调度经验积累。

NewLife.Remoting.Extensions

提供WebApi应用级服务端

GitHub repositories (6)

Showing the top 5 popular GitHub repositories that depend on NewLife.Remoting:

Repository Stars
RRQM/TouchSocket
TouchSocket is an integrated .NET networking framework that includes modules for socket, TCP, UDP, SSL, named pipes, HTTP, WebSocket, RPC, and more. It offers a one-stop solution for TCP packet issues and enables quick implementation of custom data message parsing using protocol templates.
NewLifeX/AntJob
分布式任务调度系统,纯NET打造的重量级大数据实时计算平台,万亿级调度经验积累!面向中小企业大数据分析场景。
NewLifeX/Stardust
星尘,轻量级分布式服务框架。配置中心、集群管理、远程自动发布、服务治理。服务自动注册和发现,负载均衡,动态伸缩,故障转移,性能监控。
NewLifeX/NewLife.Net
单机吞吐2266万tps的网络通信框架
NewLifeX/XCoder
新生命码神工具,代码生成、网络工具、API工具、串口工具、正则工具、图标工具、加解密工具、地图接口。
Version Downloads Last updated
3.2.2024.1116 417 11/16/2024
3.1.2024.1103-beta0605 81 11/3/2024
3.1.2024.1101 1,013 11/1/2024
3.1.2024.1002 1,008 10/2/2024
3.1.2024.923-beta0435 152 9/23/2024
3.1.2024.914-beta0002 204 9/14/2024
3.1.2024.913-beta0902 101 9/13/2024
3.1.2024.912-beta0006 109 9/12/2024
3.0.2024.902 1,451 9/2/2024
3.0.2024.812-beta0813 190 8/12/2024
3.0.2024.811-beta0608 121 8/11/2024
3.0.2024.806-beta0146 155 8/6/2024
3.0.2024.805 1,745 8/5/2024
3.0.2024.729-beta0815 635 7/29/2024
3.0.2024.710-beta1226 534 7/10/2024
3.0.2024.708 5,381 7/8/2024
3.0.2024.708-beta1003 107 7/8/2024
3.0.2024.703-beta0048 117 7/3/2024
3.0.2024.701 475 7/1/2024
3.0.2024.701-beta0219 94 7/1/2024
3.0.2024.630-beta0606 100 6/30/2024
3.0.2024.628-beta0626 232 6/28/2024
3.0.2024.627-beta1636 254 6/27/2024
3.0.2024.627-beta0009 112 6/27/2024
3.0.2024.626-beta1337 174 6/26/2024
3.0.2024.625-beta1714 166 6/25/2024
3.0.2024.625-beta1600 99 6/25/2024
3.0.2024.625-beta0716 101 6/25/2024
3.0.2024.624-beta1110 235 6/24/2024
3.0.2024.624-beta0627 118 6/24/2024
3.0.2024.624-beta0109 104 6/24/2024
3.0.2024.623-beta0607 182 6/23/2024
3.0.2024.622-beta1613 130 6/22/2024
2.8.2024.428-beta0930 809 4/28/2024
2.8.2024.402 3,636 4/2/2024
2.7.2024.202 1,102 2/2/2024
2.7.2024.101 1,544 1/1/2024
2.7.2024.101-beta0500 113 1/1/2024
2.7.2023.1218-beta1127 138 12/18/2023
2.7.2023.1209-beta1634 551 12/9/2023
2.7.2023.1201 2,120 12/1/2023
2.7.2023.1201-beta0310 84 12/1/2023
2.6.2023.1128-beta0013 107 11/28/2023
2.6.2023.1111-beta1140 128 11/11/2023
2.6.2023.1110-beta1323 126 11/10/2023
2.5.2023.1102 2,325 11/2/2023
2.5.2023.1102-beta0640 113 11/2/2023
2.5.2023.1101-beta0904 102 11/1/2023
2.5.2023.1031-beta0703 91 10/31/2023
2.4.2023.1028-beta0057 123 10/28/2023
2.4.2023.1001 3,470 10/1/2023
2.3.2023.907 600 9/7/2023
2.3.2023.903-beta1652 127 9/3/2023
2.3.2023.902-beta1701 216 9/2/2023
2.2.2023.902-beta1549 118 9/2/2023
2.2.2023.814 614 8/14/2023
2.2.2023.814-beta1331 126 8/14/2023
2.2.2023.707 2,749 7/7/2023
2.2.2023.707-beta0102 163 7/7/2023
2.1.2023.705-beta1042 165 7/5/2023
2.1.2023.704-beta0222 139 7/4/2023
2.1.2023.601 2,260 6/1/2023
2.1.2023.601-beta1433 140 6/1/2023
2.1.2023.516-beta0658 725 5/16/2023
2.1.2023.512 844 5/12/2023
2.1.2023.512-beta1533 137 5/12/2023
2.1.2023.401 2,269 4/1/2023
2.1.2023.401-beta1728 148 4/1/2023
2.1.2023.325-beta0151 346 3/25/2023
2.1.2023.301 2,460 3/1/2023
2.1.2023.301-beta0446 158 3/1/2023
2.0.2023.218-beta0230 361 2/18/2023
2.0.2023.214-beta1534 521 2/14/2023
2.0.2023.203 3,014 2/3/2023
2.0.2023.203-beta1355 135 2/3/2023
2.0.2023.203-beta1201 145 2/3/2023
2.0.2023.101 1,585 1/1/2023
2.0.2023.101-beta0306 163 1/1/2023
2.0.2022.1223-beta0408 1,573 12/23/2022
2.0.2022.1201 2,089 12/1/2022
2.0.2022.1201-beta1441 122 12/1/2022
2.0.2022.1127-beta0246 1,426 11/27/2022
2.0.2022.1109-beta0328 337 11/9/2022
2.0.2022.1101 2,968 11/1/2022
2.0.2022.1101-beta0755 178 11/1/2022
2.0.2022.1004 967 10/4/2022
2.0.2022.1004-beta0332 156 10/4/2022
2.0.2022.901 6,151 9/1/2022
2.0.2022.901-beta0405 164 9/1/2022
2.0.2022.813-beta1441 539 8/13/2022
2.0.2022.810-beta0529 248 8/10/2022

第三代协议通信库,增强RPC,引入主流Http/WebSockt/WebApi应用级封装