WebRTC-아키텍처
전반적인 WebRTC 아키텍처는 매우 복잡합니다.
여기에서 세 가지 다른 레이어를 찾을 수 있습니다.
API for web developers −이 계층에는 RTCPeerConnection, RTCDataChannel 및 MediaStrean 개체를 포함하여 웹 개발자가 필요로하는 모든 API가 포함되어 있습니다.
브라우저 제작자를위한 API
브라우저 제작자가 연결할 수있는 재정의 가능한 API.
전송 구성 요소를 사용하면 다양한 유형의 네트워크에서 연결을 설정할 수 있으며 음성 및 비디오 엔진은 사운드 카드 및 카메라에서 네트워크로 오디오 및 비디오 스트림을 전송하는 프레임 워크입니다. 웹 개발자에게 가장 중요한 부분은 WebRTC API입니다.
클라이언트-서버 측에서 WebRTC 아키텍처를 살펴보면 가장 일반적으로 사용되는 모델 중 하나가 SIP (Session Initiation Protocol) Trapezoid에서 영감을받은 것을 알 수 있습니다.
이 모델에서 두 장치는 서로 다른 서버에서 웹 애플리케이션을 실행합니다. RTCPeerConnection 객체는 서로 피어 투 피어로 연결할 수 있도록 스트림을 구성합니다. 이 신호는 HTTP 또는 WebSocket을 통해 수행됩니다.
하지만 가장 일반적으로 사용되는 모델은 Triangle입니다.
이 모델에서는 두 장치 모두 동일한 웹 응용 프로그램을 사용합니다. 웹 개발자는 사용자 연결을 관리 할 때 더 많은 유연성을 제공합니다.
WebRTC API
그것은 몇 가지 주요 자바 스크립트 개체로 구성되어 있습니다-
- RTCPeerConnection
- MediaStream
- RTCDataChannel
RTCPeerConnection 객체
이 개체는 WebRTC API의 기본 진입 점입니다. 피어에 연결하고 연결을 초기화하며 미디어 스트림을 첨부하는 데 도움이됩니다. 또한 다른 사용자와의 UDP 연결도 관리합니다.
RTCPeerConnection 객체의 주요 작업은 피어 연결을 설정하고 만드는 것입니다. 이 객체는 이벤트가 나타날 때 일련의 이벤트를 발생시키기 때문에 연결의 키 포인트를 쉽게 연결할 수 있습니다. 이러한 이벤트를 통해 연결 구성에 액세스 할 수 있습니다.
RTCPeerConnection은 간단한 자바 스크립트 객체로, 간단하게 이렇게 만들 수 있습니다.
[code]
var conn = new RTCPeerConnection(conf);
conn.onaddstream = function(stream) {
// use stream here
};
[/code]
RTCPeerConnection 객체는 이 튜토리얼의 뒷부분에서 다룰 conf 매개 변수를 받습니다 . onaddstream 원격 사용자가 피어 연결로 비디오 또는 오디오 스트림을 추가 할 때 이벤트가 발생합니다.
MediaStream API
최신 브라우저는 개발자에게 MediaStream API 라고도 하는 getUserMedia API에 대한 액세스 권한을 제공합니다 . 기능에는 세 가지 핵심 포인트가 있습니다.
개발자에게 비디오 및 오디오 스트림을 나타내는 스트림 개체에 대한 액세스 권한을 제공합니다.
사용자가 자신의 장치에 여러 대의 카메라 또는 마이크가있는 경우 입력 사용자 장치의 선택을 관리합니다.
사용자가 스트림을 가져오고 자 할 때마다 사용자에게 묻는 보안 수준을 제공합니다.
이 API를 테스트하기 위해 간단한 HTML 페이지를 만들어 보겠습니다. 단일 <video> 요소를 표시하고 사용자에게 카메라 사용 권한을 요청하고 페이지에 카메라의 라이브 스트림을 표시합니다. 생성 된 index.html 파일을 추가합니다 -
[code]
<html>
<head>
<meta charset = "utf-8">
</head>
<body>
<video autoplay></video>
<script src = "client.js"></script>
</body>
</html>
[/code]
그런 다음 client.js 파일을 추가 하십시오-
[code]
//checks if the browser supports WebRTC
function hasUserMedia() {
navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia
|| navigator.mozGetUserMedia || navigator.msGetUserMedia;
return !!navigator.getUserMedia;
}
if (hasUserMedia()) {
navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia
|| navigator.mozGetUserMedia || navigator.msGetUserMedia;
//get both video and audio streams from user's camera
navigator.getUserMedia({ video: true, audio: true }, function (stream) {
var video = document.querySelector('video');
//insert stream into the video tag
video.src = window.URL.createObjectURL(stream);
}, function (err) {});
}else {
alert("Error. WebRTC is not supported!");
}
[/code]
이제 index.html을 열면 얼굴을 표시하는 비디오 스트림이 표시됩니다.
그러나 WebRTC는 서버 측에서만 작동하므로주의하십시오. 단순히 브라우저로이 페이지를 열면 작동하지 않습니다. 이러한 파일은 Apache 또는 Node 서버 또는 선호하는 서버에서 호스팅해야합니다.
RTCDataChannel 객체
피어간에 미디어 스트림을 보낼뿐만 아니라 DataChannel API를 사용하여 추가 데이터를 보낼 수도 있습니다 . 이 API는 MediaStream API만큼 간단합니다. 주요 작업은 기존 RTCPeerConnection 객체에서 오는 채널을 만드는 것입니다.
[code]
var peerConn = new RTCPeerConnection();
//establishing peer connection
//...
//end of establishing peer connection
var dataChannel = peerConnection.createDataChannel("myChannel", dataChannelOptions);
// here we can start sending direct messages to another peer
[/code]
두 줄의 코드 만 있으면됩니다. 다른 모든 작업은 브라우저의 내부 레이어에서 수행됩니다. RTCPeerConnection 개체 가 닫힐 때까지 모든 피어 연결에서 채널을 만들 수 있습니다 .
요약
이제 WebRTC 아키텍처를 확실히 이해해야합니다. MediaStream, RTCPeerConnection 및 RTCDataChannel API도 다루었습니다. WebRTC API는 움직이는 대상이므로 항상 최신 사양을 유지하십시오.