Swoole을 사용하여 WebSocket 서버 및 데이터베이스 상호 작용을 구현하는 방법
소개:
WebSocket은 클라이언트와 서버 간에 실시간 양방향 통신을 설정할 수 있는 TCP 프로토콜 기반의 전이중 통신 프로토콜입니다. . Swoole은 고성능 비동기 및 동시 프로그래밍을 쉽게 구현할 수 있는 PHP 확장입니다. 이 기사에서는 Swoole을 사용하여 WebSocket 서버를 구축하고 데이터베이스와 상호 작용하는 방법을 자세히 소개합니다.
1단계: Swoole 확장 설치
먼저 Swoole 확장을 설치해야 합니다. 다음 명령을 통해 설치할 수 있습니다.
pecl install swoole
2단계: WebSocket 서버 생성
다음으로 WebSocket 서버를 생성하고 지정된 포트를 수신하고 클라이언트와 연결을 설정합니다. 이는 다음 코드를 사용하여 달성할 수 있습니다.
<?php $server = new SwooleWebSocketServer("0.0.0.0", 9501); $server->on('open', function (SwooleWebSocketServer $server, $request) { echo "new connection open: {$request->fd} "; }); $server->on('message', function (SwooleWebSocketServer $server, $frame) { echo "received message: {$frame->data} "; // 处理数据库交互 $db = new mysqli('localhost', 'username', 'password', 'database'); $result = $db->query("SELECT * FROM users"); while ($row = $result->fetch_assoc()) { $server->push($frame->fd, json_encode($row)); } $db->close(); }); $server->on('close', function ($ser, $fd) { echo "connection close: {$fd} "; }); $server->start(); ?>
위 코드에서는 WebSocket 서버를 생성하고 세 가지 이벤트 콜백 함수를 추가했습니다. 연결이 설정되면 open
이벤트가 트리거되고, 메시지가 수신되면 message
이벤트가 트리거됩니다. close 이벤트가 발생합니다. >이벤트가 발생합니다. message
이벤트에서는 데이터베이스 대화형 작업을 수행할 수 있습니다. open
事件将被触发;当收到消息时,message
事件将被触发;当连接关闭时,close
事件将被触发。在message
事件中,我们可以进行数据库的交互操作。
步骤三:与数据库交互
在message
事件回调函数中,我们使用了MySQLi扩展来与数据库进行交互。首先,我们创建了一个$db
对象,并使用mysqli
的构造函数连接到数据库。接着,我们执行了一条查询语句,并通过while
循环将查询结果发送给客户端。最后,我们关闭了数据库连接。
需要注意的是,为了安全起见,我们应该将数据库的相关信息(如用户名和密码)设置为环境变量,并通过getenv()
函数来获取这些值,以避免直接暴露在代码中。
步骤四:运行服务器
最后,我们使用命令行来运行上述代码。在命令行中切换到代码所在的目录,并执行以下命令:
php server.php
如果一切正常,你将看到WebSocket服务器成功启动,并等待客户端的连接。当有客户端连接到服务器时,open
事件将被触发,并在命令行中显示连接的ID。当收到客户端发来的消息时,message
事件将被触发,并在命令行中显示收到的消息。当连接关闭时,close
事件将被触发,同样在命令行中显示连接的关闭。
总结:
本文详细介绍了如何使用Swoole实现WebSocket服务器与数据库的交互。通过创建WebSocket服务器,并在message
message
이벤트 콜백 함수에서는 MySQLi 확장을 사용하여 데이터베이스와 상호작용합니다. 먼저 $db
객체를 생성하고 mysqli
생성자를 사용하여 데이터베이스에 연결합니다. 다음으로 쿼리 문을 실행하고 while
루프를 통해 쿼리 결과를 클라이언트에 보냈습니다. 마지막으로 데이터베이스 연결을 닫습니다. 🎜🎜보안상의 이유로 데이터베이스 관련 정보(예: 사용자 이름 및 비밀번호)를 환경 변수로 설정하고 getenv()
함수를 통해 이러한 값을 얻어야 합니다. 코드에 직접 노출됩니다. 🎜🎜4단계: 서버 실행🎜🎜마지막으로 명령줄을 사용하여 위 코드를 실행합니다. 명령줄에서 코드가 있는 디렉터리로 전환하고 다음 명령을 실행합니다. 🎜rrreee🎜 모든 것이 순조롭게 진행되면 WebSocket 서버가 성공적으로 시작되고 클라이언트의 연결을 기다리고 있는 것을 볼 수 있습니다. 클라이언트가 서버에 연결되면 open
이벤트가 트리거되고 연결 ID가 명령줄에 표시됩니다. 클라이언트로부터 메시지가 수신되면 message
이벤트가 트리거되고 수신된 메시지가 명령줄에 표시됩니다. 연결이 닫히면 close
이벤트가 트리거되고 연결 닫힘도 명령줄에 표시됩니다. 🎜🎜요약: 🎜이 문서에서는 Swoole을 사용하여 WebSocket 서버와 데이터베이스 간의 상호 작용을 구현하는 방법을 자세히 설명합니다. WebSocket 서버를 생성하고 message
이벤트 콜백 함수에서 데이터베이스 상호작용을 수행함으로써 실시간 양방향 통신을 달성할 수 있습니다. Swoole 확장을 사용하면 고성능 비동기 및 동시 프로그래밍을 쉽게 수행할 수 있습니다. 이 기사가 Swoole을 사용하여 데이터베이스와 상호 작용하는 데 도움이 되기를 바랍니다. 🎜위 내용은 Swoole을 사용하여 WebSocket 서버 및 데이터베이스 상호 작용을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!