在Lua中编写PowerDNS后端

我无论如何也无法使它工作。脚本会正确响应,PowerDNS也会将其视为正常工作,但然后进程永远无法超越其就绪状态的确认。

PowerDNS服务器陷入read(),而端口53上的所有网络连接完全被忽略。服务器启动了一个pdns_server进程以及脚本本身,但什么也没有发生。级别9的记录根本没有用处:什么也没发生。类似于“pdns监视器”情况,只不过可以看到脚本的stderr输出。

我已经将脚本放在了这里。这太令人沮丧了...我错过了什么东西吗?这是因为io.lines()的调用吗?这是因为输入被缓冲了吗?

更新:我正在使用文档创建这个。我还看过其他语言(我会一些)-例如v6rev(虽然我不懂Python)和这个例子的Java后端。

更新2 我最好也提一下,这也与gmysql后端组合使用呢;PowerDNS确实允许多个后端,尽管我不知道具体情况。我已经在配置文件中更改了后端的顺序,但之后没有看到任何更改。此外,MySQL查询确实起作用。没有pipe后端,MySQL后端可以很好地处理东西。

原文链接 https://stackoverflow.com/questions/6499460

点赞
stackoverflow用户82775
stackoverflow用户82775

没有人给出任何提示,所以...这就是我发现的。它确实与缓冲有关-或者至少看起来是这样的。原始代码中有类似于这样的行:

print("OK\tPowerDNS backend ok")

这些行就是问题所在;用这个序列替换它们有效:

print("OK\tPowerDNS backend ok")
io.flush()

然而-用以下序列替换它们却无效

io.write("OK\tPowerDNS backend ok")
io.flush()

这可能是由于print()io.write()之间的一些差异导致的。寻找有关Lua无缓冲I/O的详细信息什么也没找到。可能我应该使用io.stdout.write()代替io.write()

偶然间,我发现了Lua-Users 邮件列表上的这篇文章,其中提到了setvbuf函数。但是,setvbuf函数似乎是从Lua 5.1开始新引入的,因此在Lua 5.0中不可用。

2011-06-28 16:39:45