> 백엔드 개발 > 파이썬 튜토리얼 > WebRTC Python 서버: Python 앱을 위한 STUN/TURN 서버

WebRTC Python 서버: Python 앱을 위한 STUN/TURN 서버

Linda Hamilton
풀어 주다: 2024-11-18 00:09:02
원래의
1012명이 탐색했습니다.

Python은 명확한 구문과 가독성으로 잘 알려진 다재다능하고 접근하기 쉬운 프로그래밍 언어입니다

이는 webrtc 애플리케이션 구축에 좋은 선택입니다.

aiortc와 같은 라이브러리를 사용하여 Python으로 WebRTC 서버를 구축할 수 있습니다

대동맥 도서관

  • 순수 Python 구현: 

    • aiortc 라이브러리는 WebRTC 및 ORTC의 순수 Python 구현입니다.
    • 즉, 타사 라이브러리나 기타 종속성에 의존할 필요가 없습니다.
  • 기본 asyncio : 

    • aiortc는 비동기 연결을 위한 Python 자체 비동기 라이브러리를 기반으로 구축되었습니다. 
    • 따라서 여러 동시 연결을 쉽게 처리할 수 있습니다
  • 미디어 및 데이터 채널:

    • 라이브러리는 비디오, 오디오 및 데이터 채널을 지원하여 다양한 실시간 통신 기능을 제공합니다.
  • 통합 용이성:

    • aiortc는 웹 서버용 aiohttp와 같은 다른 Python 라이브러리는 물론 실시간 이벤트 처리를 위한 Socket.io와 같은 기타 타사 라이브러리와 쉽게 통합될 수 있습니다
  • 광범위한 문서 및 예시:

    • aiortc 라이브러리에는 빠르게 시작하는 데 도움이 되는 광범위한 문서와 다양한 예제가 제공됩니다.

Python에서 WebRTC 서버 설정

전제조건

  1. Python 3.x 설치:

    1. 컴퓨터나 서버에 Python 3.x가 설치되어 있는지 확인하세요. 다음과 같이 Python 버전을 확인할 수 있습니다.  
python3 --version
로그인 후 복사
로그인 후 복사
  1. 비동기 프로그래밍 기본 지식:

    1. 비동기 프로그래밍의 작동 방식에 대한 기본 지식이 필요합니다. 
    2. 이 글에서는 동시 연결 및 데이터 스트림에 중요한 비동기 라이브러리를 사용할 예정입니다

필요한 라이브러리 설치 

pip를 사용하여 aiortc 및 기타 종속 항목 설치

aiortc는 webrtcand ORTC의 순수 Python 구현입니다. 실시간 통신을 처리하기 위해 Python 언어 비동기 기능을 사용합니다

다음과 같이 pip를 사용하여 라이브러리를 설치하세요

pip install aiortc aiohttp
로그인 후 복사
로그인 후 복사
  • aiorrtc는 핵심 WebRTC 기능을 제공합니다

  • aiohttp는 비동기식 HTTP 클라이언트/서버 프레임워크이므로 신호 전달에 이 프레임워크를 사용할 예정입니다

서버 개발

WebRTC python server: STUN/TURN servers for your python app

WebSocket으로 신호 설정

  1. WebSocket으로 신호 설정

WebRTC는 연결을 설정하기 위해 신호 메커니즘이 필요합니다. 

WebRTC는 피어 간에 SDP 또는 세션 설명과 ICE 후보를 교환하여 이를 수행합니다

이를 위해 무엇이든 사용할 수 있습니다. 이 기사에서는 클라이언트와 서버 간의 실시간 양방향 통신을 위해 WebSocket을 사용할 것입니다

시그널링 설정(서버 코드)

python3 --version
로그인 후 복사
로그인 후 복사
  1. 피어 연결 및 미디어 스트림 처리

여기에서는 연결 및 미디어 스트림을 관리하기 위해 RTCPeerConnection 개체를 생성하겠습니다

서버 코드 예시(Peer 연결)

pip install aiortc aiohttp
로그인 후 복사
로그인 후 복사

WebRTC python server: STUN/TURN servers for your python app

  1. TURN 서버를 ICE 구성에 통합 

NAT 통과를 처리하고 연결을 보장하려면 TURN 서버가 필요합니다.

이 기사에서는 Metered TURN 서버를 사용합니다. Metered는 TURN 서버의 글로벌 제공업체입니다.

