กรุณาปิด โปรแกรมบล๊อกโฆษณา เพราะเราอยู่ได้ด้วยโฆษณาที่ท่านเห็น
Please close the adblock program. Because we can live with the ads you see


ข่าว เบื้องหลังสถาปัตยกรรมใหม่ Teams ย้ายจาก Electron/AngularJS เป็น WebView2/React

  • ผู้เริ่มหัวข้อ ผู้เริ่มหัวข้อNews 
  • วันที่เริ่มต้น วันที่เริ่มต้น

News 

Moderator
สมาชิกทีมงาน
Moderator
Verify member
ไมโครซอฟท์เขียนบล็อกอธิบายเบื้องหลังการแก้ปัญหาระดับโลก (ระดับผู้ใช้ 250 ล้านคนต่อเดือน) เปลี่ยนสถาปัตยกรรมเบื้องหลัง Microsoft Teams บนวินโดวส์เป็นตัวใหม่ที่ดีขึ้น เร็วขึ้น กินแรมน้อยลง

ไมโครซอฟท์เล่าว่าไคลเอนต์ตัวเดิมของ Teams เริ่มเขียนในปี 2015 (Teams เปิดตัวครั้งแรกปลายปี 2016) ตั้งเป้าหมายเรื่องการทำงานข้ามแพลตฟอร์มระหว่างเว็บ-เดสก์ท็อปเป็นสำคัญ จึงเลือกใช้เทคโนโลยีที่มีในตอนนั้นคือ Electron เป็นโฮสต์, AngularJS เป็นเฟรมเวิร์คเว็บ และสร้าง custom controls ของตัวเองขึ้นมาด้วย HTML/CSS

แต่เมื่อพัฒนาความสามารถของ Teams มาเรื่อยๆ ทีมงานก็พบข้อจำกัดเรื่องการใช้ทรัพยากร จึงหาเทคโนโลยีทางเลือกใหม่ โปรเจคนี้ใช้ชื่อว่า "north star" โดยเปลี่ยน Electron มาใช้ WebView2, เปลี่ยนเฟรมเวิร์คมาใช้ React และแยก Data Layer ออกมาต่างหาก, ตัวคอนโทรลใช้ Fluent UI ซึ่งเป็นอีกโครงการของไมโครซอฟท์เอง

04b7a49b08c2d29d1eb5f3d54de88ad4.png


  • Fluent UI เป็นชุดคอนโทรลที่ไมโครซอฟท์สร้างขึ้นเป็นมาตรฐานบนแพลตฟอร์มต่างๆ (รายการแพลตฟอร์มทั้งหมด) โดยโปรเจค Teams เลือกใช้ Fluent React v9 ซึ่งปรับแต่งประสิทธิภาพการทำงานบนจาวาสคริปต์มาให้เรียบร้อยแล้ว
  • React เหตุผลในการย้ายจาก AngularJS มาเป็น React เป็นเรื่องประสิทธิภาพเป็นหลัก หลังจากเขียนโค้ดส่วนนี้ใหม่ก็ถือโอกาสออกแบบสถาปัตยกรรมโค้ดให้เป็นโมดูลมากขึ้น นำคอมโพเนนต์ไปใช้ซ้ำได้ ตอบสนองเร็วขึ้น
  • Client Data Layer สถาปัตยกรรมเดิมผนวกส่วนจัดการข้อมูลไว้เธร็ดเดียวกับ UI ส่งผลให้ดึงประสิทธิภาพระหว่างกัน สถาปัตยกรรมใหม่จึงแยกส่วนจัดการข้อมูลออกมารันในอีก worker ทำหน้าที่ดึงข้อมูล เก็บข้อมูล แจ้งเตือน และทำงานออฟไลน์ในอีกเธร็ด แล้วให้เธร็ดหลักดึงข้อมูลด้วย GraphQL ช่วยให้การตอบสนองผู้ใช้ดีขึ้น
  • WebView2 การเปลี่ยนจาก Electron เป็น WebView2 ช่วยลดการใช้หน่วยความจำและการเรียกใช้ดิสก์ ผลพลอยได้อีกอย่างคือฟีเจอร์ด้านเนทีฟของวินโดวส์ และการได้ใช้เอนจิน Chromium เวอร์ชันล่าสุด ช่วยเรื่องความปลอดภัยและประสิทธิภาพของตัวเอนจินด้วย

34a20c3462abddedb9f70e9a664f4022.png


