file_get_contents (): php_network_getaddresses: getaddrinfo не удалось: временный сбой в разрешении имен [дубликат]

Вопрос был:

Как вернуть ответ от асинхронного вызова?

blockquote>

, который может быть интерпретирован как:

Как сделать синхронный асинхронный код синхронным?

blockquote>

Решение будет состоять в том, чтобы избежать обратных вызовов и использовать комбинацию Promises и async / await.

Я хотел бы привести пример для запроса Ajax.

(Хотя он может быть записан в Javascript, я предпочитаю писать его на Python и компилировать его в Javascript, используя Transcrypt . Это будет достаточно ясно.)

Позволяет сначала включить использование JQuery, чтобы $ был доступен как S:

__pragma__ ('alias', 'S', '$')

Определить функцию, которая возвращает Promise, в этом случае вызов Ajax:

def read(url: str):
    deferred = S.Deferred()
    S.ajax({'type': "POST", 'url': url, 'data': { },
        'success': lambda d: deferred.resolve(d),
        'error': lambda e: deferred.reject(e)
    })
    return deferred.promise()

Использовать асинхронный код, как если бы он был синхронным:

async def readALot():
    try:
        result1 = await read("url_1")
        result2 = await read("url_2")
    except Exception:
        console.warn("Reading a lot failed")

8
задан Anorionil 30 April 2014 в 12:02
поделиться

3 ответа

В моем случае проблема заключалась в том, что Apache получает записи DNS из /etc/resolv.conf при запуске. К тому времени, как я начал свой Apache, сеть еще не была установлена. Перезапуск Apache (после настройки сети) решил проблему для меня.

Я объяснил это дело более подробно в своем сообщении в блоге http://diogomelo.net/blog/16/Warning-file_get_contents -php_network_getaddresses-getaddrinfo-неудавшийся No-адрес, связанный-с именем хостом

10
ответ дан Diogo Melo 5 September 2018 в 09:27
поделиться

Похоже, что поиск имени не работает во время работы cron. Я видел его только с именами в / etc / hosts, но я не тестировал DNS-имена.

Я видел его с отправкой сообщений по электронной почте и SMTP-соединениям.

I не знаю точной причины, но в моем случае я получил свой SMTP-код для подключения к 127.0.0.1 вместо localhost, и проблема исчезла.

1
ответ дан TheJosh 5 September 2018 в 09:27
поделиться

Это из-за ограничений соединения на 2-м сервере, и я считаю, что вы установили короткие интервалы времени для задания cron. Как вы знаете, серверы контролируют последовательные соединения с каждого IP-адреса. Вы можете выбрать более длительный интервал времени для решения этой проблемы.

0
ответ дан Trix 5 September 2018 в 09:27
поделиться
Другие вопросы по тегам:

Похожие вопросы: