찾다
운영 및 유지보수ApacheApache Avro 데이터를 구문 분석하는 방법에 대해 이야기해 보겠습니다(예제 설명).

Apache Avro 데이터를 구문 분석하는 방법은 무엇입니까? 이 기사에서는 Avro 데이터를 생성하기 위해 직렬화하고, Avro 데이터를 구문 분석하기 위해 역직렬화하고, FlinkSQL을 사용하여 Avro 데이터를 구문 분석하는 방법을 소개합니다. 도움이 되길 바랍니다.

Apache Avro 데이터를 구문 분석하는 방법에 대해 이야기해 보겠습니다(예제 설명).

인터넷의 급속한 발전으로 클라우드 컴퓨팅, 빅데이터, 인공지능, 사물인터넷 등 첨단기술이 전자상거래 웹사이트 등 오늘날 시대의 주류 첨단기술로 자리 잡았습니다. 집, 스마트시티 등은 사람들의 음식, 의복, 주거, ​​교통을 편리하게 할 뿐만 아니라, 그 이면에는 사람이 수집하고, 정리하고, 분석하는 수많은 데이터가 존재합니다. 낮은 대기 시간과 높은 데이터 품질을 보장하는 다양한 시스템 플랫폼이 특히 중요합니다. Apache Avro 자체는 바이너리 전송을 위해 스키마를 통해 직렬화됩니다. 반면에 데이터 보안을 보장합니다. Avro는 현재 다양한 산업에서 점점 더 많이 사용되고 있으며, Avro 데이터를 처리하고 구문 분석하는 것이 더 중요합니다. 분석을 위해 FlinkSQL을 사용하세요.

이 기사는 avro 구문 분석에 대한 데모입니다. 현재 FlinkSQL은 간단한 avro 데이터 구문 분석에만 적합합니다. 복잡한 중첩 avro 데이터는 당분간 지원되지 않습니다.

장면 소개

이 기사에서는 주로 다음 세 가지 핵심 내용을 소개합니다.

  • Avro 데이터를 직렬화하고 생성하는 방법

  • Avro 데이터를 역직렬화하고 구문 분석하는 방법

  • FlinkSQL을 사용하여 Avro 데이터를 구문 분석하는 방법 전제 조건 AVRO가 무엇인지 이해하기 위해 Avro Avro 공식 웹 사이트 Quick Start Guide를 참조하십시오 project andconfigure pom dependency

pom 파일의 내용은 다음과 같습니다.
    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
    
        <groupId>com.huawei.bigdata</groupId>
        <artifactId>avrodemo</artifactId>
        <version>1.0-SNAPSHOT</version>
        <dependencies>
            <dependency>
                <groupId>org.apache.avro</groupId>
                <artifactId>avro</artifactId>
                <version>1.8.1</version>
            </dependency>
            <dependency>
                <groupId>junit</groupId>
                <artifactId>junit</artifactId>
                <version>4.12</version>
            </dependency>
        </dependencies>
    
        <build>
            <plugins>
                <plugin>
                    <groupId>org.apache.avro</groupId>
                    <artifactId>avro-maven-plugin</artifactId>
                    <version>1.8.1</version>
                    <executions>
                        <execution>
                            <phase>generate-sources</phase>
                            <goals>
                                <goal>schema</goal>
                            </goals>
                            <configuration>
                                <sourceDirectory>${project.basedir}/src/main/avro/</sourceDirectory>
                                <outputDirectory>${project.basedir}/src/main/java/</outputDirectory>
                            </configuration>
                        </execution>
                    </executions>
                </plugin>
                <plugin>
                    <groupId>org.apache.maven.plugins</groupId>
                    <artifactId>maven-compiler-plugin</artifactId>
                    <configuration>
                        <source>1.6</source>
                        <target>1.6</target>
                    </configuration>
                </plugin>
            </plugins>
        </build>
    
    </project>
  • 참고: 위 pom 파일은 자동으로 생성된 클래스의 경로, 즉

  • 로 구성됩니다.
p

r

o

Apache Avro 데이터를 구문 분석하는 방법에 대해 이야기해 보겠습니다(예제 설명).j

e

