中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

PulsarIO中怎么調(diào)用Schema

這篇文章給大家介紹Pulsar IO 中怎么調(diào)用Schema ,內(nèi)容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

我們提供的服務有:做網(wǎng)站、網(wǎng)站制作、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、長陽ssl等。為成百上千企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術的長陽網(wǎng)站制作公司

Schema 是一種描述數(shù)據(jù)的數(shù)據(jù)   。例如,數(shù)據(jù)庫中表的信息和字段類型等都是 Schema。Pulsar 對 Schema 也有比較好的支持。    


>>> Schema 簡單應用 <<<  

 
在使用 pub/sub 生產(chǎn)和消費消息時,可以通過以下代碼使用 Schema:  
     
   
   
   
public class SensorReading {              public float temperature;          
             public SensorReading(float temperature) {                  this.temperature = temperature;              }          
             // A no-arg constructor is required              public SensorReading() {              }          
             public float getTemperature() {                  return temperature;              }          
             public void setTemperature(float temperature) {                  this.temperature = temperature;              }          }          Producer<SensorReading> producer = client.newProducer(JSONSchema.of(SensorReading.class))              .topic("my-topic")              .create();          Consumer consumer = client.newConsumer(JSONSchema.of(SensorReading.class))                  .topic("my-topic")                  .subscriptionName("my-subscription")                  .subscribe();      

通過以上操作,生產(chǎn)者和消費者可以識別出關于 SensorReading 這個類的含義。這是 Schema 在客戶端的應用,也是比較普遍的使用方法。  

 
前文已經(jīng)提到,Source 和 Sink 是對 pub/sub 的封裝,因此,Schema 的應用也是基于以上原理。以下為詳細說明。  

 
>>> Source 中的 Schema <<<  

 
在內(nèi)建的 Sink 中,實現(xiàn)了一個 Consumer,用于接收從 Pulsar 發(fā)來的數(shù)據(jù)。  
     
   
   
   if (conf.getSerdeClassName() != null && !conf.getSerdeClassName().isEmpty()) {  
    
        schema = (Schema<T>) topicSchema.getSchema(topic, typeArg, conf.getSerdeClassName(), true);  
    
    } else {  
    
        schema = (Schema<T>) topicSchema.getSchema(topic, typeArg, conf.getSchemaType(), true);  
    
    }

getSerdeClassName    會獲取用戶指定的用于序列化與反序列化的類,通過指定 --   custom-serde-inputs    參數(shù),從而構建真正的 Schema。  
     
   
   
   
case NONE:            return (Schema<T>) Schema.BYTES;          
         case AUTO_CONSUME:          case AUTO:            return (Schema<T>) Schema.AUTO_CONSUME();          
         case STRING:            return (Schema<T>) Schema.STRING;          
         case AVRO:            return AvroSchema.of(SchemaDefinition.<T>builder().withPojo(clazz).build());          
         case JSON:            return JSONSchema.of(SchemaDefinition.<T>builder().withPojo(clazz).build());          
         case KEY_VALUE:            return (Schema<T>)Schema.KV_BYTES();          
         case PROTOBUF:            return ProtobufSchema.ofGenericClass(clazz, Collections.emptyMap());          }      


關于Pulsar IO 中怎么調(diào)用Schema 就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

分享題目:PulsarIO中怎么調(diào)用Schema
文章地址:http://www.rwnh.cn/article14/pcopde.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供企業(yè)網(wǎng)站制作、電子商務、移動網(wǎng)站建設全網(wǎng)營銷推廣、、做網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站
湖口县| 衡阳市| 望城县| 富锦市| 邵阳县| 兴城市| 芜湖县| 巴塘县| 饶平县| 荔浦县| 怀来县| 东城区| 财经| 安顺市| 岗巴县| 吴川市| 石狮市| 广饶县| 比如县| 湾仔区| 常熟市| 肥东县| 宜城市| 监利县| 图们市| 龙门县| 金沙县| 南宫市| 娄底市| 鄱阳县| 桑日县| 阿勒泰市| 神农架林区| 启东市| 澎湖县| 金秀| 陆良县| 西安市| 洛扎县| 贡嘎县| 宁南县|