WCF

进程间通信手段

  • 命名管道
    命名管道提供了一种基于内核的通信机制,可以在本地或网络中的进程之间进行数据传输。它是双向的,支持同步和异步通信。
    • 匿名管道(Anonymous Pipes)
      单向通信,适用于父子进程间的通信。
  • 共享内存
    共享内存允许多个进程通过共享的内存区域来进行快速的数据交换。它可以避免数据的复制开销,但需要处理好进程同步。
  • 消息队列
    消息队列是进程间通过发送消息来进行异步通信的一种机制。消息可以存储在队列中,适合长时间保持的通信方式。
  • 套接字(Sockets)
    套接字是网络通信的基础,支持在本地进程间或者跨网络的通信。可以实现较为复杂的、灵活性较高的通信方式。TCP ,UDP ,FTP ,HTTP ,RPC等都是基于Sockets的
  • 文件(File-based)
    通过文件系统,进程可以通过读写文件实现通信。这种方式虽然效率较低,但实现起来相对简单。
    • 共享卷(Shared Volumes)
      容器可以通过挂载的卷进行文件系统级别的通信。
  • 信号量、互斥量、事件(Semaphores, Mutexes, Events)
    不属于严格的通信,而是同步
  • 信号和挂钩(Signals and Hooks)
    进程可以使用信号来通知其他进程发生了某些事件。这在 Unix-like 系统中比较常见,但在 Windows 上相对少用。
  • Service Mesh
    在微服务架构中用于管理和监控服务之间的通信。其原理是通过在每个服务实例旁边部署一个代理(称为 Sidecar)来拦截和管理微服务之间的流量。负责管理和监控服务之间的网络通信,提供负载均衡、服务发现、故障处理、安全策略、流量控制等功能

更高级别的(原理是上面的原理,但是框架做了整合,比如支持多种传输格式的WCF)

  • WCF
  • RPC相关,如gRPC,SOAP
  • API
  • 消息中间件(这里指的是更高级别的消息队列框架,如RabbitMQ,支持很多高级功能)

WCF

https://learn.microsoft.com/zh-cn/dotnet/framework/wcf/whats-wcf

Windows Communication Foundation (WCF) 是用于构建面向服务的应用程序的框架。 借助 WCF,可以将数据作为异步消息从一个服务终结点发送至另一个服务终结点。 服务终结点可以是由 IIS 承载的持续可用的服务的一部分,也可以是应用程序中承载的服务。 终结点可以是从服务终结点请求数据的服务客户端。 简单消息可以是作为 XML 发送的单个字符或单个单词,复杂消息可以是二进制数据流。
WCF 设计提供一种用于创建 Web 服务和 Web 服务客户端的可管理的方式。
gRPC 是一种现代 RPC 框架,是 WCF 的常用替代方法。
性能:gRPC 比 WCF 更高效,尤其是对于长时间运行的连接。
可伸缩性:gRPC 旨在扩展到大量客户端和服务器。
安全性:gRPC 支持各种安全机制,包括 TLS 和身份验证。
跨平台:gRPC 是平台中立的,可用于各种编程语言。

上面是官网的介绍(所以其实gRPC更先进,如果本着学习直接上gRPC)
WCF(Windows Communication Foundation)是一个用于构建和运行与服务导向架构(SOA)兼容的分布式应用程序的框架。WCF允许开发人员构建安全、可靠、跨平台的消息传递系统,支持多种网络协议和消息编码格式。

  • 服务导向
    面向服务的体系结构 (SOA) 依赖 Web 服务发送和接收数据。松耦合,只要符合基本协定,则在任何平台上创建的任何客户端均可连接到服务。

  • 通用性
    可以和COM,COM+, .NET Framework,WSE 3.0 Web ,ASP.NET Web ,POX等应用程序集成

  • 多种消息模式
    请求/答复模式,单项消息,全双工交换模式

  • 支持元数据,可以用来生成客户端

  • 多种传输格式

  • 安全性

  • 持久化

  • 事务

  • 可拓展

关键概念

  • 服务:即等待客户端与其进行通信并响应该通信的应用程序。服务通过公开一个或多个契约(Contract)来定义它能执行的操作。

  • 客户端 : 即启动通信的应用程序,单个应用程序既可以充当客户端,也可以充当服务

  • 契约(Contract)

    • 服务契约(Service Contract):定义服务的操作。
    • 数据契约(Data Contract):定义数据结构以便服务之间进行交换。
    • 消息契约(Message Contract):允许对消息的结构进行更精细的控制。
    • 错误契约(Fault Contract):定义服务可能返回的错误。
  • 绑定(Binding):指定如何连接到服务,包括使用的协议(如HTTP、TCP)、编码(如文本、二进制)和安全要求(如加密、认证)。

  • 终结点(Endpoint):一个服务的访问点。每个终结点由一个地址(Address)、一个绑定(Binding)和一个契约(Contract)组成。简称为ABC。

  • 宿主(Host):服务必须在某种宿主进程中运行,宿主可以是IIS、Windows服务、控制台应用程序等。

服务契约和实现

using System.ServiceModel;

[ServiceContract]
public interface ICalculator
{
    [OperationContract]
    int Add(int a, int b);

    [OperationContract]
    int Subtract(int a, int b);
}

public class CalculatorService : ICalculator
{
    public int Add(int a, int b)
    {
        return a + b;
    }

    public int Subtract(int a, int b)
    {
        return a - b;
    }
}

还需再在App.Config配置 Serive name,baseAddress endpoint,binding,contract等等

宿主应用程序

创建一个宿主应用程序来托管这个服务。

using System;
using System.ServiceModel;

class Program
{
    static void Main(string[] args)
    {
        using (ServiceHost host = new ServiceHost(typeof(CalculatorService)))
        {
            host.Open();
            Console.WriteLine("Service is running...");
            Console.WriteLine("Press <Enter> to stop the service.");
            Console.ReadLine();
        }
    }
}

客户端应用程序

using System;
using System.ServiceModel;

class Program
{
    static void Main(string[] args)
    {
        ChannelFactory<ICalculator> channelFactory = new ChannelFactory<ICalculator>(new BasicHttpBinding(), new EndpointAddress("http://localhost:8000/CalculatorService"));
        ICalculator proxy = channelFactory.CreateChannel();

        int result1 = proxy.Add(1, 2);
        int result2 = proxy.Subtract(5, 3);

        Console.WriteLine($"1 + 2 = {result1}");
        Console.WriteLine($"5 - 3 = {result2}");

        ((IClientChannel)proxy).Close();
        channelFactory.Close();
    }
}

同样也需要配置 binding,endpoint ,address等等

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,616评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,020评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,078评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,040评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,154评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,265评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,298评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,072评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,491评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,795评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,970评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,654评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,272评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,985评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,815评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,852评论 2 351

推荐阅读更多精彩内容