swoole 4.2.11 报错【async-io must be used in PHP CLI mode】 以及 websocket server收到的数据总是乱码的问题

本猿在2018.12.30使用swoole的websocket server与html5的websocket进行聊天测试,发现,前端传到swoole的数据,即使只是几个英文字符,swoole 的websocket server在onMessage中收到的数据($frame->data)总是乱码。

//创建websocket服务器对象,监听0.0.0.0:9502端口
$webSocketServer = new  Swoole\WebSocket\Server("0.0.0.0", 9502);

//监听WebSocket连接打开事件
$webSocketServer->on('open', function ($ws, $request) {
    $ws->push($request->fd, "hello, welcome");
});

//监听WebSocket消息事件
$webSocketServer->on('message', function ($ws, $frame) {
    $ws->push($frame->fd, 'swoole收到信息:'.$frame->data);
});

//监听WebSocket连接关闭事件
$webSocketServer->on('close', function ($ws, $fd) {
    echo "client-{$fd} is closed\n";
});

$webSocketServer->start();

于是升级swoole, 从4.2.11-alpha(或者rc-1)升级到4.2.11, 结果连http server都没法玩了,总是报错: async-io must be used in PHP CLI mode。即使是这么少的代码:

$server = new Swoole\Http\Server('test.swoole.local', 9501);
$server->on('Request', function()
{

});
$server->start();

猜测是swoole的问题。因为4.2.11是前两天发布的,太新了。

swoole 4.2.11 报错【async-io must be used in PHP CLI mode】 以及 websocket server收到的数据总是乱码的问题_第1张图片

4.2.11 的状态居然是stable,我去,明明非常的unstable, 甚至可以说是一身的bug----这分明是带伤上线哪。

安装swoole 4.2.10之后,不但“async-io must be used in PHP CLI mode”消失了,swoole 的websocket server在onMessage中收到的数据($frame->data)总是乱码的问题也不治而愈了呢。

我把这个问题通过QQ报告给swoole官方,官方不相信,为了证明我没有冤枉他,这次,不在安放swoole扩展的目录直接git pull https://gitee.com/swoole/swoole.git, 然后一步一步执行编译安装的命令,而是

  1. 用"sudo rm -rf   [安放swoole扩展的目录] "彻底删除安放swoole扩展的目录,
  2. 重建目录,
  3. 再git init,
  4. 然后git pull https://gitee.com/swoole/swoole.git,
  5. 然后一步一步执行编译安装的命令。
  6. 测试一下,我去,“async-io must be used in PHP CLI mode”没有出现,swoole 的websocket server在onMessage中收到的数据($frame->data)总是乱码的问题也没有出现。

当时:

  1. 在安放swoole扩展的目录直接git pull https://gitee.com/swoole/swoole.git,
  2. 然后"sudo ./configure  --with-php-config=/www/server/php/73/bin/php-config", 执行完后,告诉我,config.h这个文件没有发生改变,我心里有一丝丝惊讶,本以为无大碍,没想到呀。。。

官方的版本还真是stable, 是本猿错了。。。我升级方法不对。

我用的的是:php 7.3 , Ubuntu Desktop 18.04。用宝塔面板安装的php7.3。

 

 

你可能感兴趣的:(swoole 4.2.11 报错【async-io must be used in PHP CLI mode】 以及 websocket server收到的数据总是乱码的问题)