尝试怎么将Laravel改成Swoole版

本篇文章给大家laravelswoole的相关知识,主要内容是教大家怎么将laravel改成swoole版(尝试学习,不建议更改现有项目),下面一起来看看吧,希望对大家有所帮助!

前言

不建议生产环境使用

创建一个新的 laravel 项目

laravel new swoole-laravel

将 Laravel 改成 Swoole 版

Laravel 的根目录创建一个 swoole_server.php 文件,然后把 public/index.php 中的代码复制过来【推荐学习:laravel视频教程】

make(Kernel::class);$response = $kernel->handle(    $request = Request::capture())->send();$kernel->terminate($request, $response);

第一步,框架文件的加载是肯定的,而且应该是在主进程中就加载好的,不需要子进程或者协程再去重复加载。因此,上面的 require 都不太需要动。

第二步,我们要启动一个 HTTP 的 Swoole 服务,这个之前已经讲过很多次了,注意,在 onRequest 中,我们应该将 $kernel 相关的代码放入进去。

$http = new SwooleHttpServer('0.0.0.0', 9501);$http->on('Request', function ($req, $res) use($app) {    try {        $kernel = $app->make(Kernel::class);        $response = $kernel->handle(            $request = Request::capture()        )->send();        $kernel->terminate($request, $response);    }catch(Exception $e){        print_r($e->getMessage());    }});echo "服务启动", PHP_EOL;$http->start();

这样就可以了吗?要不你先试试看。正常情况下可能你是获得不了任何的输入和输出的,这是为啥?

第三步,解决输入问题,其实就是超全局变量在 Swoole 中是不起作用的,所以 $_GET 之类的变量都会失效,Laravel 中 Request 相关的对象都无法获得数据了。这怎么办呢?我们从 onRequest 的参数中拿这些数据,然后再放回到当前进程协程中的 $_GET 中就好啦。

$http->on('Request', function ($req, $res) use($app) {    $_SERVER = [];    if(isset($req->server)){        foreach($req->server as $k => $v){            $_SERVER[strtoupper($k)] = $v;        }    }    $_GET = [];    if(isset($req->get)){        foreach ($req->get as $k => $v){            $_GET[$k] = $v;        }    }    $_POST = [];    if(isset($req->post)){        foreach ($req->post as $k => $v){            $_POST[$k] = $v;        }    }    try {        $kernel = $app->make(Kernel::class);        $response = $kernel->handle(            $request = Request::capture()        )->send();        $kernel->terminate($request, $response);    }catch(Exception $e){        print_r($e->getMessage());    }});

上面三段代码,分别解决了 $_SERVER、$_GET 和 $_POST 的问题。现在你再试试,参数是可以接收到了,但输出怎么是打印在控制台的?

第四步,解决输出问题,将框架中的所有输出放到输出缓冲区,然后再用 Swoole 的 Response 返回。

