亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

.NET開源高性能Socket通信中間件Helios介紹及演示

2019-11-14 13:34:14
字體:
來源:轉載
供稿:網友

一:Helios是什么

  Helios是一套高性能的Socket通信中間件,使用C#編寫。Helios的開發受到Netty的啟發,使用非阻塞的事件驅動模型架構來實現高并發高吞吐量。Helios為我們大大的簡化了Socket編程,它已經為我們處理好了高并發情況下的解包,粘包,buffer管理等等。

  GitHub:https://github.com/helios-io/helios/

  為避免誤會特別提示:helios不是本人作品,小弟還在努力的路上。

二:Helios的特點

  1.Powerful APIs

    Takes the complexity out of socket PRogramming with intelligent I/O, concurrency, buffer management, and pipelining APIs.

    使用socket編程不再復雜。提供智能的I/O,并發,buffer管理,管道形式的API。

  2.Event-Driven

    Helios is Reactive - it uses a event-driven architecture to simplify development and build responsive systems that scale.

    Helios是反應式的,它使用事件驅動的架構來簡化開發和構建易伸縮的系統。

  3.Performant

    Performance is a cross-cutting concern we factor in at every level in the design of the framework in order to eliminate overhead for your apps and clients.

    這個系統在開發和設計的時候都充分考慮到了性能,構建你的app和client的時候請消除這方面的顧慮。

  4.Battle-Tested

    Helios powers the clustering and remoting capbilities built into Akka.NET and more.

    Akka.net的集群,遠程功能構建在Helios之上。

三:一個基于Helios的聊天室示例

  要用來演示Socket通信那么最好的示例無非就是聊天程序了。

  整個解決方案包含3個項目:

  

  1.HeliosChat.Common

  這個項目里是一些公共的類型,新建完之后使用nuget添加helios的庫

  

  Message 類:所有發送的消息都是通過Message包裝的,每一個消息都有一個Command跟Content來構成。

 public class Message    {        public Command Command { get; set; }        public string Content { get; set; }    }

  Command枚舉:用來描述消息的命令

public enum Command    {        Join,        Send,    }

  MessageConverter靜態類:這個類用來轉換Message對象為Byte[],或者把Byte[]轉換成Message對象。Message對象在通過Helios傳輸的時候需要先轉成Byte[],所以我們需要自己定義包的格式。我們用Byte[]的前四位來存放Command,Content轉成Byte后從第5位開始存放。

public class MessageConverter    {        public static Message ToMessage(NetworkData data)        {            try            {                var commandData = data.Buffer.Take(4).ToArray();                var contentData = data.Buffer.Skip(4).Take(data.Buffer.Length - 4).ToArray();                var command = BitConverter.ToInt32(commandData,0);                var content = Encoding.UTF8.GetString(contentData);                return new Message()                {                    Command = (Command)command,                    Content = content                };            }            catch (Exception exc)            {                Console.WriteLine("Cant convert NetworkData to Message : {0}", exc.Message);            }            return null;        }        public static byte[] ToBytes(Message message)        {            try            {                var commandBytes = BitConverter.GetBytes((int)message.Command);                var messageBytes = Encoding.UTF8.GetBytes(message.Content);                var bytes = new byte[commandBytes.Length + messageBytes.Length];                commandBytes.CopyTo(bytes, 0);                messageBytes.CopyTo(bytes, commandBytes.Length);                return bytes;            }            catch (Exception exc)            {                Console.WriteLine("Cant convert message to bytes : {0}", exc.Message);            }            return null;        }    }

  2.HeliosChat.Server

  不用說也知道,這是聊天室的服務端,負責連接用戶及轉發消息。

internal class Program    {        private static readonly ConcurrentDictionary<string, IConnection> Clients =            new ConcurrentDictionary<string, IConnection>();        private static void Main(string[] args)        {            var host = IPAddress.Any;            var port = 9991;            Console.Title = "Server";            Console.WriteLine("Starting server on {0}:{1}", host, port);            var serverFactory =                new ServerBootstrap()                    .SetTransport(TransportType.Tcp)                    .Build();            var server = serverFactory.NewReactor(NodeBuilder.BuildNode().Host(host).WithPort(port));            server.OnConnection += (address, connection) =>            {                Console.WriteLine("Connected: {0}", address);                connection.BeginReceive(Receive);            };            server.OnDisconnection += (reason, address) =>                Console.WriteLine("Disconnected: {0}; Reason: {1}", address.RemoteHost, reason.Type);            server.Start();            Console.WriteLine("Running, press any key to exit");            Console.ReadKey();        }        /// <summary>        /// 處理接受到的消息        /// </summary>        /// <param name="data"></param>        /// <param name="channel"></param>        public static void Receive(NetworkData data, IConnection channel)        {            var message = MessageConverter.ToMessage(data);            switch (message.Command)            {                case Command.Join:                    JoinGroup(message.Content, channel);                    break;                case Command.Send:                    Broadcast(message.Content);                    break;            }        }        public static void JoinGroup(string clientName, IConnection channel)        {            if (Clients.TryAdd(clientName, channel))            {                Broadcast(string.Format("{0} join group successful .", clientName));            }            else            {                var errMsg = new Message()                {                    Command = Command.Send,                    Content = "client name is used."                };                SendMessage(channel, errMsg);            }        }        /// <summary>        /// 廣播消息        /// </summary>        /// <param name="clientMessage"></param>        public static void Broadcast(string clientMessage)        {            Console.WriteLine(clientMessage);            var clientName = clientMessage.Split(':')[0];            var message = new Message            {                Command = Command.Send,                Content = clientMessage            };            foreach (var client in Clients)            {                if (client.Key != clientName)                {                    SendMessage(client.Value, message);                }            }        }        public static void SendMessage(IConnection connection, Message message)        {            var messageBytes = MessageConverter.ToBytes(message);            connection.Send(new NetworkData { Buffer = messageBytes, Length = messageBytes.Length });        }    }

