1. 程式人生 > >快速搭建CentOS+ASP.NET Core環境支援WebSocket

快速搭建CentOS+ASP.NET Core環境支援WebSocket

以前用python,go嘗試在linux下做web服務,python沒有強型別支援與高效能,go又沒有很好的整合開發環境(還有強迫症的語法),回頭看了幾次.net,都沒有時間嘗試,現終於實現了這些想法,與大家分享。做web大專案,做工程,必須要有稱手的工具幫我除錯、測試、開發。工程化很重要,VS是一個稱職好選手。

環境:CentOS 7.x,.net core 2

以下.net core 2安裝操作為官方方法。如果你使用Docker,那麼更簡單了,只需要docker pull microsoft/dotnet就可以了。如果你使用Bash On Windows,那麼與實際對應的Linux子系統安裝完全相同。

https://www.microsoft.com/net/learn/get-started/linux/centos

CentOS安裝.net core(其他系統在這個頁面都可以選擇,包括:RHEL、Ubuntu、Debian、Fedora、openSUSE):

依次執行(root下沒有sudo也可以):

sudo rpm --import https://packages.microsoft.com/keys/microsoft.asc

sudo sh -c 'echo -e "[packages-microsoft-com-prod]\nname=packages-microsoft-com-prod \nbaseurl= https://packages.microsoft.com/yumrepos/microsoft-rhel7.3-prod\nenabled=1\ngpgcheck=1\ngpgkey=https://packages.microsoft.com/keys/microsoft.asc" > /etc/yum.repos.d/dotnetdev.repo'

sudo yum update

sudo yum install libunwind libicu

sudo yum install dotnet-sdk-2.1.101

只需要這幾部,.net core 2就安裝好了。

用dotnet命令建立空web專案,編譯測試:

dotnet new web -o wstest
dotnet build wstest
dotnet run --project wstest

注:dotnet new 命令會幫你建立專案,包括資料夾,必要的專案檔案。build與run命令之前可以cd wstest,這樣就可以免去後面的引數,把當前目錄當作操作物件。

注:可以再簡潔點:dotnet run -p wstest。編譯執行一起完成。

無意外的話,專案已經啟動,並且在localhost(埠預設是5000)開始監聽http請求。做這些事情的方便快捷是python、go、node.js、PHP、JAVA等等不能比的。當然,如果你在Windows下,就更快了,包括後續的編碼、除錯、測試。

接下來,我們進入WebSocket階段。

1、我們先建立一個html檔案,放到專案的wwwroot目錄下,用於測試WebSocket。

<!DOCTYPE html>

<html>

<body>

    <div id="out"></div>

    <script>

        var ws = new WebSocket("ws://127.0.0.1:5000/ws")

        ws.onopen = function () {

            log("open")

        }

        ws.onmessage = function (ev) {

            log(ev.data)

        }

        function log(text) {

            out.innerHTML+="<div>"+text+"</div>"

        }

    </script>

</body>

</html>

2、開啟asp.net的靜態檔案訪問與WebSocket支援。Linux下的asp.net宿主服務Kestrel已經支援WebSocket,可以直接執行。

在Startup.cs的public Configure成員函式中新增:

app.UseWebSockets();
app.UseStaticFiles();

3、為Startup.cs的Startup類新增WebSocket處理方法(成員函式):

async Task Echo(HttpContext ctx, WebSocket ws)

        {

            var bytes = System.Text.UTF8Encoding.UTF8.GetBytes("ok");

            var buff = new ArraySegment<byte>(bytes);

            await ws.SendAsync(buff, WebSocketMessageType.Text, true, System.Threading.CancellationToken.None);

        }

4、再為Startup.cs的public Configure成員函式新增處理函式,可選擇去掉app.Run的呼叫:

app.Use(async (context, next) =>

            {

                if (context.WebSockets.IsWebSocketRequest)

                {

                    WebSocket ws = await context.WebSockets.AcceptWebSocketAsync();

                    await Echo(context, ws);

                }

                else

                    await next();

            });

5、Startup.cs檔案的頭部新增引用:

using System.Net.WebSockets;

程式碼就這麼多了。接下來驗證結果。

注意:

1、如果你放到華為雲、騰訊雲,這樣有安全組的伺服器上,你需要開啟之前提到的埠TCP轉入許可權。

2、test.html中的websocket地址請更換為實際的伺服器地址與埠。

3、動態IP支援的雲主機自己是不知道自己的外網IP地址的,所以只能監聽0.0.0.0埠或者內外繫結的埠。

4、注意自己的防火牆是否放行對應的埠,可用iptables或firewall-cmd查詢,CentOS7預設採用firewall-cmd作為防火牆的操作端。iptables也可以,但是不能儲存。可安裝iptables-services解決。

dotnet run以後,你可以找個瀏覽器訪問你的http服務了。

如果順利,你可以看到頁面輸出ok字樣。說明,asp.net core的靜態頁面已經輸出,並且頁面用WebSocket協議訪問我們的http服務。

不順利的可能基本是監聽的IP地址無法訪問或埠未開放。

另一個原因是dotnet建立的專案裡沒有專案配置檔案,你可能不知道怎麼配置監聽ip與埠。下面是launchSettings.json檔案。你應該把它放到專案的Properties資料夾中。它是我從VisualStudio嚮導生成的檔案中提取的。

{

  "profiles": {

    "anyname": {

      "commandName": "Project",

      "launchBrowser": true,

      "environmentVariables": {

        "ASPNETCORE_ENVIRONMENT": "Development"

      },

      "applicationUrl": "http://0.0.0.0:5000/"

    }

  }

}

好了,祝你順利!

原文:https://www.cnblogs.com/fyter/p/linux_centos_aspnet_core_websocket.html

.NET社群新聞,深度好文,歡迎訪問公眾號文章彙總 http://www.csharpkit.com

640?wx_fmt=jpeg