Java를 사용하여 Apache Druid 기반 실시간 분석 및 쿼리 애플리케이션을 개발하는 방법
Java를 사용하여 Apache Druid 기반 실시간 분석 및 쿼리 애플리케이션을 개발하는 방법
소개:
Apache Druid는 오픈 소스 실시간 데이터 처리 및 쿼리 엔진으로 고성능, 확장성과 안정성이 뛰어나 실시간 분석 및 쿼리 애플리케이션 구축에 적합합니다. 이 기사에서는 Java 언어를 사용하여 Apache Druid 기반의 실시간 분석 및 쿼리 애플리케이션을 개발하는 방법을 소개하고 구체적인 코드 예제를 제공합니다.
1. Apache Druid 환경 설정
먼저 Apache Druid 환경을 설정해야 합니다. 구체적인 단계는 다음과 같습니다.
- Apache Druid 설치 패키지를 다운로드하고 압축을 풉니다.
- JAVA_HOME 및 DRUID_HOME을 포함한 Druid의 환경 변수를 구성합니다.
- 주키퍼 서비스를 시작하세요.
- 브로커, 코디네이터, 오버로드 및 히스토리컬 노드를 포함한 드루이드 서비스를 시작하세요.
2. Druid 데이터 소스 생성
다음으로 Druid 데이터 소스를 생성하고 해당 데이터를 Druid로 가져와야 합니다. 구체적인 단계는 다음과 같습니다.
- 타임스탬프, 차원 및 측정값 필드와 같은 필수 필드가 포함된 데이터 소스를 만듭니다.
- Java 코드를 사용하여 Druid의 Coordinator 노드에 연결하고 데이터 소스를 생성합니다.
- Java 코드를 사용하여 Druid의 데이터 소스로 데이터를 가져옵니다. 구체적인 코드 예시는 다음과 같습니다.
DruidDataSource dataSource = new DruidDataSource(); dataSource.setUrl("jdbc:mysql://localhost:3306/mydb"); dataSource.setUsername("root"); dataSource.setPassword("password"); String jsonPath = "path/to/data.json"; String dataSourceName = "myDataSource"; File jsonFile = new File(jsonPath); InputStream inputStream = new FileInputStream(jsonFile); InputStreamReader reader = new InputStreamReader(inputStream); String data = IOUtils.toString(reader); String jsonPayload = String.format(data, dataSourceName); HttpURLConnection connection = (HttpURLConnection) new URL("http://localhost:8081/druid/coordinator/v1/metadata/datasources").openConnection(); connection.setRequestMethod("POST"); connection.setDoOutput(true); OutputStream outputStream = connection.getOutputStream(); outputStream.write(jsonPayload.getBytes()); outputStream.close(); int responseCode = connection.getResponseCode(); if (responseCode == 200) { System.out.println("Data source created successfully."); }
3. Druid 쿼리 코드 작성
데이터 소스가 성공적으로 생성되고 데이터를 가져오면 Druid 쿼리 코드를 작성할 수 있습니다. 구체적인 단계는 다음과 같습니다:
- Java 코드를 사용하여 Druid의 Broker 노드에 연결합니다.
- Druid 쿼리 요청을 구성하여 Druid 클러스터로 보냅니다. 구체적인 코드 예시는 다음과 같습니다.
DruidQueryRequest queryRequest = new DruidQueryRequest(); queryRequest.setDataSource("myDataSource"); queryRequest.setGranularity("hour"); queryRequest.setIntervals("2022-01-01T00:00:00Z/2022-01-02T00:00:00Z"); DruidAggregation aggregation = new DruidAggregation(); aggregation.setType("longSum"); aggregation.setName("totalClicks"); aggregation.setFieldName("clicks"); queryRequest.setAggregations(Collections.singletonList(aggregation)); URL url = new URL("http://localhost:8082/druid/v2"); HttpURLConnection connection = (HttpURLConnection) url.openConnection(); connection.setRequestMethod("POST"); connection.setDoOutput(true); Gson gson = new Gson(); String jsonPayload = gson.toJson(queryRequest); OutputStream outputStream = connection.getOutputStream(); outputStream.write(jsonPayload.getBytes()); outputStream.close(); int responseCode = connection.getResponseCode(); if (responseCode == 200) { InputStream inputStream = connection.getInputStream(); InputStreamReader reader = new InputStreamReader(inputStream); String result = IOUtils.toString(reader); System.out.println(result); }
4. 쿼리 결과 표시
마지막으로 쿼리 결과를 표시하거나 처리해야 합니다. 구체적인 코드 예시는 다음과 같습니다.
JsonParser parser = new JsonParser(); JsonObject jsonObject = parser.parse(result).getAsJsonObject(); JsonArray events = jsonObject.getAsJsonArray("events"); for (JsonElement event : events) { JsonObject eventObject = event.getAsJsonObject(); String timestamp = eventObject.get("__time").getAsString(); long clicks = eventObject.get("totalClicks").getAsLong(); System.out.println("Timestamp: " + timestamp); System.out.println("Total Clicks: " + clicks); }
결론:
이 글에서는 Druid 환경 설정, Druid 데이터 소스 생성, 작성 등 Java 언어를 사용하여 Apache Druid 기반 실시간 분석 및 쿼리 애플리케이션을 개발하는 방법을 소개합니다. Druid 쿼리 코드 및 쿼리 결과 표시. 이러한 단계를 통해 강력한 실시간 분석 및 쿼리 애플리케이션을 쉽게 구축하여 데이터 분석 및 의사 결정을 신속하게 수행할 수 있습니다.
참고 자료:
- Apache Druid 공식 문서: https://druid.apache.org/
- GitHub의 Druid 샘플 코드: https://github.com/apache/druid/tree/master/examples/quickstart
위 내용은 Java를 사용하여 Apache Druid 기반 실시간 분석 및 쿼리 애플리케이션을 개발하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

