快速搭建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