  3.HeliosChat.Client

  聊天服務的客戶端

internal class Program    {        public static IConnection Client;        public static string ClientName;        private static void Main(string[] args)        {            var host = IPAddress.Loopback;            var port = 9991;            var connectionFactory =                new ClientBootstrap()                    .SetTransport(TransportType.Tcp).Build();            //New一個Client            Client = connectionFactory.NewConnection(Node.Empty(), NodeBuilder.BuildNode().Host(host).WithPort(port));            Client.OnConnection += (address, connection) =>            {                Console.WriteLine("Connect server successful.");                connection.BeginReceive(Received);            };            Client.OnDisconnection += (address, reason) => Console.WriteLine("Disconnected.");            Console.WriteLine("Input ClientName ");            ClientName = Console.ReadLine();            Console.Title = string.Format("Client {0}", ClientName);            //建立連接            Client.Open();            //加入聊天組            Join();            //等待輸入            WaitInput();        }        public static void WaitInput()        {            while (true)            {                var input = Console.ReadLine();                if (!string.IsNullOrEmpty(input))                {                    var message = MakeSendMessage(input);                    SendMessage(Client, message);                }            }        }        /// <summary>        /// Jion chat group        /// </summary>        public static void Join()        {            var message = MakeJoinMessage();            SendMessage(Client,message);        }        /// <summary>        /// 處理接受到的消息        /// </summary>        /// <param name="data"></param>        /// <param name="responseChannel"></param>        public static void Received(NetworkData data, IConnection responseChannel)        {            var message = MessageConverter.ToMessage(data);            if (message.Command == Command.Send)            {                Console.WriteLine(message.Content);            }        }        /// <summary>        /// 構造聊天消息        /// </summary>        /// <param name="input"></param>        /// <returns></returns>        public static Message MakeSendMessage(string input)        {            return new Message            {                Command = Command.Send,                Content = string.Format("{0}:{1}", ClientName, input)            };        }        /// <summary>        /// 構造加入組的消息        /// </summary>        /// <returns></returns>        public static Message MakeJoinMessage()        {            var message = new Message();            message.Command = Command.Join;            message.Content = ClientName;            return message;        }        public static void SendMessage(IConnection connection, Message message)        {            var messageBytes = MessageConverter.ToBytes(message);            connection.Send(new NetworkData { Buffer = messageBytes, Length = messageBytes.Length });        }    }

  4.運行結果

  這樣一個簡單的聊天室程序就完成了。

四:Helios 2.0

  helios 1.0的異步編程模型是基于APM的,從helios 2.0開始會改成SocketAsyncEventArgs方式來實現異步。SocketAsyncEventArgs底層封裝了IOCP,IOCP是Windows server上Socket通訊性能最高的技術,使用了IOCP的helios 2.0勢必具有更高的性能,所以對于helios 2.0還是非常期待的。

