[英]Intermittent error in PostGIS query via Rails (string interpolation failure?)
在部署我的 Rails 应用程序后出现间歇性错误。
此代码在 Sidekiq 中运行(5 个进程,每个进程有 10 个线程),它在 Docker 容器中运行。 我可以在任何时候让数以万计的这些工作排队。
path = Path.find(path_id)
nearby_nodes = Node.where("ST_DWITHIN(geog, ST_GeographyFromText(?), 25)", path.geog.to_s)
错误是:
ActiveRecord::StatementInvalid: PG::InternalError: ERROR: parse error - invalid geometry
HINT: "01" <-- parse error at position 2 within geometry
PG::InternalError: ERROR: parse error - invalid geometry
HINT: "01" <-- parse error at position 2 within geometry
如果我让所有 Sidekiq 进程安静下来,停止工作人员,稍等片刻,然后重新启动工作人员,我可以让这些工作成功运行。
我在部署过程中添加了一些延迟(如果重新启动工作人员可以解决问题,我猜测放慢速度可能会有所帮助),但这并没有帮助。
我通常每天可以成功部署一次。 在第一次部署之后,它更有可能陷入此故障 state 并且如果它进入此 state 之后的每次部署都会导致同样的问题。
Path.first.geog
返回: #<RGeo::Geographic::SphericalPointImpl:0x3ffd8b2a6688 "POINT (-72.633932 42.206081)">
Path.first.geog.class
返回: RGeo::Geographic::SphericalPointImpl
我已经尝试了许多不同格式的这个查询,这可能会揭示它是如何/为什么失败的(尽管我仍然对为什么它只是间歇性的感到困惑):
Node.where("ST_DWITHIN(geog, ST_GeographyFromText(?), 25)", path.geog)
失败,生成此查询:Node Load (1.0ms) SELECT "nodes".* FROM "nodes" WHERE (ST_DWITHIN(geog, ST_GeographyFromText('0020000001000010e6c05228925785f8d340451a60dcb9a9da'), 25)) LIMIT $1 [["LIMIT", 11]]
这个错误:
ActiveRecord::StatementInvalid (PG::InternalError: ERROR: parse error - invalid geometry)
HINT: "00" <-- parse error at position 2 within geometry
Node.where("ST_DWITHIN(geog, ST_GeographyFromText('#{path.geog}'), 25)")
成功,生成以下查询:Node Load (5.1ms) SELECT "nodes".* FROM "nodes" WHERE (ST_DWITHIN(geog, ST_GeographyFromText('POINT (-72.633932 42.206081)'), 25)) LIMIT $1 [["LIMIT", 11]]
Node.where("ST_DWITHIN(geog, ST_GeographyFromText(?), 25)", path.geog.to_s)
也成功,生成相同的查询:Node Load (2.3ms) SELECT "nodes".* FROM "nodes" WHERE (ST_DWITHIN(geog, ST_GeographyFromText('POINT (-72.633932 42.206081)'), 25)) LIMIT $1 [["LIMIT", 11]]
to_s
转换作为某种迷信测试也有效:geog_string = path.geog.to_s
nearby_nodes = Node.where("ST_DWITHIN(geog, ST_GeographyFromText(?), 25)", geog_string)
查询 2-4 通常可以工作,但有时表现得像查询 1 并且仅在 deploy 之后。 我无法让 2-4 表现得像 Rails 控制台中的第一个查询。 唯一一次查询 2-4 表现得像第一个查询是在部署后的 Sidekiq 作业中。 好像字符串转换有时不起作用。
以下是可能相关的 gem/版本的列表:
无需将地理转换为字符串,然后将其作为地理读回。
可以直接试试
Node.where("ST_DWITHIN(geog, ?, 25)", path.geog)
话虽如此,您可能确实有一些无效的几何图形
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.