[Q&A][FAQ] Why is Clickhouse or Loki or xxx not supported as an storage option? #11975
wu-sheng
started this conversation in
Show and tell
Replies: 1 comment
-
Added this as a FAQ, #12059 |
Beta Was this translation helpful? Give feedback.
0 replies
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
-
Background
In the past several years, community users have asked why Clickhouse, Loki, or some other storage is not supported in the upstream. We have repeated the answer many times, but it is still happening, at here, I would like to write down the summary to help people understand more
Previous Discussions
All the following issues were about discussing new storage extension topics.
Generally, all those asking are about adding a new kind of storage.
Why they don't exist ?
First of all,
WHY
is not a suitable question. SkyWalking is a volunteer-driven community, the volunteers build this project including bug fixes, maintenance work, and new features from their personal and employer interests. What you saw about the current status is the combination of all those interests rather than responsibilities.So, in SkyWalking, anything you saw existing is/was someone's interest and contributed to upstream.
This logic is the same as this question, SkyWalking active maintainers are focusing on JDBC(MySQL and PostgreSQL ecosystem) Database and Elasticsearch for existing users, and moving forward on BanyanDB as the native one. We for now don't have people interested in ClickHouse or any other database. That is why they are not there.
How could add one?
To add a new feature, including a new storage plugin, you should go through SWIP - SkyWalking Improvement Proposal workflow, and have a full discussion with the maintenance team.
SkyWalking has a pluggable storage system, so, ideally new storage option is possible to implement a new provider for the storage module. Meanwhile, in practice, as storage implementation should be in high performance and well optimized, considering our experiences with JDBC and Elasticsearch implementations, some flags and annotations may need to be added in the kernel level and data model declarations.
Furthermore, as current maintainers are not a fun of Clickhouse or others(otherwise, you should have seen those implementations), they are not going to be involved in the code implementations and they don't know much more from a general perspective about which kind of implementation in that specific database will have a better behavior and performance. So, if you want to propose this to upstream, you should be very experienced in that database, and have enough scale and environments to provide solid benchmark.
What happens next if the new implementation gets accepted/merged/released?
Who proposed this new implementation(such as clickhouse storage), has to take the responsibilities of the maintenance. The maintenance means they need to
Even if the storage gets accepted/merged/released, but no one can't take the above responsibilities or the community doesn't receive the feedback and questions about those storages, SkyWalking PMC(Project Management Committee) will start the process to remove the implementations. This happened before for Apache IoTDB and InfluxDB storage options. Here is the last vote about this,
Beta Was this translation helpful? Give feedback.
All reactions