php中使用swoole加速lumen项目-laravelS实战

2024-04-02 23:58

本文主要是介绍php中使用swoole加速lumen项目-laravelS实战,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

参考:https://www.phpmianshi.com/?id=195

背景

 

公司项目严重依赖lumen系列,代码众多,重构困难,虽然访问量变大,性能问题越来越严重,急需要提升性能,于是找到了这个项目

 

https://github.com/hhxsv5/laravel-s

 

下面我们来实战一下

 

环境介绍

 

php7.2

centos7

swoole4.5.7

lumen5.8

 

1.安装

源码安装

wget  https://github.com/swoole/swoole-src/archive/v4.5.7.tar.gz
tar -xzvf v4.5.7.tar.gz
cd swoole-src-4.5.7 && \
phpize && \
./configure && \
make && sudo make install

 

启动扩展,需要在 php.ini 中加入如下配置来启用 Swoole 扩展

 extension=swoole.so

 

验证是否配置成功

php -m |grep swoole

 

如果没有可能是 php.ini 的路径不对。
可以使用 php --ini 来定位到 php.ini 的绝对路径,Loaded Configuration File 一项显示的是加载的 php.ini 文件,如果值为 none 证明根本没加载任何 php.ini 文件,需要自己创建。

#安装laravelS
composer require "hhxsv5/laravel-s:3.7.8" -vvv
# 确保你的composer.lock文件是在版本控制中

 

2.注册,咱们是lumen5.8需要手动注册,修改 bootstrap/app.php

$app->register(Hhxsv5\LaravelS\Illuminate\LaravelSServiceProvider::class);

 

3.发布配置和二进制文件

注意:每次升级LaravelS后,需重新publish;点击Release去了解各个版本的变更记录。

php artisan laravels publish
# 配置文件:config/laravels.php
# 二进制文件:bin/laravels bin/fswatch bin/inotify

4.修改配置config/laravels.php:监听的IP、端口等

 

请参考配置项。

5.运行

php bin/laravels {start|stop|restart|reload|info|help}

 

start  启动laravelS,展示已启动进程 ps -ef |grep laravels

stop  停止laravelS,并处罚自定义进程的onStop方法

restart  重启LaravelS:先平滑Stop,然后再Start;在Start完成之前,服务是不可用的

reload  平滑重启所有Task/Worker/Timer进程(这些进程内包含了你的业务代码),并触发自定义进程的onReload方法,不会重启Master/Manger进程;修改config/laravels.php后,你只有调用restart来完成重启

info 显示组件的版本信息

help  显示帮助信息

 

nginx配置

