首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在生产上启动laravel-echo服务器?

如何在生产上启动laravel-echo服务器?
EN

Stack Overflow用户
提问于 2021-04-20 12:34:33
回答 2查看 5.8K关注 0票数 2

我的刺。堆叠:

https://example.com

  1. Vue.js CLI

我已经在本地主机上使用laravel-echo服务器& socket.io创建了一个实时聊天。

但是,我想在我的生产服务器上运行它。为此,我使用了nginx。

问题是,当我运行laravel-echo-server start 时,它成功地启动了,但是当我从web浏览器访问我的站点时,它没有给出响应。(无用加入)

我已经重建了vue应用程序,清除了laravel缓存,并重新启动了nginx服务。

/etc/nginx/sites-enabled/default,我有:

代码语言:javascript
复制
server {
    server_name example.com www.example.com;

    root /var/www/html/Example/api/public/;    
    index index.html index.php;

    location / {
        root /var/www/html/Example/web/dist/;
        try_files $uri $uri/ /index.html;
    }

    location /socket.io/ {
        proxy_pass http://localhost:6001;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "Upgrade";
        proxy_set_header Host $host;
    }

    location /api {
        try_files $uri $uri/ /index.php$is_args$args;
    }

    location ~ \.php$ {
        include snippets/fastcgi-php.conf;
        fastcgi_pass unix:/run/php/php8.0-fpm.sock;
    }
}

连接到web套接字的main.js文件:

代码语言:javascript
复制
import Echo from "laravel-echo"
window.io = require('socket.io-client')

window.Echo = new Echo({
    broadcaster: 'socket.io',
    host: 'https://example.com/socket.io',
    auth: {
        headers: {
            'Authorization': `Bearer ${localStorage.getItem('token')}`
        }
    }
});

我的laravel-echo.server.json

代码语言:javascript
复制
{
    "authHost": "https://example.com/api",
    "authEndpoint": "/broadcasting/auth",
    "clients": [
        {
            appId: "xxxxx",
            key: "xxxxx"
        }
    ],
    "database": "redis",
    "databaseConfig": {
        "redis": {},
        "sqlite": {
            "databasePath": "/database/laravel-echo-server.sqlite"
        }
    },
    "devMode": false,
    "host": null,
    "port": "6001",
    "protocol": "http",
    "socketio": {},
    "secureOptions": 67108864,
    "sslCertPath": "",
    "sslKeyPath": "",
    "sslCertChainPath": "",
    "sslPassphrase": "",
    "subscribers": {
        "http": true,
        "redis": true
    },
    "apiOriginAllow": {
        "allowCors": true,
        "allowOrigin": "*",
        "allowMethods": "GET, POST",
        "allowHeaders": "Origin, Content-Type, X-Auth-Token, X-Requested-With, Accept, Authorization, X-CSRF-TOKEN, X-Socket-Id"
    }
}
EN

回答 2

Stack Overflow用户

发布于 2021-04-25 10:24:39

尝试将此host: 'https://example.com/socket.io'更改为host: 'https://example.com'

票数 0
EN

Stack Overflow用户

发布于 2022-05-07 05:22:19

我在laravel-echo配置中保留了带有普通https的站点,但是我删除了ssl规则,如证书等.我没有指向本地主机,而是指向主机ip,只更改端口:

代码语言:javascript
复制
{
    "authHost": "https://example.com/api",
    "authEndpoint": "/broadcasting/auth",
    "clients": [
        {
            appId: "xxxxx",
            key: "xxxxx"
        }
    ],
    "database": "redis",
    "databaseConfig": {
           "redis": {
                        "port": "6379",
                        "host": "127.0.0.1"
                },
        "sqlite": {
            "databasePath": "/database/laravel-echo-server.sqlite"
        }
    },
    "devMode": false,
    "host": 127.0.0.1,
    "port": "6001",
    "protocol": "http",
    "socketio": {},
    "secureOptions": 67108864,
    "sslCertPath": "",
    "sslKeyPath": "",
    "sslCertChainPath": "",
    "sslPassphrase": "",
    "subscribers": {
        "http": true,
        "redis": true
    },
    "apiOriginAllow": {
        "allowCors": true,
        "allowOrigin": "*",
        "allowMethods": "GET, POST",
        "allowHeaders": "Origin, Content-Type, X-Auth-Token, X-Requested-With, Accept, Authorization, X-CSRF-TOKEN, X-Socket-Id"
    }
}

加上ngnix:

代码语言:javascript
复制
        location /socket.io {
                proxy_pass http://127.0.0.1:6001;
                proxy_http_version 1.1;
                proxy_set_header Upgrade $http_upgrade;
                proxy_set_header Connection "Upgrade";
        }

在vue客户端:

代码语言:javascript
复制
    window.Echo = new Echo({
        broadcaster: 'socket.io',
        host: window.location.origin, // sem a porta
        auth: {
            headers: {
                Authorization: 'Bearer ' + bearerToken,
            }
        }
    });
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67179049

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档