惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Microsoft Azure Blog
Microsoft Azure Blog
有赞技术团队
有赞技术团队
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
F
Fox-IT International blog
Recorded Future
Recorded Future
T
ThreatConnect
T
The Exploit Database - CXSecurity.com
SecWiki News
SecWiki News
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
人人都是产品经理
人人都是产品经理
T
Tenable Blog
L
LINUX DO - 最新话题
博客园_首页
Hugging Face - Blog
Hugging Face - Blog
罗磊的独立博客
博客园 - 司徒正美
The Hacker News
The Hacker News
博客园 - 聂微东
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
Scott Helme
Scott Helme
博客园 - 【当耐特】
O
OpenAI News
Schneier on Security
Schneier on Security
Latest news
Latest news
S
Security @ Cisco Blogs
S
Secure Thoughts
F
Full Disclosure
L
Lohrmann on Cybersecurity
S
SegmentFault 最新的问题
T
Tor Project blog
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
量子位
小众软件
小众软件
T
Threat Research - Cisco Blogs
Simon Willison's Weblog
Simon Willison's Weblog
IT之家
IT之家
大猫的无限游戏
大猫的无限游戏
N
News and Events Feed by Topic
E
Exploit-DB.com RSS Feed
J
Java Code Geeks
Last Week in AI
Last Week in AI
酷 壳 – CoolShell
酷 壳 – CoolShell
Application and Cybersecurity Blog
Application and Cybersecurity Blog
S
Schneier on Security
Cisco Talos Blog
Cisco Talos Blog
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
P
Proofpoint News Feed
Recent Commits to openclaw:main
Recent Commits to openclaw:main
雷峰网
雷峰网

博客园 - FredGrit

WCF produce message and WPF consume periodically via DispatcherTimer WCF deconstruct WebConfig includes bindings, behaviors, service, endpoint ,serviceHostingEnvironment C# insert data into SQLite in batch periodically WPF SQLite SQLiteStudio - FredGrit WPF customize MultiSelectComboBox based on combobox WPF DataGrid Context menu binding command and commandparameter to datacontext WCF set fixed port as http://localhost:8888/ via Project /Properties/web/project url to create virtual directory WPF customize datagrid behavior based on behavior<datagrid> with command and command parameter WPF Microsoft Visual Studio XAML designer is busy WCF WebHttpBinding support both http and https WCF support basicHttpBinding and webHttpBinding - FredGrit WCF TestClient set fixed configuration file WPF consume http json and update periodically via DispatcherTimer WPF Prism.Core version 9.0.537 implemented navigation register singleton with splash screen, pass global variable via RegisterSingleton method WPF render periodically via DispatcherTimer, customize behavior - FredGrit Python cosume WCF service via requests in json format WPF call webHttpBinding from WCF WCF binding webHttpBinding is used to web browser in json format both in request and response WPF invoke WCF dll periodically via DispatcherTimer WCF webHttpBinding is open for web browser and wpf WPF DataTemplateSelector WPF DataGrid customize behavior with multiple commands and command parameters then invoke in mvvm - FredGrit WPF DataGrid behavior customize command and command parameter then invoke and implemented in MVVM - FredGrit WPF ItemsControl customize behavior and save all items WCF service can be accessed by browser WPF WCF produce data as service and WPF consume data as client periodically WPF GRPC and Probuf generated data as service then consume by wpf periodically WPF customize behavior based on Microsoft.Xaml.Behaviors.Wpf with command and commandparameter WPF call data from CPP wrapper dll via CLI\CLR - FredGrit WPF customize behavior WPF get gpu information via System.Management WPF ItemsControl IsItemsHost=True WPF Customize behavior and dependency property command C# Serilog, Serilog.Sinks.Console, Serilog.Sinks.File C# Serilog both in file and console Windows powershell view huge file via command C# serialize huge data more than 100M via splitting into batch and concatenating as one big json file WPF WeakReference C# serialize datetime then deserialize, print lose precision. resolve by ToString("o") C# produce data and send via WebSocket as service, Python,Flask,HTML as consumer invoke periodically C# write generated data service and sent via websocket, then consume by python periodically C# DateTime print precision to microseconds C# WebSocket console as service provide data, another console as client,send request periodically C# WebAPI [HttpGet("{cnt}"] pass argument WPF implement ICommand with async execute WPF ListBox control virtualization in mvvm WPF Data Source invoke from web api C# WebAPI
C# produce and consume data via Google.Protobuf
FredGrit · 2026-05-23 · via 博客园 - FredGrit
Install-Package Google.Protobuf
Install-Package Grpc.AspNetCore
Install-Package Grpc.Net.Client
Install-Package Grpc.Tools
//Add new file book.proto

syntax="proto3";

option csharp_namespace="GrpcBookServer";

package book;

message  BookProto{
    int64 id=1;
    string name=2;
    string isbn=3;
    string abstract=4;
    string author=5;
    string comment=6;
    string content=7;
    string summary=8;
    string title=9;
    string topic=10;
}

message GetBooksListRequest{
    int32 cnt=1;
}

message GetBooksListResponse{
    repeated BookProto books=1;
}

service BookService
{
    rpc GetBooksList(GetBooksListRequest) returns (GetBooksListResponse);
}
 
 

Add new file book.proto and set properties of book.proto   Build action as Protobuf compiler both in producer and consumer app.

image

