PHPackages                             firma/swoole-http-bundle - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. firma/swoole-http-bundle

ActiveSymfony-bundle

firma/swoole-http-bundle
========================

Symfony Swoole HTTP Server Bundle

v1.0.0(7y ago)317PHPPHP &gt;=7.1.3

Since Sep 3Pushed 7y ago1 watchersCompare

[ Source](https://github.com/firma/swoole-http-bundle)[ Packagist](https://packagist.org/packages/firma/swoole-http-bundle)[ RSS](/packages/firma-swoole-http-bundle/feed)WikiDiscussions master Synced 4w ago

READMEChangelogDependencies (1)Versions (3)Used By (0)

安装
--

[](#安装)

```
# 安装服务
$ composer require firma/swoole-http-bundle
```

命令行操作
-----

[](#命令行操作)

```
# 启动swoole 服务
$ php bin/console swoole:server:start
```

```
# 关闭swoole 服务
$ php bin/console swoole:server:stop
```

```
# 重载swoole 服务
$ php bin/console swoole:server:reload
```

```
# swoole 服务状态
$ php bin/console swoole:server:status
```

---

配置
--

[](#配置)

#### 默认配置

[](#默认配置)

- 在 config/packages 下配置 firma\_swoole.yaml

```
firma_swoole:
    host: 0.0.0.0
    port: 8000
    options:
        pid_file:  '%kernel.logs_dir%/%kernel.environment%_swoole_server.pid'
        log_file: '%kernel.logs_dir%/swoole.log'
        daemonize: true #守护进程化
        document_root: '%kernel.project_dir%/public' #配置静态文件根目录， https://wiki.swoole.com/wiki/page/783.html
        enable_static_handler: true
```

#### 参数配置

[](#参数配置)

```
options:
    max_request: ~ #设置worker进程的最大任务数，默认为0，一个worker进程在处理完超过此数值的任务后将自动退出，进程退出后会释放所有内存和资源。
    open_cpu_affinity: ~ #启用CPU亲和性设置。在多核的硬件平台中，启用此特性会将swoole的reactor线程/worker进程绑定到固定的一个核上。可以避免进程/线程的运行时在多个核之间互相切换，提高CPU Cache的命中率。
    task_worker_num: ~ #配置Task进程的数量，配置此参数后将会启用task功能。所以Server务必要注册onTask、onFinish2个事件回调函数。如果没有注册，服务器程序将无法启动。
    enable_port_reuse: ~ #设置端口重用，此参数用于优化TCP连接的Accept性能，启用端口重用后多个进程可以同时进行Accept操作。
    worker_num: ~ #设置启动的Worker进程数。
    reactor_num: ~ #Reactor线程数 z，reactor_num => 2，通过此参数来调节主进程内事件处理线程的数量，以充分利用多核。默认会启用CPU核数相同的数量。
    dispatch_mode: ~ #数据包分发策略。可以选择3种类型，默认为2
    discard_timeout_request: ~ #swoole在配置dispatch_mode=1或3后，系统无法保证onConnect/onReceive/onClose的顺序，因此可能会有一些请求数据在连接关闭后，才能到达Worker进程。
    open_tcp_nodelay: ~ #启用open_tcp_nodelay，开启后TCP连接发送数据时会关闭Nagle合并算法，立即发往客户端连接。在某些场景下，如http服务器，可以提升响应速度。
    open_mqtt_protocol: ~ #启用mqtt协议处理，启用后会解析mqtt包头，worker进程onReceive每次会返回一个完整的mqtt数据包。
    user: ~ #设置worker/task子进程的所属用户。服务器如果需要监听1024以下的端口，必须有root权限。但程序运行在root用户下，代码中一旦有漏洞，攻击者就可以以root的方式执行远程指令，风险很大。配置了user项之后，可以让主进程运行在root权限下，子进程运行在普通用户权限下。
    group: ~ #设置worker/task子进程的进程用户组。与user配置相同，此配置是修改进程所属用户组，提升服务器程序的安全性。
    #设置SSL隧道加密，设置值为一个文件名字符串，制定cert证书和key私钥的路径。
    ssl_cert_file: ~
    ssl_key_file: ~
```

为Redis连接定义Symfony服务，并将其设置为服务的构造函数参数RedisSessionHandler：

```
# config/services.yaml
services:
    Redis:
        class: Redis
        calls:
            - method: connect
              arguments:
                  - '%env(REDIS_HOST)%'
                  - '%env(int:REDIS_PORT)%'
            # If you need key prefix, uncomment line belows
            # - method: setOption
            #   arguments:
            #       - !php/const Redis::OPT_PREFIX
            #       - 'my_prefix'

    Symfony\Component\HttpFoundation\Session\Storage\Handler\RedisSessionHandler:
        arguments:
            - '@Redis'

```

要了解有关%env(…)%Symfony 3\\4 中引入的高级用法的更多信息（如我在此处使用的int处理器），请查看 [Symfony文档](https://symfony.com/doc/current/configuration/external_parameters.html)。 您现在可以将该服务用作会话处理程序：

```
# config/packages/framework.yaml
framework:
    session:
        handler_id: Symfony\Component\HttpFoundation\Session\Storage\Handler\RedisSessionHandler

```

- [swoole参数文档](https://wiki.swoole.com/wiki/page/p-max_request.html)

###  Health Score

26

—

LowBetter than 43% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity9

Limited adoption so far

Community7

Small or concentrated contributor base

Maturity58

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Unknown

Total

1

Last Release

2805d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/38864581ac274dd81ef362fcf618b4a111a30a07c233a4bf6c3bac68e707df2c?d=identicon)[keyed](/maintainers/keyed)

---

Top Contributors

[![firma](https://avatars.githubusercontent.com/u/2088807?v=4)](https://github.com/firma "firma (5 commits)")

### Embed Badge

![Health badge](/badges/firma-swoole-http-bundle/health.svg)

```
[![Health](https://phpackages.com/badges/firma-swoole-http-bundle/health.svg)](https://phpackages.com/packages/firma-swoole-http-bundle)
```

###  Alternatives

[scheb/2fa

Two-factor authentication for Symfony applications (please use scheb/2fa-bundle to install)

578630.7k1](/packages/scheb-2fa)[stfalcon/tinymce-bundle

This Bundle integrates TinyMCE WYSIWYG editor into a Symfony2 project.

2692.9M24](/packages/stfalcon-tinymce-bundle)[shopware/core

Shopware platform is the core for all Shopware ecommerce products.

595.2M386](/packages/shopware-core)[symfony/ai-bundle

Integration bundle for Symfony AI components

30282.3k6](/packages/symfony-ai-bundle)[rikudou/psr6-dynamo-db-bundle

PSR-6 and PSR-16 cache implementation using AWS DynamoDB for Symfony

2077.8k](/packages/rikudou-psr6-dynamo-db-bundle)[leapt/core-bundle

Symfony LeaptCoreBundle

2529.1k4](/packages/leapt-core-bundle)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
