feather-chat远程访问无法使用VMware Fusion进行连接

时间:2018-05-26 23:39:16

标签: socket.io feathersjs

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

1 个答案:

答案 0 :(得分:0)

我没有使用羽毛上的袜子,但我已经在休息羽毛应用程序上处理了这个问题(所以希望这适用!)。

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

然后,对于本地开发者,它可以是VM的IP,当您部署config/production.json时,可以拥有实时IP。

以下是有关使用配置变量的文档: https://docs.feathersjs.com/api/configuration.html#example

<强>更新 如果您使用Docker而不是VMWare进行本地开发,那么您可以使用docker-compose并使用内置网络功能。这是我正在研究的羽毛应用程序的docker-compose文件的示例。它只是一个API,所以我不是在与客户打交道,但我认为它应该是一个很好的起点。

安装docker后,将这两个文件放在项目根目录中,然后运行docker-compose up -d。它暴露羽毛服务器上的端口3030,您应该能够从主机再次与http://localhost:3030连接。如果你想添加另一个docker容器到docker-compose,你可以从那个容器中访问http://server:3030的服务器,因为它将使用内部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" ]