1

我希望有人可以帮助我解决这个问题:

我的 laravel 项目(7.x)在本地环境(带有 redis 的 Laragon 4.0)上没有问题广播。我想实时移动它,以便使用 Ubuntu 18.04.4、apache2、virtualmin cp 在我的 VPS 上进行更准确的测试。

我确实安装了redis服务器(最新版本)并且正在运行(PING-> PONG,创建键->值,读取键->值...重新启动服务并且键->值仍然存在...所有测试都运行良好)。当我触发我的事件并广播一些东西时,我会在队列中看到它:定期工作,但是每次我启动 LARAVEL ECHO SERVER 并且客户端连接非常快,几秒钟后我开始在控制台中收到此错误:

[ioredis] Unhandled error event: Error: connect ETIMEDOUT
at Socket.<anonymous> (/usr/local/lib/node_modules/laravel-echo-server/node_modules/ioredis/built/redis/index.js:285:37)
at Object.onceWrapper (events.js:313:30)
at emitNone (events.js:106:13)
at Socket.emit (events.js:208:7)
at Socket._onTimeout (net.js:420:8)
at ontimeout (timers.js:482:11)
at tryOnTimeout (timers.js:317:5)
at Timer.listOnTimeout (timers.js:277:5)

我在这里检查了关于 stackoverflow、laracasts 的每一篇文章以及提到这个错误的所有地方,但我找不到解决方案。我的 .env 文件感兴趣的部分在这里:

APP_NAME=Testapp
APP_ENV=local
APP_KEY=[omitted]
APP_DEBUG=true
APP_URL=[omitted]
LOG_CHANNEL=stack
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=17306
DB_DATABASE=[omitted]
DB_USERNAME=[omitted]
DB_PASSWORD=[omitted]
BROADCAST_DRIVER=redis
CACHE_DRIVER=none
QUEUE_CONNECTION=redis
SESSION_DRIVER=database
SESSION_LIFETIME=1200
REDIS_HOST=127.0.0.1
REDIS_PASSWORD=null
REDIS_PORT=6379

这是广播.php

    'default' => env('BROADCAST_DRIVER', 'null'),

/*
|--------------------------------------------------------------------------
| Broadcast Connections
|--------------------------------------------------------------------------
|
| Here you may define all of the broadcast connections that will be used
| to broadcast events to other systems or over websockets. Samples of
| each available type of connection are provided inside this array.
|
*/

'connections' => [

    'pusher' => [
        'driver' => 'pusher',
        'key' => env('PUSHER_APP_KEY'),
        'secret' => env('PUSHER_APP_SECRET'),
        'app_id' => env('PUSHER_APP_ID'),
        'options' => [
            'cluster' => env('PUSHER_APP_CLUSTER'),
            'useTLS' => true,
        ],
    ],

    'redis' => [
        'driver' => 'redis',
        'connection' => 'default',
    ],

我的数据库.php

    'redis' => [

    'client' => env('REDIS_CLIENT', 'phpredis'),

    'options' => [
        'cluster' => env('REDIS_CLUSTER', 'redis'),
        'prefix' => env('REDIS_PREFIX', Str::slug(env('APP_NAME', 'laravel'), '_').'_database_'),
    ],

    'default' => [
        'url' => env('REDIS_URL'),
        'host' => env('REDIS_HOST', '127.0.0.1'),
        'password' => env('REDIS_PASSWORD', null),
        'port' => env('REDIS_PORT', '6379'),
        'database' => env('REDIS_DB', '0'),
    ],

    'cache' => [
        'url' => env('REDIS_URL'),
        'host' => env('REDIS_HOST', '127.0.0.1'),
        'password' => env('REDIS_PASSWORD', null),
        'port' => env('REDIS_PORT', '6379'),
        'database' => env('REDIS_CACHE_DB', '1'),
        'timeout' => 10000,
    ],

我的 laravel-echo-server.json

{
"authHost": "127.0.0.1",
"authEndpoint": "/broadcasting/auth",
"clients": [],
"database": "redis",
"databaseConfig": {
    "redis": {},
    "sqlite": {
        "databasePath": "/database/laravel-echo-server.sqlite"
    }
},
"devMode": true,
"host": null,
"port": "6001",
"protocol": "https",
"socketio": {},
"secureOptions": 67108864,
"sslCertPath": "/home/[myuser]/ssl.cert",
"sslKeyPath": "/home/[myuser]/ssl.key",
"sslCertChainPath": "",
"sslPassphrase": "",
"subscribers": {
    "http": true,
    "redis": true
},
"apiOriginAllow": {
    "allowCors": false,
    "allowOrigin": "",
    "allowMethods": "",
    "allowHeaders": ""
}

}

防火墙上的端口应该是打开的,我发现服务正在侦听它们的端口。

我真的不知道还能做什么,请如果有人可以帮助我,因为我老了,我想在退休前解决它:)

谢谢,

西蒙娜

更新

我确实在 unixsocket 上配置了 Redis 并避免了网络问题,现在运行良好。

4

0 回答 0