Не удается подключиться к удаленному доступу с помощью VMware Fusion. - PullRequest
0 голосов
/ 27 мая 2018

Я создал демо-версию перья в чате с помощью клиента перьев-чата-vuex, подключенного через socketio, но у меня возникают проблемы с удаленным доступом через socketio.Демонстрация работает нормально, пока я обращаюсь к клиенту из браузера в той же системе, которая оказывается виртуальной машиной Ubuntu, работающей под управлением VMware Fusion на Macbook Pro.Но если я пытаюсь подключиться к клиенту из браузера на хосте MacOS, он открывает страницу входа в систему, но не может войти в систему. В консоли devtools появляется сообщение «Соединение WebSocket с ... localhost: 3030 fail»что, конечно, так и произошло, потому что сервер пернатого чата не работает на этом локальном хосте, он работает в виртуальной машине.Socketio настроено в пером-client.js следующим образом: "const socket = io ('http://localhost:3030', {transports: [' websocket ']})".Если я жестко закодирую IP-адрес виртуальной машины следующим образом: «const socket = io ('http://172.16.184.194:3030', {transports: [' websocket ']})», то удаленный доступ работает нормально.Но, конечно, я не могу этого сделать, потому что в общем случае я не знаю IP-адрес сервера во время выполнения.Так может кто-нибудь сказать мне правильный способ настроить это?Спасибо!

1 Ответ

0 голосов
/ 27 мая 2018

Я не работал с socketio для перьев, но я имел дело с этим в приложении с остальными перьями (так что, надеюсь, это применимо!).

Вставьте IP-адрес в файл конфигурации.Когда вы в конечном итоге развернете приложение, вы все равно будете указывать его на IP-адрес рабочего сервера, поэтому имеет смысл настроить его.

Тогда для локального разработчика это может быть IP-адрес виртуальной машины, а при развертывании ваш config/production.json может иметь действующий IP-адрес.

Вот документы об использовании переменных конфигурации: https://docs.feathersjs.com/api/configuration.html#example

Обновление Если вы используете Docker вместо VMWare для локальной разработки, вы можете использовать docker-compose и использовать встроенные сетевые функции.Вот пример файла docker-compose для приложения перьев, над которым я работаю.Это просто API, поэтому я не имею дело с клиентом, но я думаю, что это должно быть хорошей отправной точкой для вас.

С установленным докером поместите эти два файла в корневой каталог вашего проекта и затем запустите docker-compose up -d,Он предоставляет порт 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" ]
...