c t mai n /avr o/{project.basedir}/src/main/avro/ 및 p roj ec t.basedi r/s {project.basedir }/src/main/ java/.이 구성 후 mvn 명령을 실행할 때 이 플러그인은 이 디렉터리의 avsc 스키마에서 클래스 파일을 자동으로 생성하고 후자의 디렉터리에 배치합니다. avro 디렉터리가 생성되지 않은 경우 수동으로 생성하세요.

{"namespace": "lancoo.ecbdc.pre",
 "type": "record",
 "name": "User",
 "fields": [
     {"name": "name", "type": "string"},
     {"name": "favorite_number",  "type": ["int", "null"]},
     {"name": "favorite_color", "type": ["string", "null"]}
 ]
}
3 스키마를 컴파일합니다.

点击maven projects项目的compile进行编译,会自动在创建namespace路径和User类代码

Apache Avro 데이터를 구문 분석하는 방법에 대해 이야기해 보겠습니다(예제 설명).

4、序列化

创建TestUser类,用于序列化生成数据

User user1 = new User();
user1.setName("Alyssa");
user1.setFavoriteNumber(256);
// Leave favorite col or null

// Alternate constructor
User user2 = new User("Ben", 7, "red");

// Construct via builder
User user3 = User.newBuilder()
        .setName("Charlie")
        .setFavoriteColor("blue")
        .setFavoriteNumber(null)
        .build();

// Serialize user1, user2 and user3 to disk
DatumWriter<User> userDatumWriter = new SpecificDatumWriter<User>(User.class);
DataFileWriter<User> dataFileWriter = new DataFileWriter<User>(userDatumWriter);
dataFileWriter.create(user1.getSchema(), new File("user_generic.avro"));
dataFileWriter.append(user1);
dataFileWriter.append(user2);
dataFileWriter.append(user3);
dataFileWriter.close();

执行序列化程序后,会在项目的同级目录下生成avro数据

Apache Avro 데이터를 구문 분석하는 방법에 대해 이야기해 보겠습니다(예제 설명).

user_generic.avro内容如下:

Objavro.schema�{"type":"record","name":"User","namespace":"lancoo.ecbdc.pre","fields":[{"name":"name","type":"string"},{"name":"favorite_number","type":["int","null"]},{"name":"favorite_color","type":["string","null"]}]}

至此avro数据已经生成。

5、反序列化

通过反序列化代码解析avro数据

// Deserialize Users from disk
DatumReader<User> userDatumReader = new SpecificDatumReader<User>(User.class);
DataFileReader<User> dataFileReader = new DataFileReader<User>(new File("user_generic.avro"), userDatumReader);
User user = null;
while (dataFileReader.hasNext()) {
    // Reuse user object by passing it to next(). This saves us from
    // allocating and garbage collecting many objects for files with
    // many items.
    user = dataFileReader.next(user);
    System.out.println(user);
}

执行反序列化代码解析user_generic.avro

Apache Avro 데이터를 구문 분석하는 방법에 대해 이야기해 보겠습니다(예제 설명).

avro数据解析成功。

6、将user_generic.avro上传至hdfs路径

hdfs dfs -mkdir -p /tmp/lztest/

hdfs dfs -put user_generic.avro /tmp/lztest/

Apache Avro 데이터를 구문 분석하는 방법에 대해 이야기해 보겠습니다(예제 설명).

7、配置flinkserver

  • 准备avro jar包

将flink-sql-avro-*.jar、flink-sql-avro-confluent-registry-*.jar放入flinkserver lib,将下面的命令在所有flinkserver节点执行

cp /opt/huawei/Bigdata/FusionInsight_Flink_8.1.2/install/FusionInsight-Flink-1.12.2/flink/opt/flink-sql-avro*.jar /opt/huawei/Bigdata/FusionInsight_Flink_8.1.3/install/FusionInsight-Flink-1.12.2/flink/lib

chmod 500 flink-sql-avro*.jar

chown omm:wheel flink-sql-avro*.jar

Apache Avro 데이터를 구문 분석하는 방법에 대해 이야기해 보겠습니다(예제 설명).

  • 同时重启FlinkServer实例,重启完成后查看avro包是否被上传

    hdfs dfs -ls /FusionInsight_FlinkServer/8.1.2-312005/lib

