Как настроить сервер Spring Cloud Zipkin с Elasticsearch для сохранения?

Я хочу загрузить свой zipkin-сервер Spring Cloud с помощью asticsearch. Я думаю, я попробовал почти все, что мог. но, он все еще работает с в памяти. (когда я перезагружаю zipkin-сервер, все данные теряются.) Я хочу настроить zipkin сластиком поиска. Пожалуйста, скажите мне, какие именно зависимости и Applicartion.yml или какие-либо другие вещи необходимы.

2 ответа

Решение

Создание пользовательских серверов zipkin является неподдерживаемой конфигурацией, но если вам необходимо, все параметры конфигурации описаны в файле readme проекта: https://github.com/openzipkin/zipkin/blob/master/zipkin-server/README.md

Для части зависимостей наиболее важным является zipkin-autoconfigure-storage-asticsearch-http, вот полный пример maven pom.xml:

<?xml version="1.0"?>
<project
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<modelVersion>4.0.0</modelVersion>

<groupId>com.example</groupId>
<artifactId>zipkin-server</artifactId>
<version>1.0.0-SNAPSHOT</version>
<name>zipkin-server</name>
<url>http://maven.apache.org</url>

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.5.2.RELEASE</version>
    <relativePath/>
</parent>

<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.target>1.8</maven.compiler.target>
    <maven.compiler.source>1.8</maven.compiler.source>
    <spring-cloud.version>Dalston.SR1</spring-cloud.version>
    <zipkin.version>1.23.2</zipkin.version>
</properties>

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>${spring-cloud.version}</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>
<dependencies>
    <dependency>
        <groupId>io.zipkin.java</groupId>
        <artifactId>zipkin-server</artifactId>
    </dependency>
    <dependency>
        <groupId>io.zipkin.java</groupId>
        <artifactId>zipkin-autoconfigure-ui</artifactId>
    </dependency>
    <dependency>
        <groupId>io.zipkin.java</groupId>
        <artifactId>zipkin-autoconfigure-collector-kafka10</artifactId>
        <version>1.26.0</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-sleuth-zipkin-stream</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-stream-kafka</artifactId>
    </dependency>
    <dependency>
        <groupId>io.zipkin.java</groupId>
        <artifactId>zipkin-autoconfigure-storage-elasticsearch-http</artifactId>
        <version>${zipkin.version}</version>
    </dependency>
</dependencies>

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
</build>

Для части конфигурации вам понадобится следующее в вашем application.yml:

zipkin:
  storage:
    type: elasticsearch
    elasticsearch:
      hosts: localhost:9200

Я настроил zipkin для использования ES в качестве хранилища данных поверх кубернетов. Если это соответствует вашим требованиям, вы можете скачать и использовать https://github.com/handysofts/zipkin-on-kubernetes

Другие вопросы по тегам