gpt4 book ai didi

elixir - Phoenix 实时重新加载因编译错误而中断

转载 作者:行者123 更新时间:2023-12-02 02:09:11 24 4
gpt4 key购买 nike

偶尔,当我在 Elixir 代码中输入错误时,会出现 CompileError发生这种情况,即使我修复了所有问题,Phoenix 也拒绝实时重新加载,并继续打印 App.Endpoint.path/1 is undefined ( App 是我的应用程序)。当然,端点定义得非常好,并且一旦我重新启动就可以再次工作 mix phoenix.server .

据我所知,我使用的都是最新版本。由于我在网上找不到有关此错误的任何信息,因此我怀疑我配置了某些错误,并且非常感谢您就如何追查问题根源的建议。

[info] Sent 200 in 200ms
iex[debug] Live reload: web/resolver/reviewer.ex
[debug] Live reload: web/resolver/reviewer.ex
Compiling 20 files (.ex)

== Compilation error on file web/resolver/reviewer.ex ==
** (Ecto.Query.CompileError) unbound variable `f` in query
(ecto) expanding macro: Ecto.Query.preload/3
(app) web/resolver/reviewer.ex:519: App.Resolver.Reviewer.sc_data/1
(elixir) expanding macro: Kernel.|>/2
(app) web/resolver/reviewer.ex:520: App.Resolver.Reviewer.sc_data/1
(elixir) lib/kernel/parallel_compiler.ex:116: anonymous fn/4 in Kernel.ParallelCompiler.spawn_compilers/1

[error] #PID<0.2279.0> running App.Endpoint terminated
Server: localhost:4000 (http)
Request: GET /reviewers/2016/1234
** (exit) an exception was raised:
** (UndefinedFunctionError) function App.Endpoint.path/1 is undefined (module App.Endpoint is not available)
(app) App.Endpoint.path("/phoenix/live_reload/frame")
(phoenix_live_reload) lib/phoenix_live_reload/live_reloader.ex:115: Phoenix.LiveReloader.reload_assets_tag/1
(phoenix_live_reload) lib/phoenix_live_reload/live_reloader.ex:97: anonymous fn/1 in Phoenix.LiveReloader.before_send_inject_reloader/1
(elixir) lib/enum.ex:1623: Enum."-reduce/3-lists^foldl/2-0-"/3
(plug) lib/plug/conn.ex:909: Plug.Conn.run_before_send/2
(plug) lib/plug/conn.ex:355: Plug.Conn.send_resp/1
(phoenix) lib/phoenix/code_reloader.ex:50: Phoenix.CodeReloader.call/2
(app) lib/app/endpoint.ex:1: App.Endpoint.phoenix_pipeline/1
(app) lib/plug/debugger.ex:93: App.Endpoint."call (overridable 3)"/2
(app) lib/app/endpoint.ex:1: App.Endpoint.call/2
(plug) lib/plug/adapters/cowboy/handler.ex:15: Plug.Adapters.Cowboy.Handler.upgrade/4
(cowboy) src/cowboy_protocol.erl:442: :cowboy_protocol.execute/4
[error] Ranch protocol #PID<0.2281.0> (:cowboy_protocol) of listener App.Endpoint.HTTP terminated
** (exit) killed
Compiling 20 files (.ex)

== Compilation error on file web/resolver/reviewer.ex ==
** (Ecto.Query.CompileError) unbound variable `f` in query
(ecto) expanding macro: Ecto.Query.preload/3
(app) web/resolver/reviewer.ex:519: App.Resolver.Reviewer.sc_data/1
(elixir) expanding macro: Kernel.|>/2
(app) web/resolver/reviewer.ex:520: App.Resolver.Reviewer.sc_data/1
(elixir) lib/kernel/parallel_compiler.ex:116: anonymous fn/4 in Kernel.ParallelCompiler.spawn_compilers/1

^C
BREAK: (a)bort (c)ontinue (p)roc info (i)nfo (l)oaded
(v)ersion (k)ill (D)b-tables (d)istribution

最佳答案

看来 Phoenix 的实时重新加载功能是 Endpoint 的一部分,因此一旦后者崩溃,代码重新加载就不再起作用。

通过在属于端点的代码中插入错误,例如,可能会导致端点崩溃。通过添加 plug :some_imaginary_plug 或在 router.ex 中引起语法错误,因为路由器也插入了 Endpoint。

现在,事实证明我正在使用 Absinthe通过forward将所有/graphql请求直接打包到苦艾酒插件。因此,任何 GraphQL 类型定义和相关的解析器函数(恰好构成了我的应用程序的大部分)都是脆弱的:任何不明显的编译错误(但不可避免) )导致端点崩溃。

我发现的最佳解决方法是使用 iex -S mix phoenix.server 启动服务器,直到 Absinthe 开发人员设法使解析器独立于类型定义(他们建议这样做) code>,并在端点崩溃时手动运行重新编译。虽然这并不能解决 CodeReloader 作为 Endpoint 的一部分的根本问题,反之亦然,但它使我不必每次都重新运行 webpack,这是最大的痛点。

关于elixir - Phoenix 实时重新加载因编译错误而中断,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38709444/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com