Python은 명확한 구문과 가독성으로 잘 알려진 다재다능하고 접근하기 쉬운 프로그래밍 언어입니다
이는 webrtc 애플리케이션 구축에 좋은 선택입니다.
aiortc와 같은 라이브러리를 사용하여 Python으로 WebRTC 서버를 구축할 수 있습니다
순수 Python 구현:
기본 asyncio :
미디어 및 데이터 채널:
통합 용이성:
광범위한 문서 및 예시:
Python 3.x 설치:
python3 --version
비동기 프로그래밍 기본 지식:
pip를 사용하여 aiortc 및 기타 종속 항목 설치
aiortc는 webrtcand ORTC의 순수 Python 구현입니다. 실시간 통신을 처리하기 위해 Python 언어 비동기 기능을 사용합니다
다음과 같이 pip를 사용하여 라이브러리를 설치하세요
pip install aiortc aiohttp
aiorrtc는 핵심 WebRTC 기능을 제공합니다
aiohttp는 비동기식 HTTP 클라이언트/서버 프레임워크이므로 신호 전달에 이 프레임워크를 사용할 예정입니다
WebSocket으로 신호 설정
WebRTC는 연결을 설정하기 위해 신호 메커니즘이 필요합니다.
WebRTC는 피어 간에 SDP 또는 세션 설명과 ICE 후보를 교환하여 이를 수행합니다
이를 위해 무엇이든 사용할 수 있습니다. 이 기사에서는 클라이언트와 서버 간의 실시간 양방향 통신을 위해 WebSocket을 사용할 것입니다
시그널링 설정(서버 코드)
python3 --version
여기에서는 연결 및 미디어 스트림을 관리하기 위해 RTCPeerConnection 개체를 생성하겠습니다
서버 코드 예시(Peer 연결)
pip install aiortc aiohttp
NAT 통과를 처리하고 연결을 보장하려면 TURN 서버가 필요합니다.
이 기사에서는 Metered TURN 서버를 사용합니다. Metered는 TURN 서버의 글로벌 제공업체입니다.
월간 50GB의 TURN 서버 할당량을 제공하는 Metered TURN 서버의 무료 요금제에 가입할 수 있으며 유료 요금제도 사용할 수 있습니다.
단계:
Metered.ca/stun-turn에 가입하고 TURN 자격 증명을 받으세요
대시보드에서 첫 번째 자격 증명을 생성하려면 여기를 클릭하세요 버튼을 클릭하여 새 TURN 서버 자격 증명을 생성하세요
그런 다음 지침 버튼을 클릭하여 ICE 서버 어레이를 가져옵니다.
API 키를 사용하여 TURN 서버를 활성화할 수도 있습니다
import asyncio from aiohttp import web import json async def index(request): with open('index.html', 'r') as f: content = f.read() return web.Response(text=content, content_type='text/html') async def websocket_handler(request): ws = web.WebSocketResponse() await ws.prepare(request) # Handle incoming WebSocket messages here return ws app = web.Application() app.router.add_get('/', index) app.router.add_get('/ws', websocket_handler) web.run_app(app)
여기서 모든 것을 통합할 수 있는 방법은 다음과 같습니다
from aiortc import RTCPeerConnection, RTCSessionDescription pcs = set() # Keep track of peer connections async def websocket_handler(request): ws = web.WebSocketResponse() await ws.prepare(request) pc = RTCPeerConnection() pcs.add(pc) @pc.on("datachannel") def on_datachannel(channel): @channel.on("message") async def on_message(message): # Handle incoming messages pass async for msg in ws: if msg.type == web.WSMsgType.TEXT: data = json.loads(msg.data) if data["type"] == "offer": await pc.setRemoteDescription(RTCSessionDescription( sdp=data["sdp"], type=data["type"])) answer = await pc.createAnswer() await pc.setLocalDescription(answer) await ws.send_json({ "type": pc.localDescription.type, "sdp": pc.localDescription.sdp }) elif data["type"] == "candidate": candidate = data["candidate"] await pc.addIceCandidate(candidate) elif msg.type == web.WSMsgType.ERROR: print(f'WebSocket connection closed with exception {ws.exception()}') pcs.discard(pc) return ws
STUN 서버: 이는 NAT 뒤에 있는 클라이언트 장치가 자신의 IP 주소와 포트 번호를 아는 데 도움이 됩니다. STUN 서버에 대해 자세히 알아보려면 Stun 서버: NAT용 세션 탐색 유틸리티란 무엇인가요?
를 참조하세요.TURN 서버: TURN 서버는 NAT 또는 방화벽 규칙으로 인해 직접 통신이 불가능한 경우 피어에서 퍼로 트래픽을 릴레이합니다. TURN 서버에 대해 자세히 알아보려면 다음 페이지로 이동하세요. TURN 서버란 무엇인가요?
동시성 관리를 위해 asyncio 사용
미디어 스트림 관리 모범 사례
API: 강력한 API로 서버 관리를 시작하세요. API를 통해 자격 증명 추가/제거, API를 통해 사용자별/자격 증명 및 사용자 지표 검색, API를 통해 자격 증명 활성화/비활성화, API를 통해 날짜별 사용량 데이터 검색 등의 작업을 수행할 수 있습니다.
글로벌 지리적 위치 타겟팅: 자동으로 트래픽을 가장 가까운 서버로 전달하여 지연 시간을 최소화하고 성능을 최고화합니다. 전 세계 어디에서나 50ms 미만의 지연 시간
전 세계 모든 지역의 서버: 토론토, 마이애미, 샌프란시스코, 암스테르담, 런던, 프랑크푸르트, 방갈로르, 싱가포르, 시드니, 서울, 달라스, 뉴욕
낮은 지연 시간: 전 세계 어디에서나 50ms 미만의 지연 시간.
비용 효율적: 대역폭 및 볼륨 할인이 가능한 종량제 가격.
손쉬운 관리: 사용 로그, 계정이 임계값 한도에 도달할 때 이메일, 청구 기록, 이메일 및 전화 지원을 받으세요.
표준 준수: UDP, TCP, TLS 및 DTLS.
다중 테넌시: 여러 개의 자격 증명을 생성하고 고객 또는 다른 앱별로 사용량을 구분합니다. 사용 로그, 청구 기록 및 임계값 알림을 받으세요.
엔터프라이즈 신뢰성: SLA를 통한 99.999% 가동 시간.
엔터프라이즈 규모: 동시 트래픽 또는 총 트래픽에 제한이 없습니다. 계량형 TURN 서버는 엔터프라이즈 확장성을 제공합니다
5GB/월 무료: 무료 플랜으로 매월 5GB 무료 TURN 서버 사용량을 받으세요
포트 80 및 443에서 실행
TURNS SSL을 지원하여 심층 패킷 검사 방화벽을 통한 연결을 허용합니다.
TCP와 UDP 모두 지원
무료 무제한 STUN
위 내용은 WebRTC Python 서버: Python 앱을 위한 STUN/TURN 서버의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!