Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[ISSUE#173]Connect Exporter for Prometheus #200

Open
wants to merge 6 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
47 changes: 47 additions & 0 deletions connectors/rocketmq-connect-metrics-exporter/pom.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
<?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>org.apache.rocketmq</groupId>
<artifactId>rocketmq-connect-metrics-exporter</artifactId>
<version>1.0-SNAPSHOT</version>
<name>rocketmq-connect-metrics-exporter</name>


<properties>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<openmessaging.connector.version>0.1.3</openmessaging.connector.version>
</properties>

<dependencies>
<dependency>
<groupId>io.openmessaging</groupId>
<artifactId>openmessaging-connector</artifactId>
<version>${openmessaging.connector.version}</version>
</dependency>
</dependencies>

<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.6.1</version>
<configuration>
<source>${maven.compiler.source}</source>
<target>${maven.compiler.target}</target>
<compilerVersion>${maven.compiler.source}</compilerVersion>
<showDeprecation>true</showDeprecation>
<showWarnings>true</showWarnings>
</configuration>
</plugin>
</plugins>
</build>


</project>
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
package org.apache.rocket.connect.metrics.export.sink.connector;

import io.openmessaging.KeyValue;
import io.openmessaging.connector.api.component.task.Task;
import io.openmessaging.connector.api.component.task.sink.SinkConnector;
import java.util.ArrayList;
import java.util.List;
import org.apache.rocket.connect.metrics.export.sink.util.ServiceProvicerUtil;

public class MetricsExportSinkConnector extends SinkConnector {
private KeyValue config;

private List<MetricsExporter> metricsExporters;
{
metricsExporters = ServiceProvicerUtil.getMetricsExporterServices();
}

@Override public List<KeyValue> taskConfigs(int maxTasks) {
List<KeyValue> configs = new ArrayList<>();
configs.add(config);
return configs;
}

@Override public Class<? extends Task> taskClass() {
return MetricsExportSinkTask.class;
}

@Override public void start(KeyValue config) {
this.config = config;
}

@Override public void stop() {
this.config = null;
}

@Override public void validate(KeyValue config) {
for (MetricsExporter exporter: metricsExporters) {
exporter.validate(config);
}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
package org.apache.rocket.connect.metrics.export.sink.connector;

import io.openmessaging.KeyValue;
import io.openmessaging.connector.api.component.task.sink.SinkTask;
import io.openmessaging.connector.api.component.task.sink.SinkTaskContext;
import io.openmessaging.connector.api.data.ConnectRecord;
import io.openmessaging.connector.api.errors.ConnectException;
import java.util.List;
import org.apache.rocket.connect.metrics.export.sink.util.ServiceProvicerUtil;


public class MetricsExportSinkTask extends SinkTask {
private List<MetricsExporter> metricsExporters;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Has the implementation of MetricsExporter been submitted yet?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry not yet :( . But I am trying my best to finish a exporter for Prometheus which gets the metrics from the log files, and some preliminary knowledge is got. And I hear the sftp source connector (my upstream task) is designing in the last weekly meeting. So I'm waiting for the implementation ConnectRecord in it in order to complete my parsing.


@Override public void put(List<ConnectRecord> sinkRecords) throws ConnectException {
for (MetricsExporter exporter : metricsExporters) {
exporter.export(sinkRecords);
}
}

@Override public void start(KeyValue config) {
for (MetricsExporter exporter : metricsExporters) {
exporter.start(config);
}
}

@Override public void stop() {
for (MetricsExporter exporter : metricsExporters) {
exporter.stop();
}
}

@Override public void init(SinkTaskContext sinkTaskContext) {
super.init(sinkTaskContext);
metricsExporters = ServiceProvicerUtil.getMetricsExporterServices();
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
package org.apache.rocket.connect.metrics.export.sink.connector;

import io.openmessaging.KeyValue;
import io.openmessaging.connector.api.data.ConnectRecord;
import java.util.List;

public interface MetricsExporter {
void export(List<ConnectRecord> sinkRecords);

void validate(KeyValue config);

void start(KeyValue config);

void stop();

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
package org.apache.rocket.connect.metrics.export.sink.util;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.ServiceLoader;
import org.apache.rocket.connect.metrics.export.sink.connector.MetricsExporter;

/**
* @author: ming
*/
public class ServiceProvicerUtil {

public static List<MetricsExporter> getMetricsExporterServices(){
List<MetricsExporter> metricsExporterList = new ArrayList<>();
ServiceLoader<MetricsExporter> metricsExporters = ServiceLoader.load(MetricsExporter.class);
Iterator<MetricsExporter> iterator = metricsExporters.iterator();
while (iterator.hasNext()){
metricsExporterList.add(iterator.next());
}
return metricsExporterList;
}
}