Socket.io 无法使用VMware Fusion连接远程访问

Socket.io 无法使用VMware Fusion连接远程访问,socket.io,feathersjs,Socket.io,Feathersjs,我使用通过socketio连接的feathers chat vuex客户端构建了feathers chat演示程序,但是我在通过socketio进行远程访问时遇到了问题。只要我从同一系统上的浏览器访问客户机,演示就可以正常工作,该系统恰好是在MacBookPro上的VMware Fusion下运行的Ubuntu VM。但是,如果我尝试从主机MacOS中的浏览器连接到客户端,它会打开登录页面,但无法登录。在devtools控制台中,它会显示“WebSocket连接到…localhost:3030失

我使用通过socketio连接的feathers chat vuex客户端构建了feathers chat演示程序,但是我在通过socketio进行远程访问时遇到了问题。只要我从同一系统上的浏览器访问客户机,演示就可以正常工作,该系统恰好是在MacBookPro上的VMware Fusion下运行的Ubuntu VM。但是,如果我尝试从主机MacOS中的浏览器连接到客户端,它会打开登录页面,但无法登录。在devtools控制台中,它会显示“WebSocket连接到…localhost:3030失败”,当然是这样,因为feathers聊天服务器没有在本地主机上运行,而是在VM中运行。socketio在feathers-client.js中的设置如下:“const socket=io(“”,{transports:['websocket']})”。如果我在其中硬编码VM IP地址,如下所示:“const socket=io(“”,{transports:['websocket']})”,那么远程访问工作正常。但我当然不能这样做,因为一般来说,我在运行时不知道服务器的IP地址。有人能告诉我正确的设置方法吗?谢谢

我还没有在羽毛上使用socketio,但我已经在rest feathers应用程序上处理过这个问题(所以希望这适用!)

将IP地址放入配置文件中。当您最终部署应用程序时,无论如何,您都会将其指向生产服务器的IP地址,因此可以对其进行配置

然后,对于本地开发人员来说,它可以是虚拟机的IP,当您部署
config/production.json
时,它可以拥有实时IP

以下是有关使用配置变量的文档:

更新 如果在本地开发中使用Docker而不是VMWare,则可以使用Docker compose并使用内置的网络功能。下面是我正在开发的docker compose file for feathers应用程序的一个示例。这只是一个API,所以我不会和客户打交道,但我认为这应该是一个很好的起点

安装docker后,将这两个文件放入项目根目录中,然后运行
docker compose up-d
。它公开了feathers服务器上的端口3030,您应该能够连接
http://localhost:3030
再次从您的主机启动。如果要将另一个docker容器添加到docker compose,则可以从该容器访问服务器,网址为
http://server:3030
,因为它将使用内部docker网络

docker-compose.yml:

version: "3"
services:
  server:
    build: .
    volumes:
      - .:/usr/src/app
    ports:
      - "3030:3030"
    stdin_open: true
    tty: true
  mongo:
    image: mongo
    volumes:
      - ./protected_db/howlround-mongodb:/data/db
    command:
      - --storageEngine=mmapv1
还有我的Dockerfile:

FROM ubuntu:16.04

# Dockerfile based on https://github.com/nodejs/docker-node/blob/master/6.4/slim/Dockerfile

# gpg keys listed at https://github.com/nodejs/node
RUN set -ex \
  && for key in \
    9554F04D7259F04124DE6B476D5A82AC7E37093B \
    94AE36675C464D64BAFA68DD7434390BDBE9B9C5 \
    0034A06D9D9B0064CE8ADF6BF1747F4AD2306D93 \
    FD3A5288F042B6850C66B31F09FE44734EB7990E \
    71DCFD284A79C3B38668286BC97EC7A07EDE3FC1 \
    DD8F2338BAE7501E3DD5AC78C273792F7D83545D \
    B9AE9905FFD7803F25714661B63B535A4C206CA9 \
    C4F0DFFF4E8C1A8236409D08E73BC641CC11F4C8 \
  ; do \
    gpg --keyserver ha.pool.sks-keyservers.net --recv-keys "$key"; \
  done

ENV NPM_CONFIG_LOGLEVEL info
ENV NODE_VERSION 8.11.1
ENV NODE_ENV dev

RUN buildDeps='xz-utils curl ca-certificates' \
    && set -x \
    && apt-get update && apt-get install -y $buildDeps --no-install-recommends \
    && rm -rf /var/lib/apt/lists/* \
    && curl -SLO "https://nodejs.org/dist/v$NODE_VERSION/node-v$NODE_VERSION-linux-x64.tar.xz" \
    && curl -SLO "https://nodejs.org/dist/v$NODE_VERSION/SHASUMS256.txt.asc" \
    && gpg --batch --decrypt --output SHASUMS256.txt SHASUMS256.txt.asc \
    && grep " node-v$NODE_VERSION-linux-x64.tar.xz\$" SHASUMS256.txt | sha256sum -c - \
    && tar -xJf "node-v$NODE_VERSION-linux-x64.tar.xz" -C /usr/local --strip-components=1 \
    && rm "node-v$NODE_VERSION-linux-x64.tar.xz" SHASUMS256.txt.asc SHASUMS256.txt \
    && apt-get purge -y --auto-remove $buildDeps

# Install yarn and feathers-cli
RUN npm install -g yarn @feathersjs/cli pm2@latest

# Install Git
RUN add-apt-repository -y ppa:git-core/ppa;\
  apt-get update;\
  apt-get -y install git

# Create app directory
RUN mkdir -p /usr/src/app

WORKDIR /usr/src/app
RUN cd /usr/src/app

# Install app dependencies
RUN yarn install

EXPOSE 3030
CMD [ "node" ]

问题是,我正在开发一个嵌入式应用程序,它将部署在许多盒子上,可能是在docker中。我不清楚如何将特定框的ip地址输入到feather配置中。如果你打算使用docker,那就更好了。我建议切换到docker进行本地开发,它在容器之间具有网络功能,可能对您有用。“我的羽毛”开发设置使用
docker compose
。然后,您可以使用容器名称从同一docker网络上的另一个容器访问一个容器。因此,如果您的服务器名为
server
,那么您可以连接到
http://server:3030
。我用feathers+docker本地开发设置更新了答案,以防对您的情况有所帮助。我认为Docker在本地开发方面优于VMWare,特别是因为您最终正在考虑使用Docker进行部署。@Lannie有什么进展吗?请使用一些降价让这个问题更具可读性。把它分成两三段。请参阅以获取更多帮助。