Rust VoIP - Janus Media Server #26: App To Sip: Talking State & End State
Bài 2624:51

Rust VoIP - Janus Media Server #26: App To Sip: Talking State & End State

Trong bài học này, chúng ta sẽ hoàn thiện những bước cuối cùng của luồng gọi App-to-SIP với Rust và Janus Media Server. Sau khi đã kết nối thành công từ WebRTC Browser đến SIP Phone ở bài trước, video hôm nay sẽ tập trung vào việc triển khai Talking State và End State để quản lý toàn bộ vòng đời cuộc gọi VoIP từ khi bắt đầu đàm thoại đến lúc giải phóng tài nguyên hoàn toàn. Bạn sẽ học cách xử lý SIP 200 OK, quản lý SIP Dialog, xử lý sự kiện kết thúc cuộc gọi từ nhiều nguồn khác nhau và cleanup tài nguyên trên Janus Media Server một cách chính xác trong hệ thống SIP ↔ WebRTC production.

1. Xử lý SIP Response & Transition sang TalkingState

→ Parse và xử lý:

• SIP 200 OK

từ SIP Phone để xác nhận cuộc gọi đã được answer.

📌 State transition:

• ConnectToSipState
→ TalkingState

→ Hoàn tất SIP signaling flow cho outbound App-to-SIP call.

2. Hiện thực hóa TalkingState trong Rust

📌 on_enter():

→ Gửi notification answer cho:

• WebRTC Browser Client

→ Đồng bộ trạng thái UI khi cuộc gọi được kết nối thành công.

📌 Quản lý đa nguồn sự kiện trong on_event():

• WebSocket Event
→ Browser hangup

• Janus Event
→ Room destroyed
→ Participant left

• SIP Event
→ SIP BYE từ Phone

→ Điều phối signaling và lifecycle trong suốt thời gian đàm thoại.

3. EndState & Cleanup Resource

📌 Notify & Stop Timer:

→ Gửi:

• call_end

cho WebRTC Client.

→ Stop toàn bộ timer liên quan đến cuộc gọi.

📌 Cleanup Janus Resource:

→ Delete Room
→ Detach Handle
→ Destroy Session

→ Giải phóng tài nguyên trên Janus Media Server theo đúng quy trình.

📌 SIP Dialog Termination:

→ Gửi:

• SIP BYE
hoặc
• SIP CANCEL

tùy theo trạng thái hiện tại của cuộc gọi.

→ Đảm bảo SIP Dialog được đóng hoàn toàn từ phía SIP Server/Phone.

4. Demo thực tế & Test Audio hai chiều

📞 Demo flow hoàn chỉnh:

WebRTC Browser
↔ Rust Server
↔ Janus Media Server
↔ Kamailio
↔ SIP Phone (Zoiper)

📌 Kiểm tra:

• Two-way audio
• SIP signaling
• Hangup từ Browser
• Hangup từ SIP Phone
• Resource cleanup

→ Xác nhận media flow và signaling hoạt động ổn định.

5. 🚀 Kết quả đạt được:

→ Hoàn thiện TalkingState cho App-to-SIP
→ Xử lý SIP 200 OK & SIP BYE
→ Quản lý lifecycle cuộc gọi VoIP
→ Cleanup tài nguyên Janus đúng cách
→ Điều phối signaling SIP ↔ WebRTC
→ Hoàn thiện outbound calling flow bằng Rust

Đây là nền tảng quan trọng trước khi triển khai các tính năng nâng cao như:

• Call Recording
• Audio Injection
• Voice Bot
• SIP Automation
• Production VoIP Platform