$http->on('Request', function ($req, $res) use($app) {    $_SERVER = [];    if(isset($req->server)){        foreach($req->server as $k => $v){            $_SERVER[strtoupper($k)] = $v;        }    }    $_GET = [];    if(isset($req->get)){        foreach ($req->get as $k => $v){            $_GET[$k] = $v;        }    }    $_POST = [];    if(isset($req->post)){        foreach ($req->post as $k => $v){            $_POST[$k] = $v;        }    }    //把返回放到一个缓冲区里    ob_start();    try {        $kernel = $app->make(Kernel::class);        $response = $kernel->handle(            $request = Request::capture()        )->send();        $kernel->terminate($request, $response);    }catch(Exception $e){        print_r($e->getMessage());    }    $ob = ob_get_contents();    ob_end_clean();    $res->end($ob);});

最后的 ob_start () 这些内容,也是我们之前学习过的内容,也就不多做解释了。

全部代码

on('Request', function ($req, $res) use($app) {    $_SERVER = [];    if(isset($req->server)){        foreach($req->server as $k => $v){            $_SERVER[strtoupper($k)] = $v;        }    }    $_GET = [];    if(isset($req->get)){        foreach ($req->get as $k => $v){            $_GET[$k] = $v;        }    }    $_POST = [];    if(isset($req->post)){        foreach ($req->post as $k => $v){            $_POST[$k] = $v;        }    }    //把返回放到一个缓冲区里    ob_start();    try {        $kernel = $app->make(Kernel::class);        $response = $kernel->handle(            $request = Request::capture()        )->send();        $kernel->terminate($request, $response);    }catch(Exception $e){        print_r($e->getMessage());    }    $ob = ob_get_contents();    ob_end_clean();    $res->end($ob);});echo "服务启动", PHP_EOL;$http->start();

至此,我们最简单的框架改造就完成了,赶紧试试效果吧。

图改改 图改改

在线修改图片文字

图改改 455 查看详情 图改改

运行

php swoole_server.php

访问

http://47.113.xxx.xx:9501/

试试协程效果

先定义一个路由。或者我们直接改造一下默认的路由。

Route::get('/', function () {    echo SwooleCoroutine::getCid(), "
"; print_r(SwooleCoroutine::stats()); SwooleCoroutine::sleep(10); echo "
"; echo getmypid(), "
";// return view('welcome');});

打印了一堆东西,不过应该都比较熟悉吧,前两个是协程 ID 和协程信息的输出,然后我们 SwooleCoroutine::sleep () 了 10 秒,再打印一下进程 ID 。

然后我们打开浏览器,准备两个标签一起访问。

// 第一个访问的页面1Array(    [event_num] => 2    [signal_listener_num] => 0    [aio_task_num] => 0    [aio_worker_num] => 0    [aio_queue_size] => 0    [c_stack_size] => 2097152    [coroutine_num] => 1    [coroutine_peak_num] => 1    [coroutine_last_cid] => 1)1468// 第二个访问的页面2Array(    [event_num] => 2    [signal_listener_num] => 0    [aio_task_num] => 0    [aio_worker_num] => 0    [aio_queue_size] => 0    [c_stack_size] => 2097152    [coroutine_num] => 2    [coroutine_peak_num] => 2    [coroutine_last_cid] => 2)1468

看出来了吗?每个 onRequest 事件其实都是开了一个新的协程来处理请求所以它们的协程 ID 不同。同时,第二个请求不会因为第一个请求阻塞而等到 20 秒后才返回。最后在协程状态中,我们还看到了第二个请求中显示 coroutine_num 有两个,说明当前有两个协程在处理任务。最后,进程是相同的,它们都是走的同一个进程。

试试多进程效果

默认情况下,上面的代码是一个主进程,一个 Worker 进程,然后再使用了协程能力。其实这样的效果已经能秒杀普通的 PHP-FPM 效果了。但我们要充分利用多核机器的性能,也就是说,我们来开启多进程,使用多进程 + 多协程的超强处理模式。最简单的方式,直接设置 HTTP 服务的进程 Worker 数量即可。

$http->set(array(    'worker_num' => 4,      // 'worker_num' => 1,单进程));

现在运行起服务器,可以看到多了几个进程了。然后我们再新建一个测试路由

Route::get('/a', function () {    echo SwooleCoroutine::getCid(), "
"; print_r(SwooleCoroutine::stats()); echo "
"; echo getmypid(), "
";});

现在再次访问首页和这个 /a 页面。

// 首页一1Array(    [event_num] => 2    [signal_listener_num] => 0    [aio_task_num] => 0    [aio_worker_num] => 0    [aio_queue_size] => 0    [c_stack_size] => 2097152    [coroutine_num] => 1    [coroutine_peak_num] => 1    [coroutine_last_cid] => 1)1562// 首页二1Array(    [event_num] => 2    [signal_listener_num] => 0    [aio_task_num] => 0    [aio_worker_num] => 0    [aio_queue_size] => 0    [c_stack_size] => 2097152    [coroutine_num] => 1    [coroutine_peak_num] => 1    [coroutine_last_cid] => 1)1563// /a 页面1Array(    [event_num] => 2    [signal_listener_num] => 0    [aio_task_num] => 0    [aio_worker_num] => 0    [aio_queue_size] => 0    [c_stack_size] => 2097152    [coroutine_num] => 1    [coroutine_peak_num] => 1    [coroutine_last_cid] => 1)1564

发现没有,它们的进程 ID 也都不同了吧,如果没有阻塞,会优先切换进程,如果所有进程都有阻塞,则再循环创建协程进行进程内的处理。

以上就是尝试怎么将Laravel改成Swoole版的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/340292.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月5日 17:56:05
下一篇 2025年11月5日 17:56:53

相关推荐

  • 在摩尔多瓦创建网站:成功的关键步骤

    在摩尔多瓦建立网站是企业、自由职业者和创业者拓展在线业务的关键一步。无论您需要的是个人博客、电商平台还是公司官网,都需要遵循以下几个重要步骤: 域名和主机选择: 首先,选择一个能够体现您品牌形象的域名。摩尔多瓦常用的域名后缀包括 .md 和 .com。 接下来,选择一个速度快、稳定性高的可靠主机服务…

    2025年12月19日
    000
  • 网络开发的学习路径

    开启您的网络开发之旅!这份指南涵盖了核心技术、常用框架以及学习资源,无论您是新手还是想提升技能的开发者,都能从中获益。 一、核心技能: HTMLCSSJavaScriptGit & GitHub 二、选择您的方向: 前端开发: 学习一个前端框架,例如:ReactVueAngular后端开发:…

    2025年12月19日
    000
  • ENV文件要考虑的OST重要事项列表

    大型项目开发中,.env 文件的管理至关重要。本文总结了六个最佳实践,帮助您在开发和生产环境中安全有效地使用 .env 文件。 1. .env 文件权限设置: 大多数 Web 应用(如 React.js、Laravel 或 Node.js)都使用 .env 文件存储环境变量。 Linux 系统默认隐…

    2025年12月19日
    000
  • 最佳 JavaScript 框架 Nextjs 与 Laravel、新的开发人员工具等

    JavaScript 开发者们,大家好! 欢迎阅读本周 JavaScript 最新动态! 2025 年伊始,令人振奋的趋势正在涌现,包括技术栈的演变、Laravel 与 Next.js 的竞争,以及一些能提升开发效率的便捷新工具。 JavaScript 技术栈的新变化 2025 年,在 AI 辅助开…

    2025年12月19日
    000
  • Google Project IDX、Material UI 的新 React 组件库等等

    JavaScript 开发者们,大家好! 本周的JavaScript 新闻速递来啦! 即使假期来临,JavaScript的世界依旧精彩纷呈。无论您是专注性能优化、深入研究现代框架,还是探索新型数据库,我们都为您准备了重磅更新、实用工具和版本升级,助您提升开发效率。 Google Project ID…

    2025年12月19日
    000
  • 使用 Laravel、Inertiajs v 和 Vue 3 实现无限滚动

    在这篇综合指南中,我们将探索如何使用 inertia.js v2.0 和 vue 3 在 laravel 应用程序中实现无限滚动。我们将介绍前端和后端实现,特别注意处理整页刷新并保持滚动位置。 目录 了解组件前端实现后端实现现实示例:带有类别的博客文章最佳实践和注意事项 了解组件 无限滚动的实现依赖…

    2025年12月19日
    000
  • 进入后端世界的新 Web 开发人员必须了解的技巧

    过渡到后端开发对于 Web 开发人员来说既令人兴奋又充满挑战。前端专注于用户界面和体验,而后端开发则处理为 Web 应用程序提供支持的幕后逻辑、数据库和服务器端进程。如果您是刚进入后端世界的新开发人员,这里有十个基本技巧可以帮助您导航和发展。 1。了解后端的作用后端是 Web 应用程序的基础。它处理…

    2025年12月19日
    000
  • Lithe 内部:PHP 框架如何改变游戏规则

    近年来,使用 PHP 进行 Web 开发取得了令人瞩目的发展,极简框架也变得越来越流行。其中,Lithe 作为轻量级、敏捷且功能强大的解决方案脱颖而出,专为寻求灵活性和性能的开发人员而设计。但 Lithe 到底是如何改变 PHP 开发的游戏规则的呢?让我们深入了解一下为什么这个微框架越来越受到关注。…

    2025年12月19日
    000
  • 我作为全栈开发者的旅程:从 Laravel 到 Nextjs

    作为一名全栈开发人员,我踏上了一段激动人心的旅程,这让我能够探索各种技术、框架和开发实践。在本文中,我想分享我使用 Laravel 进行后端开发和使用 Next.js 进行前端解决方案的经验,以及我在构建创新应用程序时如何在它们之间进行转换。 Laravel API 冒险我的旅程始于 Laravel…

    2025年12月19日
    000
  • 实时交付披萨应用程序

    是一个小型 Laravel CRUD 项目。本项目采用了服务模式。但这个项目的主要特点是高级功能。这些是 – 活动功能。实时通知系统。数据库通知系统。邮件功能。数据库备份功能。安排命令功能。 现在的竞争非常激烈。如果您的项目组合中有一个具有这些高级功能的项目,那么您将会领先一些。 最后,我将尝试展示…

    2025年12月19日
    000
  • Express NextJS NestJS 初学者速查表

    简介 我最近必须学习 nestjs,为一个用它编写的项目做好准备。请注意,不是 nextjs,而是 nestjs。和你们中的一些人一样,我听说过它,但从未有机会实际使用它。它已经流行了一段时间了,今年早些时候赶上了 nodejs 后端开发的鼻祖——expressjs。这是他们的官方推文: <i…

    好文分享 2025年12月19日
    000
  • 使用 Secrets Loader 轻松管理 Laravel 和 JS 项目

    跨各种环境管理 api 密钥、令牌和凭证等敏感数据可能非常棘手,尤其是在开发和部署应用程序时。确保秘密在需要时安全地存储和获取,而不是将它们硬编码到版本控制中,对于维护安全性至关重要。 这就是我创建 secrets loader 的原因,这是一个 bash 脚本,可以动态地将 aws ssm 和 c…

    2025年12月19日
    000
  • 当超级管理员因错误而不允许用户登录时会发生什么

    想象一下,您是网络应用程序的用户,兴奋地导航到登录页面以访问您的帐户,然后输入凭据,单击闪亮的“登录”按钮,然后满怀期待地等待。但可惜的是,您的个性化仪表板并没有迎接您,而是出现了一条不祥的错误消息:“抱歉,由于系统错误,站点管理员已暂时禁用用户登录。”当您感到沮丧时,您可能想知道是什么导致了这种不…

    2025年12月19日
    000
  • 在 Laravel 项目中使用 SCSS 和 TailwindCSS 代码示例

    在编码领域,人们经常意识到什么有效,什么无效,以及尽管是新事物,但什么可以带来明确的改变。在这个小教程中,我将向您展示将 scss tailwindcss 一起用于无数 web 应用程序的最简单的事情。这个强大的组合可以显着增强您的 web 开发工作流程并创建更易于维护的样式表。 所以在开始之前先做…

    2025年12月19日
    000
  • 每个开发人员都应该了解的顶级后端框架

    在不断发展的 Web 开发世界中,后端框架是无名英雄,为我们最喜​​欢的应用程序背后的引擎提供动力。这些框架不仅简化了开发过程,还确保您的应用程序可扩展、安全且健壮。这里是每个开发人员都应该知道的 10 个后端框架。 1.Django-Python: Django 是一个高级 Python 框架,鼓…

    2025年12月19日
    000
  • 使用 Laravel 和 jQuery 实现无限滚动

    与传统分页相比,无限滚动提供了一种更现代、更流畅的数据加载方式。当用户向下滚动页面时,新数据会自动加载,而不是单击分页链接。 先决条件 laravel 和 jquery 的基础知识。具有分页模型的 laravel 项目(例如,用户)。 第 1 步:设置 laravel 进行分页 首先,设置控制器来处…

    2025年12月19日 好文分享
    000
  • 使用 Laravel + React 安装 Shadcn/ui❤️

    目前有很多css框架,例如bootstrap、bulma、semantic ui等。这可以加快构建显示(用户界面)的速度。目前流行的 css 工具之一是 shadcn/ui,它之前是什么? 在其官方网站shadcn/ui上表示 “我们可以复制并粘贴到我们的应用程序中的可重用组件的集合。” 所以 sh…

    2025年12月19日 好文分享
    000
  • 从头开始构建 Web 应用程序:基本指南以及何时雇用 Magento 开发人员

    简介 Web 应用程序已成为现代商业的基石,提供动态和交互式平台,可提高用户参与度和运营效率。无论您是开发简单的内容管理系统还是复杂的电子商务平台,了解 Web 应用程序开发的基础知识都至关重要。本指南将引导您完成从头开始构建 Web 应用程序的过程,并解释何时以及为何应考虑雇用 Magento 开…

    2025年12月19日
    000
  • 如何将shadcn添加到现有项目中

    如果您是一名 web 开发人员,您很可能听说过 shadcn/ui,它是基于 radix ui 的最流行的组件库之一。在这篇文章中,我们将探讨如何将 shadcn 添加到现有项目中。 根据您的项目设置方式以及您使用的框架,将 shadcn 添加到现有项目将会有所不同。当使用 shadcn 使用此库时…

    2025年12月19日
    000
  • Javascript没有全栈框架(这次将怀念全栈时代)

    本文开始了关于 Gergely Orosz 的 What is Old is New Again 演讲的一系列笔记,试图将他的预测(引起我强烈共鸣)转化为聪明的软件工程师的实际步骤。 “全栈正在如火如荼地进行” 当你开始考虑全栈框架时,你很可能会想到三大兄弟:PHP 的 Laravel、Ruby o…

    2025年12月19日
    000

发表回复

登录后才能评论
关注微信