ساخت داشبوردهای آنگولار بلادرنگ با WebSockets
بیشتر داشبوردها قدیمی و بیروح به نظر میرسند. کاربران وارد صفحه میشوند و منتظر میمانند. آنها یا دکمه refresh را میزنند یا با polling مداوم دستوپنجه نرم میکنند که باعث کند شدن سرور شما میشود.
WebSockets این وضعیت را تغییر میدهند. به جای اینکه کلاینت درخواست داده بدهد، سرور آن را push میکند. این روش برای متریکهای زنده، فعالیت کاربران یا دادههای مالی ایدهآل است.
در اینجا نحوه ساخت یک داشبورد بلادرنگ آمادهی تولید (production-ready) با استفاده از Angular، RxJS و Signals آورده شده است.
معماری
- استفاده از RxJS webSocket برای مدیریت اتصال.
- استفاده از shareReplay برای اینکه چندین کامپوننت بتوانند از یک اتصال استفاده کنند.
- استفاده از Angular Signals برای داشتن یک منبع واحد حقیقت (single source of truth).
- استفاده از الگوی Store برای ساده نگه داشتن کامپوننتها.
۱. لایه سرویس (The Service Layer)
برای هر کامپوننت یک اتصال جدید باز نکنید. از webSocket subject از rxjs/webSocket استفاده کنید. از shareReplay استفاده کنید تا کل اپلیکیشن شما از یک استریم واحد استفاده کند. این کار از پردازش صدها اتصال غیرضروری توسط سرور شما جلوگیری میکند.
۲. استور سیگنال (The Signal Store)
از قرار دادن منطق تجاری (business logic) در کامپوننتها خودداری کنید. یک Store بسازید که به سرویس شما subscribe شود. این استور، متریکها و هشدارها را در Signals نگه میدارد. سپس کامپوننتهای شما فقط این سیگنالها را میخوانند. این کار باعث میشود رابط کاربری (UI) شما سریع و تست آن آسان باشد.
۳. کامپوننتهای تمیز (Clean Components)
کامپوننتهای شما فقط باید یک کار انجام دهند: رندر کردن دادهها. اگر از یک استور مبتنی بر Signal استفاده کنید، کد کامپوننت شما بسیار کوچک باقی میماند. کد فقط یک مقدار را میخواند و آن را روی صفحه نمایش میدهد.
نکات حرفهای کلیدی
- وضعیت اتصال: همیشه یک نشانگر "Live" یا "Reconnecting" نمایش دهید. کاربران باید بدانند که آیا دادههایشان بهروز است یا خیر.
- مدیریت خطا: برای تلاش مجدد جهت اتصال (reconnections)، از روش exponential backoff استفاده کنید. وقتی سرور از دسترس خارج میشود، به آن فشار نیاورید.
- مدیریت دادهها: از
.slice()روی آرایههای هشدار خود استفاده کنید. این کار باعث میشود تاریخچه شما بدون مصرف بیش از حد حافظه، کاربردی باقی بماند.
WebSockets زمانی بهترین عملکرد را دارند که به ارتباط دوطرفه نیاز داشته باشید. اگر فقط نیاز به دریافت داده دارید، Server-Sent Events (SSE) را به عنوان یک گزینه سادهتر بررسی کنید.
دیگر کاربران خود را مجبور به فشردن دکمه refresh نکنید.
منبع: https://dev.to/rigole/building-real-time-dashboards-in-angular-with-websockets-a-complete-guide-10he