ホームページ バックエンド開発 Python チュートリアル WebRTC Python サーバー: Python アプリの STUN/TURN サーバー

WebRTC Python サーバー: Python アプリの STUN/TURN サーバー

Nov 18, 2024 am 12:09 AM

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 オブジェクトを作成します

サーバーコード例 (ピア接続)

pip install aiortc aiohttp
ログイン後にコピー
ログイン後にコピー

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

  1. TURN サーバーを ICE 構成に組み込む

NAT トラバーサルを処理し、接続を確保するには、TURN サーバーが必要です。

この記事では、従量制の TURN サーバーを使用します。 Metered は TURN サーバーのグローバルプロバイダー

月間 50 GB の TURN サーバー割り当てを提供する従量制 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. Key Streps を示すコード例

ここですべてを統合する方法は次のとおりです

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 Server: 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. グローバル地理位置ターゲティング: トラフィックを最も近いサーバーに自動的に送信し、遅延を最小限に抑え、最高品質のパフォーマンスを実現します。世界中のどこでも遅延が 50 ミリ秒未満

  3. 世界のすべての地域のサーバー: トロント、マイアミ、サンフランシスコ、アムステルダム、ロンドン、フランクフルト、バンガロール、シンガポール、シドニー、ソウル、ダラス、ニューヨーク

  4. 低遅延: 世界中のどこでも遅延が 50 ミリ秒未満です。

  5. 費用対効果の高い: 帯域幅とボリュームの割引が可能な従量課金制の料金設定です。

  6. 簡単な管理: 使用状況ログ、アカウントがしきい値制限に達したときのメール、請求記録、メールと電話のサポートを取得します。

  7. 準拠規格: UDP、TCP、TLS、および DTLS で RFC 5389、5769、5780、5766、6062、6156、5245、5768、6336、6544、5928 に準拠します。

  8. マルチテナンシー: 複数の認証情報を作成し、顧客ごとまたは異なるアプリごとに使用を分離します。使用状況ログ、請求記録、およびしきい値アラートを取得します。

  9. エンタープライズの信頼性: SLA による 99.999% の稼働時間。

  10. エンタープライズ規模: 同時トラフィックまたは合計トラフィックに制限はありません。従量制の TURN サーバーはエンタープライズ スケーラビリティを提供します

  11. 5 GB/月 無料: 無料プランでは毎月 5 GB の TURN サーバーを無料で利用できます

  12. ポート 80 および 443 で実行

  13. ディープ パケット インスペクション ファイアウォールを介した接続を許可する TURNS SSL をサポートします。

  14. TCP と UDP の両方をサポート

  15. 無料無制限スタン

以上がWebRTC Python サーバー: Python アプリの STUN/TURN サーバーの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Python vs. C:曲線と使いやすさの学習 Python vs. C:曲線と使いやすさの学習 Apr 19, 2025 am 12:20 AM

Pythonは学習と使用が簡単ですが、Cはより強力ですが複雑です。 1。Python構文は簡潔で初心者に適しています。動的なタイピングと自動メモリ管理により、使いやすくなりますが、ランタイムエラーを引き起こす可能性があります。 2.Cは、高性能アプリケーションに適した低レベルの制御と高度な機能を提供しますが、学習しきい値が高く、手動メモリとタイプの安全管理が必要です。

Pythonの学習:2時間の毎日の研究で十分ですか? Pythonの学習:2時間の毎日の研究で十分ですか? Apr 18, 2025 am 12:22 AM

Pythonを1日2時間学ぶだけで十分ですか?それはあなたの目標と学習方法に依存します。 1)明確な学習計画を策定し、2)適切な学習リソースと方法を選択します。3)実践的な実践とレビューとレビューと統合を練習および統合し、統合すると、この期間中にPythonの基本的な知識と高度な機能を徐々に習得できます。

Python vs. C:パフォーマンスと効率の探索 Python vs. C:パフォーマンスと効率の探索 Apr 18, 2025 am 12:20 AM

Pythonは開発効率でCよりも優れていますが、Cは実行パフォーマンスが高くなっています。 1。Pythonの簡潔な構文とリッチライブラリは、開発効率を向上させます。 2.Cのコンピレーションタイプの特性とハードウェア制御により、実行パフォーマンスが向上します。選択を行うときは、プロジェクトのニーズに基づいて開発速度と実行効率を比較検討する必要があります。

Python vs. C:重要な違​​いを理解します Python vs. C:重要な違​​いを理解します Apr 21, 2025 am 12:18 AM

PythonとCにはそれぞれ独自の利点があり、選択はプロジェクトの要件に基づいている必要があります。 1)Pythonは、簡潔な構文と動的タイピングのため、迅速な開発とデータ処理に適しています。 2)Cは、静的なタイピングと手動メモリ管理により、高性能およびシステムプログラミングに適しています。

Python Standard Libraryの一部はどれですか:リストまたは配列はどれですか? Python Standard Libraryの一部はどれですか:リストまたは配列はどれですか? Apr 27, 2025 am 12:03 AM

PythonListSarePartOfThestAndardarenot.liestareBuilting-in、versatile、forStoringCollectionsのpythonlistarepart。

Python:自動化、スクリプト、およびタスク管理 Python:自動化、スクリプト、およびタスク管理 Apr 16, 2025 am 12:14 AM

Pythonは、自動化、スクリプト、およびタスク管理に優れています。 1)自動化:OSやShutilなどの標準ライブラリを介してファイルバックアップが実現されます。 2)スクリプトの書き込み:Psutilライブラリを使用してシステムリソースを監視します。 3)タスク管理:スケジュールライブラリを使用してタスクをスケジュールします。 Pythonの使いやすさと豊富なライブラリサポートにより、これらの分野で優先ツールになります。

科学コンピューティングのためのPython:詳細な外観 科学コンピューティングのためのPython:詳細な外観 Apr 19, 2025 am 12:15 AM

科学コンピューティングにおけるPythonのアプリケーションには、データ分析、機械学習、数値シミュレーション、視覚化が含まれます。 1.numpyは、効率的な多次元配列と数学的関数を提供します。 2。ScipyはNumpy機能を拡張し、最適化と線形代数ツールを提供します。 3. Pandasは、データ処理と分析に使用されます。 4.matplotlibは、さまざまなグラフと視覚的な結果を生成するために使用されます。

Web開発用のPython:主要なアプリケーション Web開発用のPython:主要なアプリケーション Apr 18, 2025 am 12:20 AM

Web開発におけるPythonの主要なアプリケーションには、DjangoおよびFlaskフレームワークの使用、API開発、データ分析と視覚化、機械学習とAI、およびパフォーマンスの最適化が含まれます。 1。DjangoandFlask Framework:Djangoは、複雑な用途の迅速な発展に適しており、Flaskは小規模または高度にカスタマイズされたプロジェクトに適しています。 2。API開発:フラスコまたはdjangorestFrameworkを使用して、Restfulapiを構築します。 3。データ分析と視覚化:Pythonを使用してデータを処理し、Webインターフェイスを介して表示します。 4。機械学習とAI:Pythonは、インテリジェントWebアプリケーションを構築するために使用されます。 5。パフォーマンスの最適化:非同期プログラミング、キャッシュ、コードを通じて最適化

See all articles