SuperSocket入門(三)-Telnet多服務實例和服務實例交互配置詳解

来源:http://www.cnblogs.com/fly-bird/archive/2017/01/20/6329653.html
-Advertisement-
Play Games

在SuperSocket入門(二)中我們已經簡單瞭解了通過配置App.config文件使用BootStrap啟動SuperSocket服務。我們先來看一下上個案例中的基本配置文件示例: <?xml version="1.0" encoding="utf-8"?> <configuration> <c ...


    在SuperSocket入門(二)中我們已經簡單瞭解了通過配置App.config文件使用BootStrap啟動SuperSocket服務。我們先來看一下上個案例中的基本配置文件示例:
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<!--log 日誌記錄-->
<section name="log4net" type="System.Configuration.IgnoreSectionHandler"/>
<!--SocketEngine-->
<section name="superSocket" type="SuperSocket.SocketEngine.Configuration.SocketServiceConfig, SuperSocket.SocketEngine"/>
</configSections>
<!--服務信息描述,在window服務模式下的名稱標識-->
<appSettings>
<add key="ServiceName" value="SupperSocketService"/>
<add key="ServiceDescription" value="黃昏前黎明後的Socket程式"/>
</appSettings>
<!--SuperSocket服務配置信息 serverType是項目的服務如我自定義的myserver-->
<!--name: 實例名稱
serverType: 實例運行的AppServer類型
ip: 偵聽ip
port: 偵聽埠-->
<superSocket>
<servers>
<!--textEncoding 編碼方式"gb2312","utf-8" 預設是acii-->
<server name="SuperSocketDemo" textEncoding="gb2312" serverType="SuperSocketDemo.Server.MyServer,SuperSocketDemo" ip="Any" port="2020" maxConnectionNumber="100">
</server>
</servers>
</superSocket>
<startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5.2"/>
</startup>
</configuration>
App.config

       1、服務名稱:

       <appSettings>

            <add key="ServiceName" value="SupperSocketService"/>

            <add key="ServiceDescription" value="黃昏前黎明後的Socket程式"/>        </appSettings>        這個配置項將被用作SuperSocket系統服務的名稱。如果ServiceName設置成SupperSocketService, 則運行InstallService.bat這個批處理文件之後(註意:該處理文件使用的是SuperSocket.SocketService.exe -i命令,使用supersocket.socketservice.exe務必使server所需要的所有程式集都和SuperSocket.SocketService.exe在同一目錄), SuperSocket系統服務將以"SupperSocketService"這個名字安裝到系統之中。        2、 SuperSocket的根配置        <socketServer loggingMode="IndependantFile">                  ....        </socketServer>       根配置中的參數詳情:        loggingMode 值:           ShareFile: 多個伺服器實例共用同日誌文件,預設選項;                                    IndependantFile:多個伺服器實例擁有獨立的日誌文件;                                               Console: 控制台日誌輸出,只在控制台應用程式中有效。        maxWorkingThreads:線程池最大工作線程數量        minWorkingThreads:線程池最小工作線程數量        maxCompletionPortThreads:線程池最大完成埠線程數量        minCompletionPortThreads:線程池最小完成埠線程數量            3、伺服器實例配置          <servers>               <server name="SuperSocketDemo" textEncoding="gb2312" serverType="SuperSocketDemo.Server.MyServer,SuperSocketDemo" ip="Any" port="2020" maxConnectionNumber="100">               </server>          </servers>          伺服器實例配置詳情:
  • name: 伺服器實例名稱
  • serviceName: 指定伺服器實例運行的服務的名稱。此名稱為定義此伺服器實例運行的服務的節點的名稱。
  • ip: 指定socket伺服器監聽的伺服器IP地址。Any: 監聽本機所有的IPv4地址;IPv6Any, 監聽本機所有IPv6的地址。
  • port: 指定socket伺服器監聽的埠。
  • mode: Sync:同步模式;Async: 非同步模式;Udp: Udp協議
  • disabled: true或者false。是否禁用該伺服器實例,預設為否。
  • readTimeOut: 從socket讀取數據超時時間,預設為0。
  • sendTimeOut: 從socket發送數據超時時間,預設為0。
  • maxConnectionNumber: 最大允許的客戶端連接數目,預設為100。
  • receiveBufferSize: 用於接收數據的緩衝區大小,預設為2048。
  • sendBufferSize: 用戶發送數據的緩衝區大小,預設為2048。
  • logCommand: true或者false,是否記錄命令。
  • clearIdleSession: true或者false, 是否清除空閑會話,預設為false。
  • clearIdleSessionInterval: 清除空閑會話的時間間隔,預設為120,單位為秒。
  • idleSessionTimeOut: 會話超時時間,預設值為300,單位為秒。
  • security: Empty, Tls或者Ssl3。 Socket伺服器所採用的傳輸層加密協議,預設值為空。
  • maxCommandLength: 最大允許的命令長度,預設值為1024。
  • disableSessionSnapshot: 是否禁用會話快照,預設值為false。(1.4 SP1)
  • sessionSnapshotInterval: 生成會話快照的時間間隔。預設值為5,單位為秒。
  • keepAliveTime: keep alive消息發送時間間隔。預設值為600, 單位為秒。
  • keepAliveInterval:keep alive失敗重試的時間間隔。預設值為60, 單位為秒。
       4、多伺服器實例的配置        SuperSocket支持在同一程式中運行多個伺服器實例監聽在不同的IP或埠,只需在配置文件中添加兩個server節點,設置不同的實例名稱和IP埠組合即可。   <servers>      <server name="MyServerA"           serviceName="SupperSocketServiceA"           ip="Any"           port="2016"> </server> <server name="MyServerB"           serviceName="SupperSocketServiceB"           ip="Any"           port="2017"> </server> <services>          <service name="SupperSocketServiceA" type="SuperSocketDemo.Server.MyServerA,SuperSocketDemo.SupperSocketServiceA" />          <service name="SupperSocketServiceB" type="SuperSocketDemo.Server.MyServerB,SuperSocketDemo.SupperSocketServiceB" /> </services>          服務配置          name: 服務定義的名稱,即伺服器實例節點serviceName所對應的名稱。          type: 該服務所對應MyServer類型的完整名稱。         在某些情況下,需要兩個伺服器實例之間進行交互。例如MyServerA上的客戶端C1向MyServerB上的客戶端C2轉發消息,這樣就需要MyServerA接收到C1的命令之後通過MyServerB將消息轉發給客戶端C2。在MyServerA的OnStartup方法裡面可利用SocketServerManager的GetServerByName(string name)方法通過伺服器實例的名稱來獲取伺服器實例:  