Nâng tầm ứng dụng WebRTC của bạn lên quy mô Production Nếu bạn đã hiểu cách các trình duyệt kết nối trực tiếp qua WebRTC P2P, thì đây chính là bước đi tiếp theo để đưa ứng dụng của bạn vào thực tế Mô hình P2P rất tuyệt vời cho các kết nối đơn giản, nhưng khi đối mặt với các bài toán lớn hơn, nó bộc lộ 4 hạn chế nghiêm trọng: 1. Khả năng mở rộng: Với 10 người dùng, hệ thống P2P cần tới 90 kết nối trực tiếp, khiến việc mở rộng là gần như không thể 2. Tốn tài nguyên: Client phải upload đồng thời nhiều luồng media, gây ngốn CPU và nhanh hết pin, đặc biệt là trên thiết bị di động 3. Không thể ghi âm tập trung: Media truyền trực tiếp giữa các peer nên không có cách nào ghi lại cuộc gọi một cách tập trung tại server 4. Vấn đề NAT: Khoảng 15% người dùng gặp lỗi kết nối do NAT nghiêm ngặt Giải pháp đột phá với Janus Media Server Khóa học này sẽ hướng dẫn bạn sử dụng Janus Media Server – một thành phần trung gian mạnh mẽ để thay thế mô hình kết nối trực tiếp . Thay vì gửi dữ liệu cho nhau, tất cả client sẽ gửi media lên server để server xử lý và phân phối lại Chúng ta sẽ tập trung sâu vào kiến trúc Modular của Janus, đặc biệt là Audiobridge plugin Cơ chế Mixing: Server sẽ trộn (mix) các luồng audio lại thành một luồng duy nhất, giúp giảm đáng kể băng thông và tải cho phía người dùng Khả năng Scale: Hệ thống có thể đáp ứng hàng trăm, thậm chí hàng nghìn người dùng cùng lúc Bạn sẽ học được gì? Xuyên suốt khóa học, chúng ta sẽ cùng nhau lập trình bằng ngôn ngữ Rust để xây dựng một hệ thống hoàn chỉnh với các tính năng thực tế nhất: Call App to App: Kết nối giọng nói giữa hai ứng dụng WebRTC. Call App to SIP: Tích hợp gọi từ Web/App sang hệ thống tổng đài SIP truyền thống. Call SIP to App: Nhận cuộc gọi ngược lại từ hệ thống SIP về Web/App. Auto Callout: Phát triển hệ thống tự động gọi ra chuyên nghiệp. Mục tiêu khóa học Toàn bộ nội dung được thiết kế theo lộ trình từ cơ bản đến nâng cao, giúp bạn không chỉ hiểu về mặt lý thuyết mà còn có đủ kỹ năng để tự tay xây dựng một hệ thống Voice IP thực tế.

Công nghệ sử dụng

januskamailiortpengineb2buarustbytebuffer

Tác giả

ByteBuffer

ByteBuffer

Coder cỏ tại DTS Group và IPAS

Chuyên gia về Rust và hệ thống VoIP/WebRTC. Nhiều năm kinh nghiệm xây dựng các hệ thống real-time communication với hiệu năng cao và độ trễ thấp.

Bài học liên quan

Xem khóa học
Rust VoIP - Janus Media Server #25: App To Sip: Connect To SIP State
1:09:22

Rust VoIP - Janus Media Server #25: App To Sip: Connect To SIP State

Trong bài học này, chúng ta sẽ thực hiện một trong những bước quan trọng nhất của luồng App-to-SIP: Trạng thái Connect to SIP. Đây là giai đoạn hệ thống Rust Server của chúng ta đóng vai trò là một SIP Client (UAC) để khởi tạo cuộc gọi đến SIP Server (Kamailio) và chuyển tiếp yêu cầu từ người dùng WebRTC ra thế giới điện thoại. Bạn sẽ học cách build một bản tin SIP INVITE hoàn chỉnh, cách khai thác Janus Admin API để lấy thông tin media và cách cấu hình Kamailio để điều phối cuộc gọi đi (Outbound Call).

Bài 25
Rust VoIP - Janus Media Server #24: App To Sip: Build + Deploy + Debug App to SIP.
16:01

Rust VoIP - Janus Media Server #24: App To Sip: Build + Deploy + Debug App to SIP.

Trong bài học này, chúng ta sẽ tiếp tục hoàn thiện luồng App-to-SIP. Sau khi đã xử lý xong trạng thái chờ SDP từ người gọi, video hôm nay sẽ tập trung vào việc Build, Deploy và Debug thực tế để chuyển dịch sang trạng thái tiếp theo: Connect to SIP State. Bạn sẽ học cách định nghĩa cấu trúc trạng thái mới, xử lý các sự kiện bất đồng bộ từ WebSocket và Janus để đảm bảo điều kiện "webrtcup" được thỏa mãn trước khi thực hiện kết nối ra phía nhà mạng.

Bài 24
Rust VoIP - Janus Media Server #23: App To Sip: Waiting Caller SDP State
30:51

Rust VoIP - Janus Media Server #23: App To Sip: Waiting Caller SDP State

Sau khi đã xây dựng xong bộ khung cho luồng:📞 App-to-SIP, ở bài trước, hôm nay chúng ta sẽ bắt đầu hiện thực hóa state đầu tiên của outbound calling flow: → Waiting Caller SDP State. Đây là giai đoạn quan trọng để thiết lập media path từ WebRTC Browser trước khi hệ thống thực hiện cuộc gọi ra phía SIP/Telco.

