Я наконец окунаюсь в мир реакции сервера, используя Далее. js, однако я довольно озадачен этой проблемой.
Я звоню в API из pages/customer-preferences.tsx
, используя isomorphic-unfetch
CustomerPreferencesPage.getInitialProps = async () => {
const res = await fetch(API_URL + '/preference-customer');
const initialData = await res.json();
return { initialData };
};
Все отлично работает локально в режиме dev
или после сборки и запуска build
> start
. Чтобы разместить его, я запускаю его из docker контейнера node:10
, и когда я запускаю его локально, все тоже хорошо. Эта проблема возникает только после ее развертывания.
Когда я перехожу на /
и затем нажимаю ссылку на /customer-preferences
, все работает, как и ожидалось. Но если я обновлю sh страницу или загрузлю страницу непосредственно в /customer-preferences
, я вижу эту ошибку из Next. js
Так проблема возникает только при попытке сделать вызовы API с сервера, а не с клиента.
Я также настроил для использования простой сервер express, но не уверен, если это необходимо? !
const express = require('express');
const next = require('next');
const port = parseInt(process.env.PORT, 10) || 3000;
const dev = process.env.NODE_ENV !== 'production';
const app = next({ dev });
const handle = app.getRequestHandler();
app.prepare().then(() => {
const server = express();
server.all('*', (req, res) => {
return handle(req, res);
});
server.listen(port, err => {
if (err) throw err;
console.log(`> Ready on http://localhost:${port}`);
});
});
При проверке журналов сервера я получаю следующее:
FetchError: request to http://xxx failed, reason: getaddrinfo EAI_AGAIN xxx xxx:80
Любая помощь будет принята с благодарностью.