Запустите сервер узла (сокет.io) на Vagrant и получить доступ к ним из браузера

#node.js #angular #laravel #socket.io #vagrant

#node.js #angular #laravel #socket.io #vagrant

Вопрос:

Я использую Laravel для серверной части в своем проекте, а для целей чата я использую Redis. На моем компьютере у меня Windows, и в связи с этим я запускаю приложение Laravel / Redis на Vagrant. Также я настраиваю сервер узла для сокета.ввод-вывод на Vagrant, и связь между приложением Laravel / Redis и этим сервером работает нормально.

Проблема на стороне клиента, где я использую Angular, я не могу подключить клиентскую часть к сокету.сервер ввода-вывода работает на Vagrant, я не знаю, какой адрес использовать для подписки на стороне клиента.

Это мой сервер узла:

 var express = require('express');
var app = express();
var http = require('http').Server(app);
var redis = require('redis');
var client = redis.createClient("redis://127.0.0.1:6379");

var io = require('socket.io')(http);

app.use('/', express.static('www'));

http.listen(3000, '192.168.10.10', function(){
    console.log('listening on *:3000');
});

client.on('message', function(chan, msg) {
    console.log(chan);
    console.log(msg);
    io.sockets.emit(chan, msg);
});

client.subscribe('add-message');
 

На стороне клиента:

 const config: SocketIoConfig = { url: 'http://192.168.10.10:3000', options: {} };
 

Но когда я запускаю приложение, я получаю сообщение об ошибке, что приложение не может подписаться на сервер.

Кто-нибудь знает, как я могу получить доступ к серверу узлов, запущенному на Vagrant, из браузера или какого-либо другого IP-адреса в моей частной сети?

Заранее спасибо

РЕДАКТИРОВАТЬ: это файл Vagrant

 # -*- mode: ruby -*-
# vi: set ft=ruby :

require 'json'
require 'yaml'

VAGRANTFILE_API_VERSION ||= "2"
confDir = $confDir ||= File.expand_path(File.dirname(__FILE__))

homesteadYamlPath = confDir   "/Homestead.yaml"
homesteadJsonPath = confDir   "/Homestead.json"
afterScriptPath = confDir   "/after.sh"
aliasesPath = confDir   "/aliases"

require File.expand_path(File.dirname(__FILE__)   '/scripts/homestead.rb')

Vagrant.require_version '>= 2.1.0'

Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
    if File.exist? aliasesPath then
        config.vm.provision "file", source: aliasesPath, destination: "/tmp/bash_aliases"
        config.vm.provision "shell" do |s|
            s.inline = "awk '{ sub("r$", ""); print }' /tmp/bash_aliases > /home/vagrant/.bash_aliases"
        end
    end

    if File.exist? homesteadYamlPath then
        settings = YAML::load(File.read(homesteadYamlPath))
    elsif File.exist? homesteadJsonPath then
        settings = JSON::parse(File.read(homesteadJsonPath))
    else
        abort "Homestead settings file not found in #{confDir}"
    end

    Homestead.configure(config, settings)

    if File.exist? afterScriptPath then
        config.vm.provision "shell", path: afterScriptPath, privileged: false, keep_color: true
    end

    if Vagrant.has_plugin?('vagrant-hostsupdater')
        config.hostsupdater.aliases = settings['sites'].map { |site| site['map'] }
    elsif Vagrant.has_plugin?('vagrant-hostmanager')
        config.hostmanager.enabled = true
        config.hostmanager.manage_host = true
        config.hostmanager.aliases = settings['sites'].map { |site| site['map'] }
    end
end
 

Комментарии:

1. Работает ли клиентское приложение в Windows или в окне Vagrant?

2. клиентское приложение, работающее в Windows, в этом проблема, и оно должно работать снаружи от Vagrant

3. Можете ли вы поделиться некоторыми из ваших конфигураций vagrant? Возможно, сеть неверна для просмотра с хост-компьютера (возможно, потребуется перенаправить порты или переключиться на общедоступную сеть).

4. Я делюсь файлом Vagrant в редактировании вопроса

5. Добавить между этим блоком: Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|