upstream swoole {server 127.0.0.1:5200 weight=5 max_fails=3 fail_timeout=30s;keepalive 16;
}
server  {listen 8081;server_name 127.0.0.1;root  /data/nginx/wwwbeta/app/public;index  index.php index.html;add_header X-Frame-Options "SAMEORIGIN";add_header X-XSS-Protection "1; mode=block";add_header X-Content-Type-Options "nosniff";charset utf-8;error_page 404 /index.php;access_log  /data/nginx/logs/nginx_access.log  json;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://swoole;}location ~ /\.(?!well-known).* {deny all;}}

 

压测

 

#观察日志,看状态码是否正常
tail -f nginx_access.log |grep new_stock#ab压测swoole
ab -c 200 -n 1000 127.0.0.1:8081/stocks/new_stock#结果
Concurrency Level:      200
Time taken for tests:   2.094 seconds
Complete requests:      1000
Failed requests:        0
Write errors:           0
Total transferred:      12832000 bytes
HTML transferred:       12493000 bytes
Requests per second:    477.56 [#/sec] (mean)#压测php-fpm  
ab -c 200 -n 1000 127.0.0.1:8080/stocks/new_stock
#结果
Concurrency Level:      200
Time taken for tests:   6.057 seconds
Complete requests:      1000
Failed requests:        852(Connect: 0, Receive: 0, Length: 852, Exceptions: 0)
Write errors:           0
Non-2xx responses:      852
Total transferred:      2166668 bytes
HTML transferred:       1980172 bytes
Requests per second:    165.11 [#/sec] (mean)

可见swoole并发远超php-fpm,而且功能更加稳定,php-fpm已经开始出现大量499错误

这篇关于php中使用swoole加速lumen项目-laravelS实战的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/871406

相关文章

使用Vue-ECharts实现数据可视化图表功能

《使用Vue-ECharts实现数据可视化图表功能》在前端开发中,经常会遇到需要展示数据可视化的需求,比如柱状图、折线图、饼图等,这类需求不仅要求我们准确地将数据呈现出来,还需要兼顾美观与交互体验,所... 目录前言为什么选择 vue-ECharts?1. 基于 ECharts,功能强大2. 更符合 Vue

如何合理使用Spring的事务方式

《如何合理使用Spring的事务方式》:本文主要介绍如何合理使用Spring的事务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、底层构造1.1.事务管理器1.2.事务定义信息1.3.事务状态1.4.联系1.2、特点1.3、原理2. Sprin

Vue中插槽slot的使用示例详解

《Vue中插槽slot的使用示例详解》:本文主要介绍Vue中插槽slot的使用示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、插槽是什么二、插槽分类2.1 匿名插槽2.2 具名插槽2.3 作用域插槽三、插槽的基本使用3.1 匿名插槽

springboot+vue项目怎么解决跨域问题详解

《springboot+vue项目怎么解决跨域问题详解》:本文主要介绍springboot+vue项目怎么解决跨域问题的相关资料,包括前端代理、后端全局配置CORS、注解配置和Nginx反向代理,... 目录1. 前端代理(开发环境推荐)2. 后端全局配置 CORS(生产环境推荐)3. 后端注解配置(按接口

使用WPF实现窗口抖动动画效果

《使用WPF实现窗口抖动动画效果》在用户界面设计中,适当的动画反馈可以提升用户体验,尤其是在错误提示、操作失败等场景下,窗口抖动作为一种常见且直观的视觉反馈方式,常用于提醒用户注意当前状态,本文将详细... 目录前言实现思路概述核心代码实现1、 获取目标窗口2、初始化基础位置值3、创建抖动动画4、动画完成后

Vue 2 项目中配置 Tailwind CSS 和 Font Awesome 的最佳实践举例

《Vue2项目中配置TailwindCSS和FontAwesome的最佳实践举例》:本文主要介绍Vue2项目中配置TailwindCSS和FontAwesome的最... 目录vue 2 项目中配置 Tailwind css 和 Font Awesome 的最佳实践一、Tailwind CSS 配置1. 安

PyQt5 QDate类的具体使用

《PyQt5QDate类的具体使用》QDate是PyQt5中处理日期的核心类,本文主要介绍了PyQt5QDate类的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录核心功能常用方法及代码示例​1. 创建日期对象​2. 获取日期信息​3. 日期计算与比较​4. 日

Go语言使用slices包轻松实现排序功能

《Go语言使用slices包轻松实现排序功能》在Go语言开发中,对数据进行排序是常见的需求,Go1.18版本引入的slices包提供了简洁高效的排序解决方案,支持内置类型和用户自定义类型的排序操作,本... 目录一、内置类型排序:字符串与整数的应用1. 字符串切片排序2. 整数切片排序二、检查切片排序状态:

使用Java将实体类转换为JSON并输出到控制台的完整过程

《使用Java将实体类转换为JSON并输出到控制台的完整过程》在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用JSON格式,用Java将实体类转换为J... 在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用j

基于C#实现MQTT通信实战

《基于C#实现MQTT通信实战》MQTT消息队列遥测传输,在物联网领域应用的很广泛,它是基于Publish/Subscribe模式,具有简单易用,支持QoS,传输效率高的特点,下面我们就来看看C#实现... 目录1、连接主机2、订阅消息3、发布消息MQTT(Message Queueing Telemetr