laravel9 和 laravels 性能大比拼!

前言:最近想使用 swoole 试试 websocket, 正好安装测试下 laravel 和 swoole 性能,不知道是不是 laravel9 性能优化的好,最后压测结果和 laravels 的差不多~

laradock 安装 swoole

ed4899685b5f07e2135d4602c13d982.jpg

动手操作后遇到问题:
406a026ed7007a10f428f6a0893480a.jpg

因为原先的 PHP 版本是 7.4,需要修改.env 文件,将版本切换到 8.0 及以上 (laravels 安装的时候要求 php 是 8.1,所以还是设置成 8.1 版本的):
2029fd47cf338094a3fbc4b7c9a88ac.jpg

再次执行 build 命令后成功。【推荐:laravel视频教程】

验证结果:
14a43fc4c7f5fdec05a7f3dd81dfd3f.jpg

配置 laravels 的 http 服务器

1. 安装 laravel 项目

教程很多,此处参考自:Laravel 9 中文文档 – 安装

基于 安装了 docker 的环境

curl -s "https://laravel.build/laravel9" | bashCopy

2. 安装 laravels

composer require hhxsv5/laravel-sCopy

3. 发布 laravels 配置

php artisan laravels publishCopy

4. 配置站点

说明: 站点对应的项目代码都是 /var/www/laravel9/public

(1) 配置 laravels 的 http 服务器