월간 50GB의 TURN 서버 할당량을 제공하는 Metered TURN 서버의 무료 요금제에 가입할 수 있으며 유료 요금제도 사용할 수 있습니다.

단계:

  • 자격증 취득

Metered.ca/stun-turn에 가입하고 TURN 자격 증명을 받으세요

대시보드에서 첫 번째 자격 증명을 생성하려면 여기를 클릭하세요 버튼을 클릭하여 새 TURN 서버 자격 증명을 생성하세요

WebRTC python server: STUN/TURN servers for your python app

그런 다음 지침 버튼을 클릭하여 ICE 서버 어레이를 가져옵니다.

WebRTC python server: STUN/TURN servers for your python app

API 키를 사용하여 TURN 서버를 활성화할 수도 있습니다

  • ICE 서버 구성
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)
로그인 후 복사
  1. 키 문자열을 보여주는 코드 예

여기서 모든 것을 통합할 수 있는 방법은 다음과 같습니다

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
로그인 후 복사

실전적인 구현 팁

네트워크 고려사항

  1. Metered.ca STUN/TURN 서버로 NAT 통과 관리
  • STUN 서버: 이는 NAT 뒤에 있는 클라이언트 장치가 자신의 IP 주소와 포트 번호를 아는 데 도움이 됩니다. STUN 서버에 대해 자세히 알아보려면 Stun 서버: NAT용 세션 탐색 유틸리티란 무엇인가요?

    를 참조하세요.
  • TURN 서버: TURN 서버는 NAT 또는 방화벽 규칙으로 인해 직접 통신이 불가능한 경우 피어에서 퍼로 트래픽을 릴레이합니다. TURN 서버에 대해 자세히 알아보려면 다음 페이지로 이동하세요. TURN 서버란 무엇인가요?

  1. 신뢰할 수 있고 대기 시간이 짧은 연결 보장
  • 자동 지리적 라우팅: Metered.ca에는 자동 지리적 라우팅이 있습니다.

성능 최적화 

  1. 동시성 관리를 위해 asyncio 사용

  2. 미디어 스트림 관리 모범 사례

WebRTC python server: STUN/TURN servers for your python app

  1. API: 강력한 API로 서버 관리를 시작하세요. API를 통해 자격 증명 추가/제거, API를 통해 사용자별/자격 증명 및 사용자 지표 검색, API를 통해 자격 증명 활성화/비활성화, API를 통해 날짜별 사용량 데이터 검색 등의 작업을 수행할 수 있습니다.

  2. 글로벌 지리적 위치 타겟팅: 자동으로 트래픽을 가장 가까운 서버로 전달하여 지연 시간을 최소화하고 성능을 최고화합니다. 전 세계 어디에서나 50ms 미만의 지연 시간

  3. 전 세계 모든 지역의 서버: 토론토, 마이애미, 샌프란시스코, 암스테르담, 런던, 프랑크푸르트, 방갈로르, 싱가포르, 시드니, 서울, 달라스, 뉴욕

  4. 낮은 지연 시간: 전 세계 어디에서나 50ms 미만의 지연 시간.

  5. 비용 효율적: 대역폭 및 볼륨 할인이 가능한 종량제 가격.

  6. 손쉬운 관리: 사용 로그, 계정이 임계값 한도에 도달할 때 이메일, 청구 기록, 이메일 및 전화 지원을 받으세요.

  7. 표준 준수: UDP, TCP, TLS 및 DTLS.

  8. 다중 테넌시: 여러 개의 자격 증명을 생성하고 고객 또는 다른 앱별로 사용량을 구분합니다. 사용 로그, 청구 기록 및 임계값 알림을 받으세요.

  9. 엔터프라이즈 신뢰성: SLA를 통한 99.999% 가동 시간.

  10. 엔터프라이즈 규모: 동시 트래픽 또는 총 트래픽에 제한이 없습니다. 계량형 TURN 서버는 엔터프라이즈 확장성을 제공합니다

  11. 5GB/월 무료: 무료 플랜으로 매월 5GB 무료 TURN 서버 사용량을 받으세요

  12. 포트 80 및 443에서 실행

  13. TURNS SSL을 지원하여 심층 패킷 검사 방화벽을 통한 연결을 허용합니다.

  14. TCP와 UDP 모두 지원

  15. 무료 무제한 STUN

위 내용은 WebRTC Python 서버: Python 앱을 위한 STUN/TURN 서버의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