Apache Avro 데이터를 구문 분석하는 방법에 대해 이야기해 보겠습니다(예제 설명).

8、编写FlinkSQL

CREATE TABLE testHdfs(
  name String,
  favorite_number int,
  favorite_color String
) WITH(
  &#39;connector&#39; = &#39;filesystem&#39;,
  &#39;path&#39; = &#39;hdfs:///tmp/lztest/user_generic.avro&#39;,
  &#39;format&#39; = &#39;avro&#39;
);CREATE TABLE KafkaTable (
  name String,
  favorite_number int,
  favorite_color String
) WITH (
  &#39;connector&#39; = &#39;kafka&#39;,
  &#39;topic&#39; = &#39;testavro&#39;,
  &#39;properties.bootstrap.servers&#39; = &#39;96.10.2.1:21005&#39;,
  &#39;properties.group.id&#39; = &#39;testGroup&#39;,
  &#39;scan.startup.mode&#39; = &#39;latest-offset&#39;,
  &#39;format&#39; = &#39;avro&#39;
);
insert into
  KafkaTable
select
  *
from
  testHdfs;

Apache Avro 데이터를 구문 분석하는 방법에 대해 이야기해 보겠습니다(예제 설명).

保存提交任务

9、查看对应topic中是否有数据

Apache Avro 데이터를 구문 분석하는 방법에 대해 이야기해 보겠습니다(예제 설명).

FlinkSQL解析avro数据成功。

【推荐:Apache使用教程

위 내용은 Apache Avro 데이터를 구문 분석하는 방법에 대해 이야기해 보겠습니다(예제 설명).의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 掘金社区에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
Apache를 정의한 것은 무엇입니까? 핵심 기능Apache를 정의한 것은 무엇입니까? 핵심 기능May 09, 2025 am 12:21 AM

Apache의 핵심 기능은 모듈 식 설계 및 높은 사용자 정의이며 다양한 웹 서비스 요구를 충족시킬 수 있습니다. 1. 모듈 식 설계는 다른 모듈을로드하여 확장 된 기능을 허용합니다. 2. 여러 운영 체제를 지원하며 다른 환경에 적합합니다. 3. 멀티 프로세스, 다중 스레드 및 이벤트 중심 모델은 성능을 향상시킵니다. 4. 기본 사용법에는 가상 호스트 및 문서 루트 디렉토리 구성이 포함됩니다. 5. 고급 사용에는 URL 재 작성,로드 밸런싱 및 리버스 프록시가 포함됩니다. 6. 구문 검사 및 로그 분석을 통해 일반적인 오류를 디버깅 할 수 있습니다. 7. 성능 최적화에는 MPM 설정 조정 및 캐시 활성화가 포함됩니다.

Apache의 지속적인 사용 : 웹 호스팅 및 그 이상Apache의 지속적인 사용 : 웹 호스팅 및 그 이상May 08, 2025 am 12:15 AM

현대 웹 환경에서 여전히 Apache를 인기있게 만드는 것은 강력한 기능과 유연성입니다. 1) 모듈 식 디자인을 사용하면 보안 인증 및로드 밸런싱과 같은 사용자 정의 기능이 가능합니다. 2) 인기를 높이기 위해 여러 운영 체제를 지원합니다. 3) 다양한 응용 프로그램 시나리오에 적합한 동시 요청을 효율적으로 처리합니다.

아파치 : 오픈 소스에서 산업 표준으로아파치 : 오픈 소스에서 산업 표준으로May 07, 2025 am 12:05 AM

Apache가 오픈 소스 프로젝트에서 업계 표준으로 개발 한 이유는 다음과 같습니다. 1) 커뮤니티 중심으로 글로벌 개발자가 참여하도록 유도합니다. 2) 인터넷 표준을 준수하는 표준화 및 호환성; 3) 비즈니스 지원 및 생태계 및 엔터프라이즈 수준의 시장 지원을 얻습니다.

Apache의 유산 : 웹 호스팅에 미치는 영향Apache의 유산 : 웹 호스팅에 미치는 영향May 06, 2025 am 12:03 AM