//Producer
//D:\C\ConsoleApp19\ConsoleApp19\Program.cs
using Google.Protobuf;
using Google.Protobuf.Collections;
using Grpc.Core;
using GrpcBookServer;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Server.Kestrel.Core;
using Microsoft.Extensions.DependencyInjection;
using System.Runtime.Serialization;
using System.Threading.Tasks.Dataflow;

namespace ConsoleApp19
{
    internal class Program
    {
        static void Main(string[] args)
        {
            GrpcDemo();
            Console.ReadLine();
        }

        static async Task GrpcDemo()
        {
            var builder = WebApplication.CreateBuilder();
            builder.WebHost.ConfigureKestrel(serviceOptions =>
            {
                serviceOptions.ListenLocalhost(8888, x => x.Protocols = HttpProtocols.Http2);
            });

            builder.Services.AddGrpc(options =>
            {
                options.MaxSendMessageSize = null;
                options.MaxSendMessageSize = null;
            }); 

            var app = builder.Build();
            app.MapGrpcService<BookServiceImpl>();
            
            Console.WriteLine($"{DateTime.Now},the grpc service started at http://localhost:8888");
            await app.RunAsync("http://localhost:8888");
        }
    }

    public class BookServiceImpl:BookService.BookServiceBase
    {
        private static long id = 0;
        private static long GetIncrementId()
        {
            return Interlocked.Increment(ref id);
        }

        public List<Book> GetBooksList(int cnt=1000000)
        {
            var bksList = new List<Book>();
            for(int i=0;i<cnt;i++)
            {
                var a = GetIncrementId();
                bksList.Add(new Book()
                {
                    Id=a,
                    Name=$"Name_{a}",
                    ISBN=$"ISBN_{a}_{Guid.NewGuid():N}",
                    Abstract=$"Abstract_{a}",
                    Author=$"Author_{a}",
                    Comment=$"Comment_{a}",
                    Content=$"Content_{a}",
                    Summary=$"Summary_{a}",
                    Title=$"Title_{a}",
                    Topic=$"Topic_{a}"
                });
            }
            return bksList;
        }


        public override Task<GetBooksListResponse> GetBooksList(GetBooksListRequest request, ServerCallContext context)
        {
            var count = request.Cnt is 0 ? 1000000 : request.Cnt;
            var bksList = GetBooksList(count);

            var response=new GetBooksListResponse();
            response.Books.AddRange(bksList.ToProtoList());
            return Task.FromResult(response);
        }
    }

    public static class BookMapper
    {
        public static BookProto ToProtoBook(this Book bk)
        {
            return new BookProto
            {
                Id = bk.Id,
                Name = bk.Name ?? "",
                Isbn = bk.ISBN ?? "",
                Author=bk.Author??"",
                Abstract = bk.Abstract ?? "",
                Comment = bk.Comment ?? "",
                Content = bk.Content ?? "",
                Summary = bk.Summary ?? "",
                Title = bk.Title ?? "",
                Topic = bk.Topic ?? ""
            };
        }

        public static Book ToModel(this BookProto pt)
        {
            return new Book
            {
                Id = pt.Id,
                Name = pt.Name,
                ISBN = pt.Isbn,
                Abstract = pt.Abstract,
                Author = pt.Author,
                Comment=pt.Comment,
                Content=pt.Content,
                Summary=pt.Summary,
                Title=pt.Title,
                Topic=pt.Topic
            };
        }

        public static List<Book> ToModelList(this RepeatedField<BookProto> list)
        {
            return list.Select(ToModel).ToList();
        }

        public static List<BookProto> ToProtoList(this List<Book> list)
        {
            return list.Select(ToProtoBook).ToList();
        }
    }


     
    public class Book
    {
        public long Id { get; set; }
        public string Name { get; set; }
        public string ISBN { get; set; }
        public string Abstract { get; set; }
        public string Author { get; set; }
        public string Comment { get; set; }
        public string Content { get; set; }
        public string Summary { get; set; }
        public string Title { get; set; }
        public string Topic { get; set; }
    }

}

//Consumer

//D:\C\ConsoleApp20\ConsoleApp20\Program.cs
using Grpc.Net.Client;
using GrpcBookServer;

namespace ConsoleApp20
{
    internal class Program
    {
        private static string requestUrl = "http://localhost:8888";
        static GrpcChannel channel;
        static BookService.BookServiceClient client;
        static System.Timers.Timer tmr;
        static void Main(string[] args)
        {
            channel = GrpcChannel.ForAddress(requestUrl, new GrpcChannelOptions
            {
                MaxSendMessageSize =null,
                MaxReceiveMessageSize=null
            });
             
            client = new BookService.BookServiceClient(channel);
            Task.Run(async () =>
            {
                await ConsumeGrpcServiceAsync();
            });
            tmr = new System.Timers.Timer();
            tmr.Interval = 3000;
            tmr.Elapsed += async (s, e) =>
            {
               await  ConsumeGrpcServiceAsync();
            };
            tmr.Start();
            Console.ReadLine();
        }

        static async Task ConsumeGrpcServiceAsync(int cnt= 1000000)
        {
            var resp = await client.GetBooksListAsync(new GetBooksListRequest { Cnt = cnt });
            var books = resp.Books;
            Console.WriteLine($"{DateTime.Now},receive from server books count:{books.Count},First Id:{books.FirstOrDefault()?.Id},Last Id:{books.LastOrDefault()?.Id}");

        }
    }
}

image