# Backend storage SkyWalking storage is pluggable, we have provided the following storage solutions, you could easily use is by changing the `application.yml` Native supported storage - H2 - ElasticSearch 6 - MySQL - TiDB Redistribution version with supported storage. - ElasticSearch 5 ## H2 Active H2 as storage, set storage provider to **H2** In-Memory Databases. Default in distribution package. Please read `Database URL Overview` in [H2 official document](http://www.h2database.com/html/features.html), you could set the target to H2 in **Embedded**, **Server** and **Mixed** modes. Setting fragment example ```yaml storage: h2: driver: org.h2.jdbcx.JdbcDataSource url: jdbc:h2:mem:skywalking-oap-db user: sa ``` ## ElasticSearch 6 Active ElasticSearch 6 as storage, set storage provider to **elasticsearch**. **Required ElasticSearch 6.3.0 or higher. HTTP RestHighLevelClient is used to connect server.** Setting fragment example ```yaml storage: elasticsearch: # nameSpace: ${SW_NAMESPACE:""} # user: ${SW_ES_USER:""} # User needs to be set when Http Basic authentication is enabled # password: ${SW_ES_PASSWORD:""} # Password to be set when Http Basic authentication is enabled clusterNodes: ${SW_STORAGE_ES_CLUSTER_NODES:localhost:9200} indexShardsNumber: ${SW_STORAGE_ES_INDEX_SHARDS_NUMBER:2} indexReplicasNumber: ${SW_STORAGE_ES_INDEX_REPLICAS_NUMBER:0} # Batch process setting, refer to https://www.elastic.co/guide/en/elasticsearch/client/java-api/5.5/java-docs-bulk-processor.html bulkActions: ${SW_STORAGE_ES_BULK_ACTIONS:2000} # Execute the bulk every 2000 requests bulkSize: ${SW_STORAGE_ES_BULK_SIZE:20} # flush the bulk every 20mb flushInterval: ${SW_STORAGE_ES_FLUSH_INTERVAL:10} # flush the bulk every 10 seconds whatever the number of requests concurrentRequests: ${SW_STORAGE_ES_CONCURRENT_REQUESTS:2} # the number of concurrent requests ``` ### About Namespace When namespace is set, names of all indexes in ElasticSearch will use it as prefix. ### About Authentication We only support [basic authentication](https://www.elastic.co/guide/en/elasticsearch/client/java-rest/6.6/_basic_authentication.html). If you need that, you could set `user` and `password`. For how to enable http basic authentication, you could read this https://brudtkuhl.com/blog/securing-elasticsearch/ ## MySQL Active MySQL as storage, set storage provider to **mysql**. **NOTICE:** MySQL driver is NOT allowed in Apache official distribution and source codes. Please download MySQL driver by yourself. Copy the connection driver jar to `oap-libs`. ```yaml storage: mysql: ``` All connection related settings including link url, username and password are in `datasource-settings.properties`. This setting file follow [HikariCP](https://github.com/brettwooldridge/HikariCP) connection pool document. ## TiDB Currently tested TiDB in version 2.0.9, and Mysql Client driver in version 8.0.13. Active TiDB as storage, set storage provider to **mysql**. ```yaml storage: mysql: ``` All connection related settings including link url, username and password are in `datasource-settings.properties`. And these settings can refer to the configuration of *MySQL* above. ## ElasticSearch 5 ElasticSearch 5 is incompatible with ElasticSearch 6 Java client jar, so it could not be included in native distribution. [OpenSkywalking/SkyWalking-With-Es5x-Storage](https://github.com/OpenSkywalking/SkyWalking-With-Es5x-Storage) repo includes the distribution version. ## More storage solution extension Follow [Storage extension development guide](../../guides/storage-extention.md) in [Project Extensions document](../../guides/README.md#project-extensions) in development guide.