Apache의 웹 호스트에 미치는 영향은 주로 오픈 소스 기능, 강력한 기능 및 유연성에 반영됩니다. 1) 오픈 소스 기능은 웹 호스트의 임계 값을 낮추는 기능입니다. 2) 강력한 기능과 유연성으로 인해 대규모 웹 사이트 및 비즈니스의 첫 번째 선택이됩니다. 3) 가상 호스트 기능은 비용을 절약합니다. 동시성 조건이 높은 성능이 감소 할 수 있지만 Apache는 지속적인 최적화를 통해 경쟁력을 유지합니다.

아파치 : 웹에 대한 역사와 기여아파치 : 웹에 대한 역사와 기여May 05, 2025 am 12:14 AM

원래 1995 년에 시작된 Apache는 개발자 그룹에 의해 NCSAHTTPD 서버를 개선하고 세계에서 가장 널리 사용되는 웹 서버가되었습니다. 1. 1995 년에 시작하여 NCSAHTTPD 서버를 개선하는 것을 목표로합니다. 2. 웹 서버 표준을 정의하고 오픈 소스 이동의 개발을 촉진합니다. 3. Tomcat 및 Kafka와 같은 중요한 하위 프로젝트를 육성했습니다. 4. 클라우드 컴퓨팅 및 컨테이너 기술의 과제에 직면하여 향후 클라우드 네이티브 기술과 통합하는 데 중점을 둘 것입니다.

아파치의 영향 : 인터넷 형성아파치의 영향 : 인터넷 형성May 04, 2025 am 12:05 AM

Apache는 안정적인 웹 서버 인프라를 제공하여 오픈 소스 문화를 홍보하고 중요한 프로젝트를 배양함으로써 인터넷을 형성했습니다. 1) Apache는 안정적인 웹 서버 인프라를 제공하고 웹 기술의 혁신을 촉진합니다. 2) Apache는 오픈 소스 문화의 개발을 촉진했으며 ASF는 Hadoop 및 Kafka와 같은 중요한 프로젝트를 배양했습니다. 3) 성능 문제에도 불구하고 Apache의 미래는 여전히 희망으로 가득 차 있으며 ASF는 계속해서 새로운 기술을 시작합니다.

Apache의 유산 : 웹 서버에 미치는 영향을 살펴보십시오.Apache의 유산 : 웹 서버에 미치는 영향을 살펴보십시오.May 03, 2025 am 12:03 AM

Apachehttpserver는 1995 년 자원 봉사자들이 창설 한 이래 웹 서버 분야에 중대한 영향을 미쳤습니다. 1. NCSAHTTPD에 대한 불만에서 비롯되며보다 안정적이고 안정적인 서비스를 제공합니다. 2. Apache Software Foundation의 설립은 생태계로의 변화를 나타냅니다. 3. 모듈 식 설계 및 보안은 웹 서버의 유연성과 보안을 향상시킵니다. 4. 시장 점유율의 감소에도 불구하고 Apache는 여전히 현대 웹 기술과 밀접한 관련이 있습니다. 5. 구성 최적화 및 캐싱을 통해 Apache는 성능을 향상시킵니다. 6. 오류 로그 및 디버그 모드는 일반적인 문제를 해결하는 데 도움이됩니다.

Apache의 목적 : 웹 컨텐츠 제공Apache의 목적 : 웹 컨텐츠 제공May 02, 2025 am 12:23 AM

Apachehttpserver는 모듈 식 디자인, 가상 호스팅 기능 및 성능 최적화를 통해 현대 인터넷 환경에서 웹 컨텐츠를 효율적으로 효율적으로 제공합니다. 1) 모듈 식 디자인을 사용하면 웹 사이트 SEO 성능을 향상시키기 위해 URL 재 작성과 같은 기능을 추가 할 수 있습니다. 2) 가상 호스팅 기능은 하나의 서버에서 여러 웹 사이트를 호스팅하여 비용을 절약하고 관리를 단순화합니다. 3) 다중 스레딩 및 캐싱 최적화를 통해 Apache는 많은 동시 연결을 처리하여 응답 속도와 사용자 경험을 향상시킬 수 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

SublimeText3 영어 버전

SublimeText3 영어 버전

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

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구