>PHP 프레임워크 >Workerman >Workerman의 실제 적용: 고성능 온라인 채팅방 만들기

Workerman의 실제 적용: 고성능 온라인 채팅방 만들기

WBOY
WBOY원래의
2023-08-06 12:29:061523검색

Workerman 실습: 고성능 온라인 채팅방 만들기

소개:
오늘날의 인터넷 시대에 실시간 온라인 채팅은 사람들의 삶에 없어서는 안 될 부분이 되었습니다. 고성능 실시간 상호 작용에 대한 사용자 요구를 충족하려면 적절한 통신 프레임워크를 선택하는 것이 중요합니다. 고성능 PHP 비동기 네트워크 통신 프레임워크인 Workerman은 이러한 요구를 충족할 수 있습니다. 이번 글에서는 Workerman을 사용하여 고성능 온라인 채팅방을 구축하는 방법을 소개하고 코드 예제를 제공하겠습니다.

1. 환경 준비
시작하기 전에 환경이 다음 조건을 충족하는지 확인하세요.

  1. PHP 버전이 5.3 이상이어야 하며 pcntl 및 posix 확장이 설치되어 있어야 합니다.
  2. Workerman 및 해당 종속 라이브러리 파일을 설치하는 데 사용되는 Install Composer.

2. 채팅방 서버 만들기
먼저 채팅방 서버를 만들어야 합니다. "chat_server.php"라는 파일을 생성하고 다음 코드를 추가합니다:

<?php
require_once __DIR__ . '/vendor/autoload.php';

use WorkermanWorker;

$ws_worker = new Worker("websocket://0.0.0.0:8000");

$ws_worker->count = 4; // 设置启动4个进程

$ws_worker->onConnect = function ($connection) {
    echo "有新用户连接
";
};

$ws_worker->onMessage = function ($connection, $data) use ($ws_worker) {
    foreach ($ws_worker->connections as $clientConnection) {
        $clientConnection->send($data); // 将收到的消息发送给所有连接的客户端
    }
};

$ws_worker->onClose = function ($connection) {
    echo "有用户断开连接
";
};

Worker::runAll();

위 코드를 사용하여 WebSocket 서버를 생성하고 포트 8000을 수신했습니다. 새로운 사용자가 연결되면 "New user connects"가 백그라운드로 출력됩니다. 사용자가 연결을 끊으면 "A user connects"가 백그라운드로 출력됩니다. onMessage 콜백 함수에서는 수신된 메시지를 연결된 모든 클라이언트에게 보냅니다.

3. 채팅방 클라이언트 만들기
다음으로 간단한 채팅방 클라이언트를 만들어야 합니다. "chat_client.html"이라는 파일을 만들고 다음 코드를 추가합니다.

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>在线聊天室</title>
    <style>
        #message {
            height: 500px;
            border: 1px solid #ccc;
            padding: 10px;
            overflow-y: scroll;
        }

        #message p {
            margin: 5px 0;
        }

        #input {
            margin-top: 10px;
        }
    </style>
</head>
<body>
<div id="message"></div>
<input type="text" id="input" placeholder="请输入消息">
<button onclick="send()">发送</button>

<script>
    var ws = new WebSocket("ws://localhost:8000");

    ws.onopen = function () {
        console.log("连接成功");
    };

    ws.onmessage = function (evt) {
        var message = document.getElementById("message");
        message.innerHTML += "<p>" + evt.data + "</p>";
        message.scrollTop = message.scrollHeight; // 滚动到底部
    };

    ws.onclose = function () {
        console.log("连接关闭");
    };

    function send() {
        var input = document.getElementById("input");
        var message = input.value;
        ws.send(message);
        input.value = "";
    }
</script>
</body>
</html>

위 코드를 사용하여 간단한 채팅방 클라이언트 인터페이스를 만들었습니다. 사용자가 메시지를 입력하고 보내기 버튼을 클릭하면 메시지가 서버로 전송됩니다. 서버가 메시지를 받으면 onmessage 콜백 함수의 메시지 영역에 메시지가 표시되고 자동으로 하단으로 스크롤됩니다.

4. 채팅방 테스트
명령줄에서 다음 명령을 실행하여 서버를 시작하세요.

php chat_server.php start

그런 다음 두 개 이상의 브라우저 창을 열고 각각 "chat_client.html" 파일에 액세스하세요. 다양한 브라우저 창의 입력란에 메시지를 입력하고 보내기 버튼을 클릭하면 모든 창에서 동일한 메시지가 표시됩니다. 이런 식으로 우리는 고성능 온라인 채팅방을 성공적으로 만들었습니다.

요약:
이 글에서는 Workerman을 사용하여 고성능 온라인 채팅방을 구축하는 방법을 소개하고 해당 코드 예제를 제공합니다. Workerman을 사용하면 동시성이 높고 지연 시간이 짧은 실시간 채팅 기능을 쉽게 구현할 수 있습니다. 이 글이 워커맨의 실제 적용에 도움이 되기를 바랍니다.

위 내용은 Workerman의 실제 적용: 고성능 온라인 채팅방 만들기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.