Python サーバー プログラミング: Twisted を使用した非同期マルチユーザー チャット ルームの構築
Python サーバー プログラミング: Twisted を使用して非同期マルチユーザー チャット ルームを構築する
現代のコンピューター サイエンスにおいて、ネットワーク アプリケーションはその最も重要な部分の 1 つになっています。サーバー側プログラミングは、これらのネットワーク アプリケーションに不可欠な部分です。 Python は高級プログラミング言語として、非常に強力なサーバー側プログラミング機能を備えています。 Twisted は、Python を使用して効率的なイベント駆動型のネットワーク アプリケーションを作成できる非同期ネットワーク フレームワークです。この記事では、Twisted を使用して非同期マルチユーザー チャット ルームを構築する方法を検討します。
1.ツイストとは何ですか?
Twisted は、イベントベースの Web アプリケーションとクライアントを作成するための Python フレームワークです。これは、Web サーバー、チャット プログラム、メール サーバーなどの大規模で同時実行性の高いネットワーク アプリケーションを作成するのに非常に適した非同期ネットワーク フレームワークです。
2. Twisted チャット ルームのアーキテクチャ
まず、Twisted チャット ルームのアーキテクチャを見てみましょう:
- Twisted サーバーは TCP ポートをリッスンします。そしてクライアントが接続するのを待ちます。
- クライアントが正常に接続すると、サーバーは新しい ChatProtocol インスタンスを作成します。
- 各 ChatProtocol インスタンスはクライアント接続を表し、クライアントのすべての入出力を処理します。
- ChatProtocol インスタンスは新しいメッセージを受信すると、そのメッセージを他のすべてのクライアントに転送します。
3. Twisted チャット ルームの実装
次に、Twisted を使用してチャット ルームを実装してみましょう。まず、Twisted ライブラリをインストールする必要があります:
pip install twisted
次に、すべての接続とメッセージを処理するために ChatProtocol クラスを定義する必要があります:
from twisted.internet.protocol import Protocol class ChatProtocol(Protocol): def __init__(self, factory): self.factory = factory self.name = None def connectionMade(self): self.factory.clients.add(self) self.factory.notifyAllClients("New user connected.") def connectionLost(self, reason): self.factory.clients.remove(self) self.factory.notifyAllClients("User disconnected.") def dataReceived(self, data): message = data.decode().rstrip() if self.name is None: self.name = message self.factory.notifyAllClients("{} joined the room.".format(self.name)) else: self.factory.notifyAllClients("{}: {}".format(self.name, message)) def sendMessage(self, message): self.transport.write(message.encode())
上記のコードでは、ChatProtocol クラスを定義します。 Protocol クラスから継承するこのクラスは、接続とメッセージを処理するためのメソッドを定義します。
__init__
メソッドでは、変数 factory
と name
を初期化します。 factory
はすべてのクライアント接続を管理するために使用されるファクトリ クラスで、name
はクライアントの名前を表します。クライアントが正常に接続すると、name
は になります。なし###。
connectionMade メソッドでは、新しいクライアント接続を追加し、他のすべてのクライアントに通知メッセージを送信します。
connectionLost メソッドでは、切断されたクライアントを削除し、他のすべてのクライアントに通知メッセージを送信します。
dataReceived メソッドでは、受信したメッセージを処理します。クライアントの名前が
None の場合、このメッセージをクライアントの名前に設定し、他のすべてのクライアントに通知メッセージを送信します。それ以外の場合、このメッセージは他のすべてのクライアントに送信されます。
sendMessage メソッドで、メッセージをクライアントに送信します。
from twisted.internet.protocol import Factory class ChatFactory(Factory): def __init__(self): self.clients = set() def buildProtocol(self, addr): return ChatProtocol(self) def notifyAllClients(self, message): for client in self.clients: client.sendMessage(message)
__init__ メソッドでは、すべてのクライアント接続を保存するために使用される変数
clients を初期化します。
buildProtocol メソッドで、新しい ChatProtocol インスタンスを作成し、それに
self を渡します。
notifyAllClients メソッドで、すべてのクライアントにメッセージを送信します。
from twisted.internet import reactor factory = ChatFactory() reactor.listenTCP(1234, factory) reactor.run()
listenTCP メソッドに渡します。このメソッドは、サーバーが TCP ポート 1234 上のすべての接続をリッスンすることを示します。最後に、Twisted サーバーを起動して、接続の待機とメッセージの処理を開始します。
python chat_server.py
import socket sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) sock.connect(("localhost", 1234)) sock.sendall("Alice ".encode()) sock.sendall("Hello! ".encode()) sock.sendall("Bob ".encode()) sock.sendall("Hi there! ".encode()) sock.sendall("Charlie ".encode()) sock.sendall("How are you guys? ".encode())
以上がPython サーバー プログラミング: Twisted を使用した非同期マルチユーザー チャット ルームの構築の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









