Skip to content
This repository has been archived by the owner on Jun 30, 2023. It is now read-only.
This repository has been archived by the owner on Jun 30, 2023. It is now read-only.

StackOverFlowError at toConnectSchema #63

Open
@TobiasKrok

Description

Hi!

I'm getting this error when trying to start my Kafka connector

      [2021-06-11 14:29:10,173] ERROR Failed to start task mqtt-source-0 (org.apache.kafka.connect.runtime.Worker:560)
      java.lang.StackOverflowError
              at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
              at java.base/java.lang.reflect.Method.invoke(Method.java:566)
              at com.google.protobuf.GeneratedMessageV3.invokeOrDie(GeneratedMessageV3.java:1856)
              at com.google.protobuf.GeneratedMessageV3.access$1100(GeneratedMessageV3.java:79)
              at com.google.protobuf.GeneratedMessageV3$FieldAccessorTable$SingularFieldAccessor$ReflectionInvoker.has(GeneratedMessageV3.java:2221)
              at com.google.protobuf.GeneratedMessageV3$FieldAccessorTable$SingularFieldAccessor.has(GeneratedMessageV3.java:2329)
              at com.google.protobuf.GeneratedMessageV3.hasField(GeneratedMessageV3.java:268)
              at com.google.protobuf.GeneratedMessageV3$ExtendableMessage.hasField(GeneratedMessageV3.java:1258)
              at com.google.protobuf.GeneratedMessageV3.getAllFieldsMutable(GeneratedMessageV3.java:191)
              at com.google.protobuf.GeneratedMessageV3.access$800(GeneratedMessageV3.java:79)
              at com.google.protobuf.GeneratedMessageV3$ExtendableMessage.getAllFields(GeneratedMessageV3.java:1239)
              at com.blueapron.connect.protobuf.ProtobufData.getConnectFieldName(ProtobufData.java:78)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:216)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)
              at com.blueapron.connect.protobuf.ProtobufData.toConnectSchema(ProtobufData.java:217)

My Proto file looks like this:

syntax = "proto3";

import "google/protobuf/any.proto";

package org.eclipse.tahu.protobuf;

option java_package         = "org.eclipse.tahu.protobuf";
option java_outer_classname = "SparkplugBProto";

enum DataType {
    // Indexes of Data Types

    // Unknown placeholder for future expansion.
    Unknown         = 0;

    // Basic Types
    Int8            = 1;
    Int16           = 2;
    Int32           = 3;
    Int64           = 4;
    UInt8           = 5;
    UInt16          = 6;
    UInt32          = 7;
    UInt64          = 8;
    Float           = 9;
    Double          = 10;
    Boolean         = 11;
    String          = 12;
    DateTime        = 13;
    Text            = 14;

    // Additional Metric Types
    UUID            = 15;
    DataSet         = 16;
    Bytes           = 17;
    File            = 18;
    Template        = 19;

    // Additional PropertyValue Types
    PropertySet     = 20;
    PropertySetList = 21;

    // Array Types
    Int8Array = 22;
    Int16Array = 23;
    Int32Array = 24;
    Int64Array = 25;
    UInt8Array = 26;
    UInt16Array = 27;
    UInt32Array = 28;
    UInt64Array = 29;
    FloatArray = 30;
    DoubleArray = 31;
    BooleanArray = 32;
    StringArray = 33;
    DateTimeArray = 34;
}