Java는 플랫폼 별 문제를 어떻게 완화합니까? Java는 JVM 및 표준 라이브러리를 통해 플랫폼 독립성을 구현합니다. 1) Bytecode 및 JVM을 사용하여 운영 체제 차이를 추상화합니다. 2) 표준 라이브러리는 Paths 클래스 처리 파일 경로 및 Charset 클래스 처리 문자 인코딩과 같은 크로스 플랫폼 API를 제공합니다. 3) 최적화 및 디버깅을 위해 실제 프로젝트에서 구성 파일 및 다중 플랫폼 테스트를 사용하십시오.

java'splatformincendenceenhancesmicroservicesarchitectureDeploymentFlexibility, 일관성, 확장 성 및 포트 가능성

Graalvm은 Java의 플랫폼 독립성을 세 가지 방식으로 향상시킵니다. 1. 교차 언어 상호 운용성, Java는 다른 언어와 원활하게 상호 작용할 수 있습니다. 2. 독립적 인 런타임 환경, Java 프로그램을 GraalvMnativeImage를 통해 로컬 실행 파일로 컴파일합니다. 3. 성능 최적화, Graal Compiler는 Java 프로그램의 성능과 일관성을 향상시키기 위해 효율적인 기계 코드를 생성합니다.

ToEffectIallyTestJavaApplicationSforplatformcompatibility, followthesesteps : 1) setupAutomatedTestingAcrossMultiplePlatflatformsUsingCitools likeJenkinsorgitHubactions.2) 행동 관리자는 realHardwaretoCathissesnotfoundInvironmentments.3) Checkcross-Pla

Java Compiler는 소스 코드를 플랫폼 독립적 인 바이트 코드로 변환하여 Java의 플랫폼 독립성을 실현하여 JVM이 설치된 JVM 프로그램에서 모든 운영 체제에서 실행할 수 있습니다.

Bytecodeachievesplatformincendence는 executedbirtualmachine (vm)을 beenecutedbyavirtmachine (vm)을 허용합니다

Java는 100% 플랫폼 독립성을 달성 할 수 없지만 플랫폼 독립성은 JVM 및 바이트 코드를 통해 구현되어 코드가 다른 플랫폼에서 실행되도록합니다. 특정 구현에는 다음이 포함됩니다. 1. 바이트 코드로의 컴파일; 2. JVM의 해석 및 실행; 3. 표준 라이브러리의 일관성. 그러나 JVM 구현 차이, 운영 체제 및 하드웨어 차이, 타사 라이브러리의 호환성은 플랫폼 독립성에 영향을 줄 수 있습니다.

Java는 "Writ 2. 유지 보수 비용이 낮 으면 하나의 수정 만 필요합니다. 3. 높은 팀 협업 효율성은 높고 지식 공유에 편리합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.