  示例下載:http://files.VEVb.com/files/kklldog/HeliosChat.7z


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
色无极影院亚洲| 国产精品一区电影| 国产精品稀缺呦系列在线| 亚洲自拍偷拍第一页| 成人xvideos免费视频| 日韩第一页在线| 国外成人性视频| 亚洲精品中文字| 亚洲a成v人在线观看| 亚洲国产欧美一区二区三区同亚洲| 国产精品欧美一区二区三区奶水| 欧美乱大交做爰xxxⅹ性3| 狠狠久久亚洲欧美专区| 中文字幕欧美日韩在线| 亚洲欧美制服综合另类| 亚洲性视频网站| 日韩中文字幕网址| 久久夜色精品亚洲噜噜国产mv| 久久久久久久电影一区| 久久夜精品va视频免费观看| 国产91成人在在线播放| 亚洲最大av网站| 热re91久久精品国99热蜜臀| 欧美日韩国产成人在线| 午夜伦理精品一区| 欧美国产日韩在线| 久久人人爽亚洲精品天堂| 欧美极品少妇xxxxⅹ免费视频| 日韩精品视频在线观看免费| 亚洲免费一在线| 国产精品老女人视频| 亚洲欧美精品一区| 亚洲91精品在线观看| 精品福利免费观看| 亚洲午夜性刺激影院| 亚洲激情在线观看视频免费| 色综合亚洲精品激情狠狠| 国产suv精品一区二区| 92国产精品视频| 久久精品99久久久久久久久| 久久久人成影片一区二区三区| 亚洲人成网站色ww在线| 国产亚洲免费的视频看| 高潮白浆女日韩av免费看| 国产精品免费一区二区三区都可以| 亚洲精品永久免费精品| 欧美性猛xxx| 欧美另类极品videosbest最新版本| 性色av一区二区三区在线观看| 91在线观看欧美日韩| 日韩中文字幕在线精品| 色先锋资源久久综合5566| 国产欧美精品日韩| 综合国产在线视频| 最近更新的2019中文字幕| 中文精品99久久国产香蕉| 97视频在线播放| 国产精品大片wwwwww| 国产不卡视频在线| 91亚洲国产成人精品性色| 国产精品扒开腿做| 亚洲电影免费观看高清完整版| 亚洲深夜福利在线| 国产一区二区在线免费| 91精品国产一区| 亚洲aⅴ男人的天堂在线观看| 亚洲欧美激情在线视频| 国产精品久久久久久av| 久久精品99久久香蕉国产色戒| 中文字幕在线视频日韩| 亚洲精品电影网站| 久久99亚洲热视| 亚洲视频在线观看视频| 亚洲成人性视频| 久久久久国产精品免费| 日韩中文字幕精品| 国产成人一区二区三区小说| 欧美性69xxxx肥| 韩国国内大量揄拍精品视频| 91精品国产色综合久久不卡98| 中文字幕在线精品| 亚洲91精品在线| 97人人爽人人喊人人模波多| 亚洲精品98久久久久久中文字幕| 精品欧美激情精品一区| 伊人久久精品视频| 精品人伦一区二区三区蜜桃网站| 日韩av电影免费观看高清| 国产日韩在线免费| 97avcom| 欧美黑人一级爽快片淫片高清| 亚洲精品在线观看www| 中文字幕日韩在线观看| 久久伊人免费视频| 色偷偷亚洲男人天堂| 亚洲永久免费观看| 一区二区欧美在线| 97视频在线观看播放| 欧美日韩免费观看中文| 日韩激情视频在线| 国产在线观看一区二区三区| 欧美日韩精品二区| 亚洲欧美日韩精品久久亚洲区| 久久中文久久字幕| 国产精品高潮呻吟久久av黑人| 亚洲影视中文字幕| 亚洲国产另类 国产精品国产免费| 精品久久久久久久久久ntr影视| 久久国产精彩视频| 欧美午夜影院在线视频| 亚洲一区美女视频在线观看免费| 国产免费一区视频观看免费| 7777kkkk成人观看| 欧美与黑人午夜性猛交久久久| 中文字幕成人在线| 亚洲欧美国产精品久久久久久久| 亚洲人成网站色ww在线| 亚洲免费伊人电影在线观看av| 日韩精品极品视频| 欧美一区二区三区四区在线| 欧美日本精品在线| 北条麻妃一区二区在线观看| 亚洲黄色av女优在线观看| 亚洲а∨天堂久久精品喷水| 国产精品一区二区三区成人| 久久精品视频99| 亚洲自拍小视频| 日韩a**中文字幕| 亚洲一区二区久久久久久| 亚洲国产精品999| 国产成人综合一区二区三区| 亚洲一区中文字幕| 中文字幕久精品免费视频| 欧美老女人性视频| 亚洲一区二区久久久| 欧美高清在线播放| 成人性生交大片免费看小说| 欧美专区在线视频| 91精品在线影院| 日韩精品在线播放| 成人精品一区二区三区电影黑人| 秋霞成人午夜鲁丝一区二区三区| 日韩国产精品一区| 色综合五月天导航| 亚洲一区中文字幕| 日韩在线观看成人| 97视频在线观看网址| 国产欧美一区二区三区久久| 亚洲最新av在线| 日韩国产欧美区| 亚洲国产精品久久久| 亚洲成人精品av| 国产精品免费福利| 久久青草福利网站| 97视频色精品| 久久成人在线视频| 亚洲欧洲在线免费| 中文字幕在线日韩| 久久精品中文字幕免费mv| 国产99久久精品一区二区 夜夜躁日日躁| 欧美性生交xxxxxdddd| 欧美精品生活片| 中文字幕少妇一区二区三区| 亚洲最大的网站|