Bài 23
Rust VoIP - Janus Media Server #22: App To Sip: Setup Call
24:42

Rust VoIP - Janus Media Server #22: App To Sip: Setup Call

Sau khi đã triển khai thành công các luồng gọi: App-to-App, SIP-to-App, trong bài học này, chúng ta sẽ bắt đầu xây dựng luồng ngược lại: 📞 App-to-SIP. Đây là tính năng cho phép WebRTC Browser thực hiện cuộc gọi trực tiếp tới số điện thoại SIP thông qua hệ thống Telco Simulator.

Bài 22
Rust VoIP - Janus Media Server #21: Sip To App - Debug RTP Media
13:39

Rust VoIP - Janus Media Server #21: Sip To App - Debug RTP Media

Chào mừng bạn đến với Bài 21 của khóa học: "Lập trình VoIP với Rust: Janus Media Server".

Bài 21
Rust VoIP - Janus Media Server #20: Sip To App - Talking State
19:07

Rust VoIP - Janus Media Server #20: Sip To App - Talking State

Chào mừng bạn đến với Bài 20 của khóa học: "Lập trình VoIP với Rust: Janus Media Server". Sau khi đã xử lý xong các trạng thái chờ và các tình huống ngoại lệ (Edge Cases) ở bài trước, hôm nay chúng ta sẽ đi vào giai đoạn cuối cùng của luồng gọi SIP-to-App: → Talking State Đây là trạng thái đàm thoại chính thức, nơi các bản tin signaling cuối cùng được trao đổi để thiết lập luồng media hoàn chỉnh giữa: 📞 SIP Phone ↔ RTP ↔ Janus Media Server ↔ WebRTC Browser Trong video này, bạn sẽ học cách định nghĩa Talking State, build SIP 200 OK chuẩn RFC và quản lý toàn bộ signaling trong suốt thời gian cuộc gọi diễn ra.

Bài 20
Rust VoIP - Janus Media Server #19: Sip To App - End state and EDGE case
27:42

Rust VoIP - Janus Media Server #19: Sip To App - End state and EDGE case

Trong bài học này, chúng ta sẽ chưa đi ngay vào trạng thái Talking mà tập trung xử lý một phần cực kỳ quan trọng trong hệ thống VoIP Production: → End State → SIP Edge Cases → Resource Cleanup → SIP Dialog Management Video sẽ hướng dẫn cách xử lý các SIP message như: • CANCEL • BYE • ACK • PRACK đồng thời đảm bảo mọi tài nguyên trên Janus Media Server được giải phóng chính xác khi cuộc gọi kết thúc. Đây là bước cực kỳ quan trọng để tránh: • Memory leak • SIP retransmission loop • Zombie session • Treo signaling • Room/Handle không được cleanup

Bài 19
Rust VoIP - Janus Media Server #18: Sip To App - Connect to Agent
24:49

Rust VoIP - Janus Media Server #18: Sip To App - Connect to Agent

Sau khi đã hoàn thành việc đưa SIP Member vào phòng họp ở bài trước, hôm nay chúng ta sẽ thực hiện bước tiếp theo trong luồng SIP-to-App: → Kết nối với WebRTC Client (Agent) Mặc dù logic này có nhiều điểm tương đồng với cuộc gọi App-to-App, nhưng việc tích hợp vào luồng SIP đòi hỏi sự quản lý chặt chẽ hơn về: • WebSocket Events • Janus Events • State Machine • SDP Signaling Video này sẽ hướng dẫn cách gửi thông báo cuộc gọi, xử lý phản hồi từ trình duyệt và hoàn tất quá trình bắt tay WebRTC để chuẩn bị bước sang Talking State.

Bài 18
Rust VoIP - Janus Media Server #17: Sip To App - Join SIP Member State: Finish
30:37

Rust VoIP - Janus Media Server #17: Sip To App - Join SIP Member State: Finish

Trong bài học này, chúng ta sẽ đi đến những bước cuối cùng để hoàn thiện trạng thái: → Join SIP Member To Room Đây là giai đoạn cực kỳ quan trọng, nơi chúng ta thực hiện việc "đấu nối" thực tế luồng Media giữa: 📞 SIP Phone ↔ RTPEngine ↔ Janus Media Server Video tập trung vào cách sử dụng Janus Admin API để lấy RTP information thực tế, xây dựng SDP Answer chuẩn SIP và thiết lập Early Media trước khi kết nối tới WebRTC Client.

Bài 17

Hiển thị 9 / 25 bài học