workman(gateway)中的stdout.log(或自定义日志文件名)文件删除后新建一个,无法再写入log信息

当删除workerman中的stdout.log后,由于进程仍然引用该文件,新创建的同名文件无法被workerman写入。解决方法是在start_businessworker.php中添加代码,在MasterReload时调用Worker::resetStd(),以重置文件引用,然后重新加载workerman,即可使新stdout.log生效。
摘要由CSDN通过智能技术生成

workerman里会有个资源使用这个stdout.log,虽然文件被删除,但是实际上还是被进程引用着,只是磁盘里看不到而已。
重新创建的stdout.log是新的文件,workerman里并没有引用它,所以不会向里写入数据。
start_businessworerk.php里加上如下代码,删除完stdout.log 然后reload下workerman,应该可以重置文件引用。
$business_worker->onMasterReload = function() {
    Worker::resetStd();
};

来至:

gateway中的stdout.log文件删除后新建一个,无法再录入log信息,求指教-workerman社区

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Workerman,可以通过使用异步任务来处理长连接的业务逻辑,避免阻塞主进程。异步任务可以在Worker进程通过`AsyncTask`类来实现,具体的步骤如下: 1. 在Worker进程创建`AsyncTask`对象,指定异步任务的处理方法。 ```php use \Workerman\Worker; use \Workerman\MySQL\Connection; use \Workerman\AsyncTask; $worker = new Worker('tcp://0.0.0.0:8000'); $worker->onWorkerStart = function($worker) { // 创建MySQL连接 $mysql = new Connection('127.0.0.1', '3306', 'username', 'password', 'dbname'); // 创建异步任务 $task = new AsyncTask(); // 设置异步任务的处理方法 $task->onMessage = function($task, $data) use ($mysql) { // 处理业务逻辑 $result = $mysql->query('SELECT * FROM users WHERE id='.$data); // 返回处理结果 $task->send($result); }; // 将异步任务注册到Worker进程 $worker->addTask($task); }; ``` 2. 在客户端连接上来后,将需要处理的数据发送到异步任务,等待异步任务处理完成后,再将结果返回给客户端。 ```php $worker->onConnect = function($connection) use ($worker) { // 接收客户端发送的数据 $connection->onMessage = function($connection, $data) use ($worker) { // 将数据发送到异步任务处理 $worker->task($data, function($result) use ($connection) { // 处理异步任务返回的结果 $connection->send(json_encode($result)); }); }; }; ``` 通过以上的步骤,我们就可以在长连接使用异步任务来处理业务逻辑了。需要注意的是,异步任务的处理方法会在Worker进程的异步任务进程执行,所以需要将需要的资源例如MySQL连接等在onWorkerStart回调函数创建。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值