message Payload {

    message Template {

        message Parameter {
            string name        = 1;
            uint32 type        = 2;

            oneof value {
                uint32 int_value        = 3;
                uint64 long_value       = 4;
                float  float_value      = 5;
                double double_value     = 6;
                bool   boolean_value    = 7;
                string string_value     = 8;
                ParameterValueExtension extension_value = 9;
            }

            message ParameterValueExtension {
                repeated google.protobuf.Any extensions = 1;
            }
        }

        string version                       = 1;          // The version of the Template to prevent mismatches
        repeated Metric metrics              = 2;          // Each metric is the name of the metric and the datatype of the member but does not contain a value
        repeated Parameter parameters        = 3;
        string template_ref                  = 4;          // Reference to a template if this is extending a Template or an instance - must exist if an instance
        bool is_definition                   = 5;
        repeated google.protobuf.Any details = 6;
    }

    message DataSet {

        message DataSetValue {

            oneof value {
                uint32 int_value                        = 1;
                uint64 long_value                       = 2;
                float  float_value                      = 3;
                double double_value                     = 4;
                bool   boolean_value                    = 5;
                string string_value                     = 6;
                DataSetValueExtension extension_value   = 7;
            }

            message DataSetValueExtension {
                repeated google.protobuf.Any details = 1;
            }
        }

        message Row {
            repeated DataSetValue elements  = 1;
            repeated google.protobuf.Any details = 2;
        }

        uint64 num_of_columns                = 1;
        repeated string   columns            = 2;
        repeated uint32   types              = 3;
        repeated Row      rows               = 4;
        repeated google.protobuf.Any details = 5;
    }

    message PropertyValue {

        uint32     type                   = 1;
        bool       is_null                = 2;

        oneof value {
            uint32          int_value              = 3;
            uint64          long_value             = 4;
            float           float_value            = 5;
            double          double_value           = 6;
            bool            boolean_value          = 7;
            string          string_value           = 8;
            PropertySet     propertyset_value      = 9;
            PropertySetList propertysets_value     = 10;      // List of Property Values
            PropertyValueExtension extension_value = 11;
        }

        message PropertyValueExtension {
            repeated google.protobuf.Any details = 1;
        }
    }

    message PropertySet {
        repeated string        keys     = 1;         // Names of the properties
        repeated PropertyValue values   = 2;
        repeated google.protobuf.Any details = 3;
    }

    message PropertySetList {
        repeated PropertySet propertyset = 1;
        repeated google.protobuf.Any details = 2;
    }

    message MetaData {
        // Bytes specific metadata
        bool   is_multi_part   = 1;

        // General metadata
        string content_type    = 2;        // Content/Media type
        uint64 size            = 3;        // File size, String size, Multi-part size, etc
        uint64 seq             = 4;        // Sequence number for multi-part messages

        // File metadata
        string file_name       = 5;        // File name
        string file_type       = 6;        // File type (i.e. xml, json, txt, cpp, etc)
        string md5             = 7;        // md5 of data

        // Catchalls and future expansion
        string description     = 8;        // Could be anything such as json or xml of custom properties
        repeated google.protobuf.Any details = 9;
    }

    message Metric {

        string   name          = 1;        // Metric name - should only be included on birth
        uint64   alias         = 2;        // Metric alias - tied to name on birth and included in all later DATA messages
        uint64   timestamp     = 3;        // Timestamp associated with data acquisition time
        uint32   datatype      = 4;        // DataType of the metric/tag value
        bool     is_historical = 5;        // If this is historical data and should not update real time tag
        bool     is_transient  = 6;        // Tells consuming clients such as MQTT Engine to not store this as a tag
        bool     is_null       = 7;        // If this is null - explicitly say so rather than using -1, false, etc for some datatypes.
        MetaData metadata      = 8;        // Metadata for the payload
        PropertySet properties = 9;

        oneof value {
            uint32   int_value                      = 10;
            uint64   long_value                     = 11;
            float    float_value                    = 12;
            double   double_value                   = 13;
            bool     boolean_value                  = 14;
            string   string_value                   = 15;
            bytes    bytes_value                    = 16;       // Bytes, File
            DataSet  dataset_value                  = 17;
            Template template_value                 = 18;
            MetricValueExtension extension_value    = 19;
        }

        message MetricValueExtension {
            repeated google.protobuf.Any details = 1;
        }
    }

    uint64   timestamp      = 1;        // Timestamp at message sending time
    repeated Metric metrics = 2;        // Repeated forever - no limit in Google Protobufs
    uint64   seq            = 3;        // Sequence number
    string   uuid           = 4;        // UUID to track message type in terms of schema definitions
    bytes    body           = 5;        // To optionally bypass the whole definition above
    repeated google.protobuf.Any details = 6;
}

And my Kafka connector config looks like this:

key.converter=com.blueapron.connect.protobuf.ProtobufConverter
key.converter.schemas.enable=false
value.converter=com.blueapron.connect.protobuf.ProtobufConverter
value.converter.protoClassName=org.eclipse.tahu.protobuf.SparkplugBProto$Payload

Does anyone have an idea what could cause this? Is the Proto file too complex for this converter? I've tried experimenting with different versions of the google protobuf java library as well. Also different protoc versions just to check.

Thank you in advance!

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions