我在嵌入式模式下运行Apache钻取程序。
当我向localhost:8047/query.json发送POST请求时,它会产生400个错误:
Cannot construct instance of `org.apache.drill.exec.server.rest.QueryWrapper`, problem: null
at [Source: (org.glassfish.jersey.message.internal.EntityInputStream); line: 4, column: 1]请求:
{
"QueryType": "SQL",
"Query": "SELECT count(*) as `cnt` FROM dfs.`/data/demo/Parquet/*.parquet`"
}
Content-Type: application/json在分布式模式下运行时,也会发生这种情况。通过网络界面运行查询似乎没问题.
根据google的说法,我是唯一一个有这个错误的人。有什么想法吗?
发布于 2019-03-12 10:27:19
请求中有一个愚蠢的错误。请求中的字段必须位于camelCase中,而不是QueryType,而是queryType。由于序列化程序设置错误,以前的请求中有大写Q。
我有一个小时没有注意到这个细节。
这样做是可行的:
{
"queryType": "SQL",
"query": "SELECT count(*) as `cnt` FROM dfs.`/data/demo/Parquet/*.parquet`"
}如果API返回一个正常的错误,比如"queryType是缺少的“,而不是神秘的Cannot construct instance of org.apache.drill.exec.server.rest.QueryWrapper,那就太好了。
希望这能为一个人节省一小时的生命。
https://stackoverflow.com/questions/55119223
复制相似问题