无法在使用GenServer时运行init方法

时间:2017-12-29 07:00:55

标签: elixir mix

我是elixir的新手,最近发现GenServer是管理客户端/服务器API的好方法。所以我尝试创建一个GenServer模块来管理数据库连接但是失败了。以下是我的代码:

defmodule RedisClient do
  use GenServer
  require Logger

  # Client
  def start(url) do
    GenServer.start(__MODULE__, {url})
  end

  def init({url}) do
    Logger.info("connect to url #{url}");
    case Redix.start_link(url) do
        {:ok, conn} -> {conn}
        {:error, err} -> {:error, err}
    end
  end

end

模块RedisClient用于在其init()方法中连接到redis数据库。但它返回错误:

iex(tbc@192-168-1-7)15> RedisClient.start("redis://localhost")
{:error, {:bad_return_value, {#PID<0.6623.0>}}}
iex(tbc@192-168-1-7)16> 
17:58:20.592 [info]  connect to url redis://localhost

nil

我不明白为什么它会返回错误以及为什么它会在最后打印nil。如果我直接拨打Redis,它可以正常工作:

iex(tbc@192-168-1-7)17> Redix.start_link("redis://localhost")
{:ok, #PID<0.7443.0>}

似乎Redix上的API调用没有问题,那么我的GenServer实现有什么问题?

1 个答案:

答案 0 :(得分:3)

成功时,您需要从{:ok, state}返回init/1

{:ok, conn} -> {:ok, conn}

或者由于您确切地返回Redix.start_link返回的内容,您只需返回该内容:

def init({url}) do
  Logger.info("connect to url #{url}");
  Redix.start_link(url)
end