我的服务器今天抛出了这个,这是一个我以前从未见过的Node.js错误:

Error: getaddrinfo EAI_AGAIN my-store.myshopify.com:443
    at Object.exports._errnoException (util.js:870:11)
    at errnoException (dns.js:32:15)
    at GetAddrInfoReqWrap.onlookup [as oncomplete] (dns.js:78:26)

我想知道这是否与今天影响Shopify和许多其他服务的DynDns DDOS攻击有关。这里有一篇关于这个的文章。

我的主要问题是dns.js做什么?它属于节点的哪一部分?如何在不同的域上重新创建此错误?


当前回答

我得到这个错误后,我最近添加了一个新的网络到我的docker-compose文件。

我最初有这些服务:

services:
  frontend:
    depends_on:
      - backend
    ports:
      - 3005:3000
  
  backend:
    ports:
      - 8005:8000

我决定添加一个新的网络,它承载着我想让我的前端服务能够访问的其他服务,所以我这样做了:

networks:
  moar:
    name: moar-network
    attachable: true

services:
  frontend:
    networks:
      - moar
    depends_on:
      - backend
    ports:
      - 3005:3000
  
  backend:
    ports:
      - 8005:8000

不幸的是,上述情况导致我的前端服务在默认网络上不再可见,而只在moar网络中可见。这意味着前端服务不能再代理请求到后端,因此我得到如下错误:

试图代理到:localhost:3005/graphql/时发生错误

解决方案是将默认网络添加到前端服务的网络列表中,如下所示:

networks:
  moar:
    name: moar-network
    attachable: true

services:
  frontend:
    networks:
      - moar
      - default # here
    depends_on:
      - backend
    ports:
      - 3005:3000
  
  backend:
    ports:
      - 8005:8000

现在我们好了!


最后一件事,如果您想查看在给定网络中运行的服务,可以使用docker network inspect <network_name>命令。这帮助我发现前端服务不再是默认网络的一部分。

其他回答

启用了火焰,它仍然不工作?

很可能你需要从正确的路径来设置.env, require('dotenv')。配置({路径:__dirname + './../.)env '});不会起作用(或任何其他路径)。只需将.env文件放在函数目录中,从该目录部署到Firebase。

EAI_AGAIN是一个DNS查找超时错误,意味着它是一个网络连接错误或代理相关的错误。

我的主要问题是dns.js做什么?

dns.js用于节点获取域的ip地址(简而言之)。

更多信息: http://www.codingdefined.com/2015/06/nodejs-error-errno-eaiagain.html

在我的情况下,问题是docker网络的ip分配范围,详见这篇文章

我在使用AWS和无服务器时也遇到了同样的问题。我尝试了eu-central-1区域,但它不起作用,所以我不得不将其更改为us-east-2。

@xerq指向正确,这里有更多的参考 http://www.codingdefined.com/2015/06/nodejs-error-errno-eaiagain.html

我得到了同样的错误,我通过更新“hosts”文件在Windows操作系统的这个位置下解决了这个问题

C:\Windows\System32\drivers\etc

希望能有所帮助!!