นอกจากสถาปัตยกรรมหลักข้างต้นแล้ว ไมโครซอฟท์ยังถือโอกาสปรับปรุง Teams ในด้านอื่นด้วย ดังนี้

  • ปรับสถาปัตยกรรม video rendering pipeline ให้ประมวลผลวิดีโอคอลล์มีประสิทธิภาพมากขึ้น กินไฟน้อยลง 50% และรองรับการแสดงวิดีโอแบบกริดขนาดใหญ่ 7x7 สถาปัตยกรรมนี้ใช้กับทั้งไคลเอนต์ตัวเก่าและใหม่
  • รองรับการประชุมขนาดใหญ่ กรณีที่มีคนเข้าฟังเป็นหลักหลายพันคนพร้อมกัน ต้องสเกลระบบเบื้องหลังให้รองรับโหลดวิดีโอ-แชทจำนวนมาก ต้องปรับแต่งทุกเรื่องตั้งแต่ลดจำนวนการเรียก IPC, ลดจำนวนการเรนเดอร์ UI เป็นต้น
  • Multi-Account / Multi-Tenant ปัญหาเรื่องการจัดการบัญชีของ Teams ที่เรื้อรังมานาน ถือโอกาสเขียนใหม่ในไคลเอนต์ตัวใหม่ ปรับปรุงเรื่องล็อกอิน ซิงก์ข้อมูล ข้อความแจ้งเตือน และจับแยกสตอเรจของบัญชีไม่ให้ยุ่งกัน การสลับบัญชีผู้ใช้งานจึงราบรื่นขึ้น
  • ปรับแพ็กเกจการติดตั้งมาใช้ MSIX ซึ่งเป็นระบบจัดการแพ็กเกจแบบใหม่ของวินโดวส์ การติดตั้งและอัพเดตสะดวกขึ้น ลดการใช้แบนด์วิดท์และเนื้อที่ในดิสก์ลง จัดการผ่าน Microsoft Intune ได้ด้วย
  • ปรับปรุงความปลอดภัย ใช้เทคนิคด้านความปลอดภัยรุ่นใหม่ๆ เช่น Trusted Types, Content Security Policy เพื่อแก้ปัญหา cross-site scripting
  • ดึงข้อมูลเฉพาะบางส่วน (Partial Data) ปรับวิธีการเรียกข้อมูลของ Teams โดยเรียกเฉพาะบางส่วนก่อน (partial data) หากเลื่อนจอค่อยดึงข้อมูลเพิ่ม แทนการดึงข้อมูลทั้งหมดในไคลเอนต์ตัวเดิม ซึ่งเปลืองแรมและดิสก์
  • เปลี่ยนจาก Polling มาเป็น Push Notification ปรับการแจ้งเตือนเหตุการณ์ต่างๆ จากการถามเป็นระยะ (Polling) มาเป็นระบบ push แบบใหม่ที่เป็นมาตรฐานยุคนี้
  • ปรับแต่งการใช้แรม ปรับระบบการแคชข้อมูลแบบต่างๆ ให้ไดนามิกมากขึ้น ปรับเปลี่ยนตามพฤติกรรมของผู้ใช้งาน และเพิ่มการคืนแรมที่ไม่ใช้เป็นระยะๆ โดยอาศัย API ของวินโดวส์และ WebView2
  • พัฒนาเครื่องมือด้านวัดประสิทธิภาพ ระบบเทสต์ต้องรันให้ผ่านประสิทธิภาพที่กำหนด เพิ่มระบบตรวจสอบและแจ้งเตือนหากไคลเอนต์ให่มที่กำลังพัฒนาอยู่มีปัญหาประสิทธิภาพ
  • ใช้ซอฟต์แวร์ที่เป็นโอเพนซอร์ส เข้ามาช่วย ตัวอย่างโครงการของไมโครซอฟท์เอง ได้แก่ lage, Playwright
  • ปรับปรุง Accessibility ช่วยการเข้าถึงของคนพิการ เช่น ระบบสี High Contrast ของ Windows 11, รองรับตัวอ่านหน้าจอให้มีประสิทธิภาพดีขึ้น, ใช้ระบบการแจ้งเตือนเนทีฟของ Windows 11

994c878d30047cf94f015a64db05b226.png


ไมโครซอฟท์เล่าว่าตอนแรกพยายามขยับไปสถาปัตยกรรมใหม่ ด้วยการนำคอมโพเนนต์ที่สร้างด้วย React/Fluent บางส่วนไปใช้กับไคลเอนต์เก่าก่อน แต่ผลที่ได้คือแย่กว่าเดิม เพราะกลายเป็นมีเฟรมเวิร์คสองตัวในไคลเอนต์ตัวเดียว

ทางออกของไมโครซอฟท์จึงหันไปทำไคลเอนต์ Teams สำหรับผู้ใช้ทั่วไป (consumer client ที่ไม่ได้ล็อกอินด้วยบัญชีองค์กร) ที่มีฟีเจอร์น้อยกว่าฝั่งองค์กร (commercial client) ด้วยสถาปัตยกรรมใหม่ทั้งหมดก่อน ช่วยลดความเสี่ยงจากความซับซ้อนลง เมื่อทำไคลเอนต์ consumer ที่มีประสิทธิภาพและเสถียรภาพเป็นที่น่าพอใจแล้ว จึงค่อยๆ นำฟีเจอร์จาก commercial client ตัวเดิมมาใส่ให้ครบ

ตอนนี้ไคลเอนต์ Teams ตัวใหม่ยังรองรับเฉพาะบนวินโดวส์ x86 และ Arm แต่จะขยายไปยังแพลตฟอร์มอื่นๆ ด้วย คือ เว็บ, macOS (Intel/M1/M2) และการรันผ่าน virtual desktop infrastructure (VDI) ในระยะถัดไป ผู้ที่สนใจให้เพิ่มฟีเจอร์ไหนก็สามารถไปร่วมโหวตกันได้

ที่มา - Microsoft Teams Blog

Topics:
Microsoft Teams
React
Development
Microsoft
Web Application
Angular
Electron

อ่านต่อ...
 

ไฟล์แนบ

  • 04b7a49b08c2d29d1eb5f3d54de88ad4.png
    04b7a49b08c2d29d1eb5f3d54de88ad4.png
    15.5 กิโลไบต์ · จำนวนการดู: 28
  • 34a20c3462abddedb9f70e9a664f4022.png
    34a20c3462abddedb9f70e9a664f4022.png
    35.6 กิโลไบต์ · จำนวนการดู: 31
  • 994c878d30047cf94f015a64db05b226.png
    994c878d30047cf94f015a64db05b226.png
    32.4 กิโลไบต์ · จำนวนการดู: 27

กรุณาปิด โปรแกรมบล๊อกโฆษณา เพราะเราอยู่ได้ด้วยโฆษณาที่ท่านเห็น
Please close the adblock program. Because we can live with the ads you see
กลับ
ยอดนิยม ด้านล่าง