从java应用程序查询德鲁伊

时间:2016-11-07 12:39:18

标签: druid

我是德鲁伊的新手。我想从我的java应用程序中查询远程德鲁伊集群。我在德鲁伊用户谷歌小组中读到我们可以使用io.druid.client.DirectDruidClient。有人可以帮助我或指出一个资源与一个例子吗?

5 个答案:

答案 0 :(得分:0)

在Druid中查询的本地方式是通过HTTP上的JSON。他们确实在https://github.com/implydata/druid-client有一个Java客户端,但它看起来不像是在积极开发中。 (撰写本文时的最后一次提交是在2年前。)因此它可能不支持本机JSON查询语言的所有功能。

如果您尝试从Java应用程序查询Druid,更好的方法是在Java中构建JSON查询,然后通过HTTP发送查询。

答案 1 :(得分:0)

好吧,如果您仍在使用Druid

签出Druidry

答案 2 :(得分:0)

这是一个简单的 Spring Boot Java应用程序,它使用 Avatica JDBC驱动程序查询 Druid 数据,并打印查询的第一行。 / p>

假设Druid在本地运行,并且您已经在表名“ druid_table ”中包含数据,该表的列为 sourceIP

  

FlinkDruidApplication.java

// main.cpp
#include "Header.h"

int main()
{
  std::unique_ptr<Base> t = std::make_unique<foo>(); // this one compiles and links and I would have expected it not to.

  //foo b; // this one does not compile as expected
  return 1;
}
  

pom.xml

@SpringBootApplication
public class FlinkDruidApplication {

    public static void main(String[] args) {
        SpringApplication.run(FlinkDruidApplication.class, args);
        Logger log = LoggerFactory.getLogger("FlinkDruidApplication");
        ExecutionEnvironment env = ExecutionEnvironment.getExecutionEnvironment();
        DataSet<Row> dbData =
                env.createInput(
                        JDBCInputFormat
                                .buildJDBCInputFormat()
                                .setDrivername("org.apache.calcite.avatica.remote.Driver")
                                .setDBUrl("jdbc:avatica:remote:url=http://localhost:8082/druid/v2/sql/avatica/")
                                .setUsername("null")
                                .setPassword("null")
                                .setQuery(
                                        "SELECT sourceIP FROM druid_table"
                                )
                                .setRowTypeInfo((RowTypeInfo) Types.ROW(Types.STRING))
                                .finish()
                );

        try {

            log.info("Printing first IP :: {} " + dbData.collect().iterator().next());
        } catch (Exception e) {
            log.error(e.getMessage());
        }


    }

}

答案 3 :(得分:0)

这里是设置和测试的另一个示例。

使用简单的Java程序进行DRUID-JDBC连接测试:

JdbcTest.java

import java.sql.*;
import java.util.Properties;

public class jdbcTest{    

public static void main(String args[]) {        

// Connect to /druid/v2/sql/avatica/ on your Broker.        

String url = "jdbc:avatica:remote:url=http://ec2-15-206-160-168.ap-south-1.compute.amazonaws.com:8082/druid/v2/sql/avatica/";        

Properties connectionProperties = new Properties();                
connectionProperties.setProperty("user", "vaibhav");                
connectionProperties.setProperty("password", "Qwe@2019");        
try (Connection connection = 
DriverManager.getConnection(url,connectionProperties)) {            
  try (                    
      final Statement statement = connection.createStatement();                    
      final ResultSet rs = statement.executeQuery("select count(*) from wikipedia");            
  )            
  {                

    while (rs.next()) {                    
      // Do something                    
      System.out.println("The Count Result is=" + rs.getString(1));                
    }
  }        
}      

catch (Exception e)        
  {            
    System.out.println(e.toString());        
  }    

 }

}

如何使用此程序:

1)使用上述内容创建一个名为jdbcTest.java的Java文件,替换所需的详细信息[HostName:PortNo,User,Password,DataSource Name]。

2)要编译:javac JdbcTest.java
例如。 $ javac JdbcTest.java

  1. 下载Avatica JDBC驱动程序

可以从以下隐式存储库下载驱动程序:https://static.imply.io/support/avatica-1.12.0.jar. 

将jar avatica jar复制到您的计算机中。

4)要执行:java -cp。:/ avatica-1.12.0.jar JdbcTest

例如: $ java-cp.:/Users/vaibhav/Downloads/avatica-1.12.0.jar JdbcTest SLF4J:无法加载类“ org.slf4j.impl.StaticLoggerBinder”。 SLF4J:默认为无操作(NOP)记录器实现 SLF4J:有关更多详细信息,请参见http://www.slf4j.org/codes.html#StaticLoggerBinder。 计数结果为= 24433

预期结果:成功完全执行应返回数据源的count(*)[在这种情况下,我的数据源是Wikipedia]如下: 计数结果是=

答案 4 :(得分:-1)

public static void Connect() {

        ExecutionEnvironment env = ExecutionEnvironment.getExecutionEnvironment();
        DataSet<Row> dbData =
                env.createInput(
                        JDBCInputFormat
                                .buildJDBCInputFormat()
                                .setDrivername("org.apache.calcite.avatica.remote.Driver")
                                .setDBUrl("jdbc:avatica:remote:url=http://hostname:8082/druid/v2/sql/avatica/")
                                .setUsername("null")
                                .setPassword("null")
                                .setQuery(
                                        "SELECT __time,account,empname FROM temp where  name ='abc'"
                                )
                                .setRowTypeInfo((RowTypeInfo) Types.ROW(Types.SQL_TIMESTAMP,Types.STRING, Types.STRING))
                                .finish()
                );

        try {
            ArrayList<Row> list = (ArrayList<Row>) dbData.collect();
            System.out.println("List Size: "+list.size());
            for(Row row : list) {
                java.sql.Timestamp time = (java.sql.Timestamp) row.getField(0);
                System.out.print("Time  :" + time);
                String account = (String) row.getField(1);
                System.out.print(" Account :" + account);
                String awsregion = (String) row.getField(2);
                System.out.println(" empname :" + empname);
            }

            //System.out.println("Account:" + dbData.collect().iterator().next());
        } catch (Exception e) {
            e.printStackTrace();

        }
}