upstream laravels {    # Connect IP:Port    server workspace:5200 weight=5 max_fails=3 fail_timeout=30s;    keepalive 16;}server {    listen 80;    server_name swoole.test;    root /var/www/laravel9/public;    index index.php index.html index.htm;    # Nginx 处理静态资源,LaravelS 处理动态资源    location / {        try_files $uri @laravels;    }    location @laravels {        proxy_http_version 1.1;        proxy_set_header Connection "";        proxy_set_header X-Real-IP $remote_addr;        proxy_set_header X-Real-PORT $remote_port;        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;        proxy_set_header Host $http_host;        proxy_set_header Scheme $scheme;        proxy_set_header Server-Protocol $server_protocol;        proxy_set_header Server-Name $server_name;        proxy_set_header Server-Addr $server_addr;        proxy_set_header Server-Port $server_port;        proxy_pass http://laravels;    }    error_log /var/log/nginx/swoole_test_error.log;    access_log /var/log/nginx/swoole_test_access.log;}

注意:laravels 项目需要在 laravel9 项目下的.env 文件中增加以下配置:

LARAVELS_LISTEN_IP=workspaceLARAVELS_DAEMONIZE=trueCopy

(2) 配置普通 laravel 项目站点

盘古大模型 盘古大模型

华为云推出的一系列高性能人工智能大模型

盘古大模型 35 查看详情 盘古大模型

server {    listen 80;    listen [::]:80;    # For https    # listen 443 ssl;    # listen [::]:443 ssl ipv6only=on;    # ssl_certificate /etc/nginx/ssl/default.crt;    # ssl_certificate_key /etc/nginx/ssl/default.key;    server_name laravel.test;    root /var/www/laravel9/public;    index index.php index.html index.htm;    location / {         try_files $uri $uri/ /index.php$is_args$args;    }    location ~ .php$ {        try_files $uri /index.php =404;        fastcgi_pass php-upstream;        fastcgi_index index.php;        fastcgi_buffers 16 16k;        fastcgi_buffer_size 32k;        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;        #fixes timeouts        fastcgi_read_timeout 600;        include fastcgi_params;    }    location ~ /.ht {        deny all;    }    location /.well-known/acme-challenge/ {        root /var/www/letsencrypt/;        log_not_found off;    }    error_log /var/log/nginx/laravel_error.log;    access_log /var/log/nginx/laravel_access.log;}

(3) 本地 host 配置

127.0.0.1 swoole.test127.0.0.1 laravel.testCopy

(4) 重新 build 容器

docker-compose stopdocker-compose build workspace nginxdocker-compose up -d redis mysql nginx workspaceCopy

8af3bba1ba753e49505ce331c9e8730.jpg

(5) 进入 workspace 容器启动 laravels

进入容器命令:

docker exec -it d4940755a928 /bin/bashCopy

75f9720d82a9fccdbc50b98fb70f837.jpg

AB 性能测试结果

核心关注的是每秒请求数(Requests per second)都是基于 Laradock 环境共享同一份项目代码

1.总请求数是 100,并发数是 10(左侧为 swoole,右侧为 laravel9):
6fed5cab1c9d66b6ef8aca2a4e2d0f7.jpg

2.总请求数是 1000,并发数是 20(左侧为 swoole,右侧为 laravel9);
9a4392b610e69e6c6560b697200b75f.jpg

差距不明显,甚至有时候 laravel9 的结果更好,这样的结果算翻车吗~

原文地址:https://learnku.com/articles/73575

以上就是laravel9 和 laravels 性能大比拼!的详细内容,更多请关注创想鸟其它相关文章!

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

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

相关推荐

  • Laravel路由参数缺失问题解析与最佳实践

    本文深入探讨了Laravel应用中常见的路由参数缺失错误,特别是当路由定义了具名参数而 route() 辅助函数调用时未能正确传递参数名时引发的问题。通过分析错误根源并提供两种正确的参数传递方式,旨在帮助开发者理解并有效解决此类路由错误,确保应用导航的流畅性与准确性。 理解Laravel路由参数 在…

    2025年12月20日
    000
  • 解决 Laravel 路由参数缺失问题的教程

    本文旨在解决 Laravel 应用中常见的“Missing required parameter”路由错误。当路由定义中包含参数(如{user})而route()辅助函数调用时未能提供正确匹配的参数名时,此错误便会发生。我们将深入分析问题根源,并提供两种有效的解决方案,确保路由参数的正确传递,从而避…

    2025年12月20日
    000
  • Laravel 路由参数缺失问题排查与解决:以会话功能为例

    本文针对 Laravel 开发中常见的 “Missing required parameter” 路由错误,以一个会话功能为例,详细讲解了如何排查错误原因并提供解决方案。重点分析了路由定义、URL 生成以及控制器参数传递等环节,帮助开发者避免类似问题,确保应用的正常运行。 在…

    2025年12月20日
    000
  • 告别重复:使用Laravel Precognition统一前后端API验证

    本文旨在解决在Laravel后端与前端API交互中,如何高效复用后端验证规则的挑战。传统方案常限于表单元素,难以覆盖所有API请求。通过引入Laravel Precognition,开发者能够实现后端验证逻辑在前端的无缝应用,避免规则重复编写,从而提升开发效率与代码一致性,确保所有API请求的数据完…

    2025年12月20日
    000
  • HTML表单中JavaScript不执行的调试与解决方案

    本文深入探讨HTML表单中JavaScript不执行的常见原因及解决方案。我们将重点讲解DOM元素ID匹配的重要性、如何阻止表单的默认提交行为,以及利用事件监听器(包括原生JavaScript和jQuery)确保脚本正确执行,从而实现提交成功提示等交互功能。 在开发web表单时,我们经常需要通过ja…

    2025年12月20日
    000
  • HTML表单JavaScript交互:成功消息显示与表单处理指南

    本文旨在解决HTML表单中JavaScript代码不运行,特别是无法正确显示提交成功消息的问题。我们将深入分析常见的错误原因,如DOM元素ID不匹配和表单默认提交行为,并提供纯JavaScript和jQuery两种解决方案,确保用户提交表单后能够即时获得反馈,提升交互体验。 HTML表单JavaSc…

    2025年12月20日
    000
  • 解决Fancybox模态框中TikTok视频嵌入后消失的问题

    本教程详细阐述了在Fancybox模态框中嵌入TikTok视频时,视频立即消失的问题。该问题源于TikTok嵌入脚本误删自身iframe的行为。解决方案是利用MutationObserver动态插入一个“占位”元素,以确保TikTok脚本在模态框加载时删除的是占位符而非实际视频iframe,从而实现…

    2025年12月20日
    000
  • React 应用管理员面板构建:从本地 JSON 到生产级数据管理

    本文旨在指导React应用开发者如何为电商网站等应用构建管理员面板,以实现数据(如商品卡片)的增删改查。文章将探讨从本地JSON文件管理的局限性,到利用浏览器端文件下载模拟数据更新的临时方案,再到后端服务和无头CMS(如Strapi)等生产级解决方案,帮助开发者选择最适合其项目需求的数据管理策略。 …

    2025年12月20日
    000
  • 构建React应用管理后台:从本地JSON到Headless CMS的实践指南

    本文探讨了为React应用创建管理后台的多种方法,特别针对从本地JSON文件管理数据到实现可编辑、删除和添加内容的场景。我们将深入分析直接操作本地文件的局限性,介绍后端服务的重要性,并重点推荐使用Strapi等无头CMS作为高效、可扩展的解决方案,帮助开发者轻松构建功能完善的管理界面。 React应…

    2025年12月20日
    000
  • 为React应用构建管理员面板:从本地JSON到无头CMS的数据管理策略

    本文探讨了为React应用创建管理员面板以管理数据(如商品信息)的多种策略。从简单的客户端本地JSON文件编辑,到传统后端集成,再到现代无头CMS(如Strapi)的运用,文章详细分析了各种方案的优缺点,并提供了实现思路和代码示例,旨在帮助开发者选择最适合其项目需求的数据管理解决方案。 引言:从静态…

    2025年12月20日
    000
  • 如何用Web NFC实现智能海报的交互体验?

    Web NFC智能海报通过一碰即连的交互方式,实现物理与数字世界的无缝衔接。用户轻触嵌入NFC标签的海报,即可直接打开预设网页,无需扫码或下载App,提升互动效率与沉浸感。核心技术包括NFC标签(如NTAG213/215/216)写入NDEF格式URL、基于HTML/CSS/JavaScript构建…

    2025年12月20日
    000
  • 使用原生JavaScript实现商品数量增减按钮功能

    本文详细介绍了如何使用原生JavaScript为网页商品数量输入框添加“加”和“减”按钮功能。通过事件监听器和DOM操作,用户可以直观地调整商品数量。教程涵盖了核心JavaScript代码、关键概念解释及前端开发最佳实践建议,帮助开发者构建交互式用户界面,提升用户体验。 在电子商务网站或其他需要用户…

    2025年12月20日
    000
  • JavaScript实现动态商品数量加减:一个基础教程

    本教程详细介绍了如何使用原生JavaScript为网页上的商品数量输入框添加“加”和“减”按钮功能。通过监听按钮点击事件,动态更新输入框的数值,实现用户友好的数量调整体验。文章涵盖了HTML结构、JavaScript代码实现及关键概念解析,并提供了代码分离、ID选择器使用等最佳实践建议,帮助开发者构…

    2025年12月20日
    000
  • 使用JavaScript实现商品数量加减按钮功能

    本教程详细介绍了如何通过纯JavaScript为网页上的商品数量输入框添加“加”和“减”按钮功能。文章将从HTML结构入手,逐步讲解JavaScript代码的实现原理,包括DOM元素选择、事件监听和数值操作,并提供可直接使用的代码示例及相关最佳实践,帮助开发者提升用户体验。 1. 概述与需求分析 在…

    2025年12月20日
    000
  • JavaScript实现动态商品数量增减按钮功能教程

    本教程将详细指导如何使用纯JavaScript为网页上的商品数量输入框添加“加”和“减”按钮功能。通过事件监听器和DOM操作,用户可以直观地增减商品数量,实现客户端的动态数量控制,提升用户交互体验。 在电子商务网站的商品详情页或购物车页面,用户经常需要调整商品的购买数量。为了提供更友好的交互体验,通…

    2025年12月20日
    000
  • 使用 Tailwind CSS 离线开发指南

    Tailwind CSS 是一款流行的实用优先的 CSS 框架,但有时我们可能需要在没有互联网连接的环境中使用它。本文将介绍如何在离线环境下使用 Tailwind CSS,包括下载完整 CSS 文件、集成到项目以及注意事项。 下载完整的 Tailwind CSS 文件 首先,你需要下载完整的 Tai…

    2025年12月20日
    000
  • 使用 Tailwind CSS 离线开发:完整指南

    本文旨在指导开发者如何在没有网络连接的情况下,使用 Tailwind CSS 进行项目开发。我们将介绍如何下载完整的 Tailwind CSS 文件,并将其集成到你的项目中,确保即使在离线环境下也能正常使用 Tailwind CSS 的全部功能。 离线使用 Tailwind CSS 的方法 在某些情…

    2025年12月20日
    000
  • 使用 Tailwind CSS 离线环境搭建教程

    本文旨在提供一套在无网络环境下使用 Tailwind CSS 的完整解决方案。通过预先下载 Tailwind CSS 核心文件,并配置项目环境,即使在离线状态下,也能实现 Tailwind CSS 的编译和使用,从而保证开发流程的顺畅进行。 离线使用 Tailwind CSS 的步骤 在网络环境不稳…

    2025年12月20日
    000
  • GitHub Pages上JSON数据动态更新的挑战与最佳实践:告别客户端直写

    本文探讨了在GitHub Pages上通过客户端JavaScript(如Axios)直接修改JSON文件时遇到的CORS错误及其根本原因。我们将解释为何静态文件服务不支持此类操作,并介绍GitHub API作为一种间接方式,但重点强调了其安全局限性。最终,文章将推荐使用专业的后端服务与数据库,作为实…

    2025年12月20日
    000
  • 隐藏API密钥:使用Laravel和Leaflet创建热图的专业指南

    正如上述摘要所述,本文将指导开发者在使用Laravel和Leaflet构建空气质量热图时,如何安全地隐藏Breezometer API密钥。核心思路是创建一个服务器端代理,避免直接在客户端暴露API密钥。 实现服务器端代理 为了隐藏API密钥,我们需要在Laravel后端创建一个代理控制器。该控制器…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信