Socket.io 无法使用VMware Fusion连接远程访问
我使用通过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,当您部署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失
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有什么进展吗?请使用一些降价让这个问题更具可读性。把它分成两三段。请参阅以获取更多帮助。