2

mix fetch.btc在凤凰应用程序(lib/mix/tasks/fetch.btc.ex)上有混合任务:

defmodule Mix.Tasks.Fetch.Btc do
  use Mix.Task

  def run(_args) do
    res = HTTPoison.get!("https://blockchain.info/ticker")
    IO.inspect(res)
  end
end

当我运行时mix fetch.btc出现错误:

** (ArgumentError) argument error
    (stdlib) :ets.lookup_element(:hackney_config, :mod_metrics, 2)
    PROJ_DIR/deps/hackney/src/hackney_metrics.erl:27: :hackney_metrics.get_engine/0
    PROJ_DIR/deps/hackney/src/hackney_connect.erl:78: :hackney_connect.create_connection/5
    PROJ_DIR/deps/hackney/src/hackney_connect.erl:47: :hackney_connect.connect/5
    PROJ_DIR/deps/hackney/src/hackney.erl:330: :hackney.request/5
    lib/httpoison/base.ex:787: HTTPoison.Base.request/6
    lib/httpoison.ex:128: HTTPoison.request!/5
    lib/mix/tasks/fetch.btc.ex:14: Mix.Tasks.Fetch.Btc.run/1
    (mix) lib/mix/task.ex:331: Mix.Task.run_task/3
    (mix) lib/mix/cli.ex:79: Mix.CLI.run_task/2
    (elixir) lib/code.ex:767: Code.require_file/2

但在我的控制器中,这段代码res = HTTPoison.get!("https://blockchain.info/ticker")是成功的!

信息:

hackney: 1.15.1
httpoison: 1.5.0
phoenix: 1.4.3
  1. 我究竟做错了什么?
  2. 在混合任务中发出http请求的正确方法是什么?
4

2 回答 2

4

应用程序及其所有依赖项已经启动时,控制器中的代码就会运行。mix任务在:mix应用程序中运行,显然默认情况下不会启动:hackney

您只需要确保它已手动启动/启动:

def run(_args) do
  # ⇓⇓⇓⇓⇓⇓⇓ THIS ⇓⇓⇓⇓⇓⇓⇓
  Application.ensure_all_started(:hackney)
  # ⇑⇑⇑⇑⇑⇑⇑ THIS ⇑⇑⇑⇑⇑⇑⇑

  res = HTTPoison.get!("https://blockchain.info/ticker")
  IO.inspect(res)
end
于 2019-05-02T06:24:24.123 回答
1

您也可以HTTPoison.start()在实际调用之前使用。如果您不想每次都在混合文件中启动 hackney 应用程序,或者您不想开始使用 Application.

于 2019-05-02T06:42:53.010 回答