public class MyServerA : AppServer
{
private IDespatchServer m_DespatchServer;
 
protected override void OnStartup()
{
m_DespatchServer = SocketServerManager.GetServerByName("ServerB") as IDespatchServer;
base.OnStartup();
}
 
internal void DespatchMessage(string targetSessionKey, string message)
{
m_DespatchServer.DispatchMessage(targetSessionKey, message);
}
}
MyServerA 類
public class MyServerB : AppServer, IDespatchServer
{
public void DispatchMessage(string sessionKey, string message)
{
var session = GetAppSessionByIndentityKey(sessionKey);
if (session == null)
return;
 
session.SendResponse(message);
}
}
}
MyServerB 類
interface IDespatchServer
{
void DispatchMessage(string sessionKey, string message);
}
 
IDespatchServer類        這樣就可以在MyServerA中通過調用MyServerB實例的方法來向MyServerB的客戶端發送消息了。使用 SuperSocket 實現 Socket 伺服器的時候,不可避免的需要在配置文件中定義一些參數。 SuperSocket 提供了非常簡單的方法,讓我們在配置文件中定義這些參數,然後在代碼中讀取它們。服務端擴展配置,自定義屬性欄位我們後面再來學習。
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 很多情況下我們需要獲取外網的IP地址,一般用自帶的方法獲取到的都是不准確,往往獲取到的是內網的IP地址,所以需要採用外部網站介面來獲取。 代碼 通過訪問第三方介面來獲取真實的ip地址 ...
  • 開始學習mvc開髮網站的時候,看了傳智博客的視頻教程,其中學習了一個和牛逼的框架,開始激動的深入學習,學完後卻發現其實那套框架太重並不適合一些中小型的網站開發,並且也使用導航屬性關聯外鍵,導致打開網站的速度非常緩慢,最快也要8s以上,所有之後總結如下。 原來框架結構 EF實體關係 由於框架太過於笨重 ...
  • 這裡採用的是.net的一個引用NReco.Recommender.dll,這是一個國外電影網站推薦系統衍生而來的,有興趣的可以到他們的官網看看。 以圖書商城為例 MVC 構造行為數據 首先需要對資料庫進行設計,增加一張用戶的行為數據表,記錄用戶訪問網站的行為,例如商城的一般記錄瀏覽的商品和購買過的商 ...
  • 根據以前的做法是拼接sql語句,這會增加維護成本,因為sql語句里的內容不會報錯,所以在使用ef的時候必須要拋棄拼接sql語句的習慣。 構建實例 構建搜索條件 參數過濾 很多情況下查詢到的結果並不能滿足我們的需要,還需要進行一些處理,這裡需要用linq ...
  • 網站的後臺,多數是需要使用datatable來展示數據的,因為datatable的功能比較強大,可以更好的使用。 引用css html代碼 js代碼 服務端代碼 ...
  • 現在的.NET Core 1.0版本是一個很小的核心,APIs和工具也並不完整,但是隨著.Net Core的不斷完善,補充的Apis和創新也會一起整合到.NET Framework中。 安裝centos系統 請自行安裝或百度教程 安裝 libicu包 和 dotnet 溫馨提示:如果需要用vsc編輯 ...
  • 方法里包括了圖片大小限制、圖片尺寸、文件內容等等的判斷。。。 該案例是mvc下的demo,支持單張圖片上傳。 一般處理程式 csharp public void ProcessRequest(HttpContext context) { context.Response.ContentType = ...
  • 關於C#調用廣州醫保HG_Interface.dll調用的一些總結(外部組件異常) ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...