PHPとPythonには独自の利点と短所があり、選択はプロジェクトのニーズと個人的な好みに依存します。 1.PHPは、大規模なWebアプリケーションの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンスと機械学習の分野を支配しています。

PythonとJavaScriptには、コミュニティ、ライブラリ、リソースの観点から、独自の利点と短所があります。 1)Pythonコミュニティはフレンドリーで初心者に適していますが、フロントエンドの開発リソースはJavaScriptほど豊富ではありません。 2)Pythonはデータサイエンスおよび機械学習ライブラリで強力ですが、JavaScriptはフロントエンド開発ライブラリとフレームワークで優れています。 3)どちらも豊富な学習リソースを持っていますが、Pythonは公式文書から始めるのに適していますが、JavaScriptはMDNWebDocsにより優れています。選択は、プロジェクトのニーズと個人的な関心に基づいている必要があります。

Pytorch GPUアクセラレーションを有効にすることで、CentOSシステムでは、PytorchのCUDA、CUDNN、およびGPUバージョンのインストールが必要です。次の手順では、プロセスをガイドします。CUDAおよびCUDNNのインストールでは、CUDAバージョンの互換性が決定されます。NVIDIA-SMIコマンドを使用して、NVIDIAグラフィックスカードでサポートされているCUDAバージョンを表示します。たとえば、MX450グラフィックカードはCUDA11.1以上をサポートする場合があります。 cudatoolkitのダウンロードとインストール:nvidiacudatoolkitの公式Webサイトにアクセスし、グラフィックカードでサポートされている最高のCUDAバージョンに従って、対応するバージョンをダウンロードしてインストールします。 cudnnライブラリをインストールする:

DockerはLinuxカーネル機能を使用して、効率的で孤立したアプリケーションランニング環境を提供します。その作業原則は次のとおりです。1。ミラーは、アプリケーションを実行するために必要なすべてを含む読み取り専用テンプレートとして使用されます。 2。ユニオンファイルシステム(UnionFS)は、違いを保存するだけで、スペースを節約し、高速化する複数のファイルシステムをスタックします。 3.デーモンはミラーとコンテナを管理し、クライアントはそれらをインタラクションに使用します。 4。名前空間とcgroupsは、コンテナの分離とリソースの制限を実装します。 5.複数のネットワークモードは、コンテナの相互接続をサポートします。これらのコア概念を理解することによってのみ、Dockerをよりよく利用できます。

MINIOオブジェクトストレージ:CENTOSシステムの下での高性能展開Minioは、Amazons3と互換性のあるGO言語に基づいて開発された高性能の分散オブジェクトストレージシステムです。 Java、Python、JavaScript、Goなど、さまざまなクライアント言語をサポートしています。この記事では、CentosシステムへのMinioのインストールと互換性を簡単に紹介します。 Centosバージョンの互換性Minioは、Centos7.9を含むがこれらに限定されない複数のCentosバージョンで検証されています。

Pytorchの分散トレーニングでは、Centosシステムでトレーニングには次の手順が必要です。Pytorchのインストール:PythonとPipがCentosシステムにインストールされていることです。 CUDAバージョンに応じて、Pytorchの公式Webサイトから適切なインストールコマンドを入手してください。 CPUのみのトレーニングには、次のコマンドを使用できます。PipinstalltorchtorchtorchvisionTorchaudioGPUサポートが必要な場合は、CUDAとCUDNNの対応するバージョンがインストールされ、インストールに対応するPytorchバージョンを使用してください。分散環境構成:分散トレーニングには、通常、複数のマシンまたは単一マシンの複数GPUが必要です。場所

PytorchをCentosシステムにインストールする場合、適切なバージョンを慎重に選択し、次の重要な要因を検討する必要があります。1。システム環境互換性:オペレーティングシステム:Centos7以上を使用することをお勧めします。 Cuda and Cudnn:PytorchバージョンとCudaバージョンは密接に関連しています。たとえば、pytorch1.9.0にはcuda11.1が必要ですが、pytorch2.0.1にはcuda11.3が必要です。 CUDNNバージョンは、CUDAバージョンとも一致する必要があります。 Pytorchバージョンを選択する前に、互換性のあるCUDAおよびCUDNNバージョンがインストールされていることを確認してください。 Pythonバージョン:Pytorch公式支店

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