107 строки
5.3 KiB
Markdown
107 строки
5.3 KiB
Markdown
# Microsoft Azure Kusto (Azure Data Explorer) SDK for Java
|
|
|
|
![Released Version](https://img.shields.io/maven-central/v/com.microsoft.azure.kusto/kusto-ingest.svg)
|
|
|
|
|
|
master: [![Build status](https://msazure.visualstudio.com/One/_apis/build/status/Custom/Kusto/azure-kusto-java-sdk%20ci?branchName=master)](https://msazure.visualstudio.com/One/_build/latest?definitionId=57651)
|
|
![Github Actions Build](https://github.com/Azure/azure-kusto-java/actions/workflows/build.yml/badge.svg)
|
|
|
|
|
|
This is the Microsoft Azure Kusto client library which allows communication with Kusto to bring data in (ingest) and query information already stored in the database.
|
|
This library contains 3 different modules:
|
|
- data: The main client that allows interaction with Kusto, including creating a connection, issuing (control) commands and querying data
|
|
- ingest: Provides an easy way to bring data into Kusto
|
|
- quickstart: Self-contained, configurable and runnable sample app for easily getting started with the SDK
|
|
- samples: Sample code implementing various scenarios
|
|
|
|
# Install
|
|
|
|
## Maven
|
|
|
|
This method is the easiest to follow, just add the following dependency to your pom.xml (with the right version tag from maven central):
|
|
```xml
|
|
<dependency>
|
|
<groupId>com.microsoft.azure.kusto</groupId>
|
|
<artifactId>kusto-ingest</artifactId>
|
|
<version>[see badge below]</version>
|
|
</dependency>
|
|
```
|
|
[![Maven Central](https://maven-badges.herokuapp.com/maven-central/com.microsoft.azure.kusto/kusto-ingest/badge.svg?style=plastic)](https://maven-badges.herokuapp.com/maven-central/com.microsoft.azure.kusto/kusto-ingest)
|
|
|
|
|
|
## Clone
|
|
Download the source code, compile and install locally.
|
|
|
|
One way to do this is by using maven like in the following example:
|
|
```
|
|
git clone git://github.com/Azure/azure-kusto-java.git
|
|
cd azure-kusto-java
|
|
mvn install
|
|
```
|
|
|
|
# Prerequisites
|
|
|
|
- A Java Developer Kit (JDK), version 11 or later
|
|
- Maven
|
|
|
|
# Samples
|
|
|
|
- [Execute a query](samples/README.md#execute-query-sample)
|
|
- [Ingest a file](samples/README.md#file-ingestion-sample)
|
|
- [Check status of an ingest operation](samples/README.md#query-table-status-sample)
|
|
|
|
## Using A Proxy
|
|
The SDK includes support for the built-in proxy system properties in java.
|
|
For example, when the address of your proxy server is 1.2.3.4:8989, you can run:
|
|
`java -ea -Dhttp.proxyHost=1.2.34 -Dhttp.proxyPort=8989 -Dhttps.proxyHost=1.2.3.4 -Dhttps.proxyPort=8989`
|
|
And the SDK will know to use these values automatically.
|
|
|
|
Alternatively, you can define a proxy programmatically when creating a client, using `HttpClientProperties`:
|
|
```java
|
|
HttpClientProperties httpClientProperties = HttpClientProperties.builder()
|
|
.proxy(new ProxyOptions(ProxyOptions.Type.HTTP, new InetSocketAddress("myproxy.contoso.com", 8080)))
|
|
.build();
|
|
|
|
Client = ClientFactory.createClient(<engine_connection_string>, httpClientProperties);
|
|
// Or for DM:
|
|
IngestClient ingestClient = IngestClientFactory.createClient(<dm_connection_string>, httpClientProperties)
|
|
|
|
```
|
|
|
|
## Best Practices
|
|
See the SDK [best practices guide](https://docs.microsoft.com/azure/data-explorer/kusto/api/netfx/kusto-ingest-best-practices), which though written for the .NET SDK, applies similarly here.
|
|
|
|
# Need Support?
|
|
- **Have a feature request for SDKs?** Please post it on [User Voice](https://feedback.azure.com/forums/915733-azure-data-explorer) to help us prioritize
|
|
- **Have a technical question?** Ask on [Stack Overflow with tag "azure-data-explorer"](https://stackoverflow.com/questions/tagged/azure-data-explorer)
|
|
- **Need Support?** Every customer with an active Azure subscription has access to [support](https://docs.microsoft.com/en-us/azure/azure-supportability/how-to-create-azure-support-request) with guaranteed response time. Consider submitting a ticket and get assistance from Microsoft support team
|
|
- **Found a bug?** Please help us fix it by thoroughly documenting it and [filing an issue](https://github.com/Azure/azure-kusto-java/issues/new).
|
|
|
|
# Looking for SDKs for other languages/platforms?
|
|
- [Node](https://github.com/azure/azure-kusto-node)
|
|
- [Python](https://github.com/azure/azure-kusto-python)
|
|
- [.NET](https://docs.microsoft.com/en-us/azure/kusto/api/netfx/about-the-sdk)
|
|
|
|
# Contributing
|
|
|
|
This project welcomes contributions and suggestions. Most contributions require you to agree to a
|
|
Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us
|
|
the rights to use your contribution. For details, visit https://cla.microsoft.com.
|
|
|
|
When you submit a pull request, a CLA-bot will automatically determine whether you need to provide
|
|
a CLA and decorate the PR appropriately (e.g., label, comment). Simply follow the instructions
|
|
provided by the bot. You will only need to do this once across all repos using our CLA.
|
|
|
|
This project has adopted the [Microsoft Open Source Code of Conduct](https://opensource.microsoft.com/codeofconduct/).
|
|
For more information see the [Code of Conduct FAQ](https://opensource.microsoft.com/codeofconduct/faq/) or
|
|
contact [opencode@microsoft.com](mailto:opencode@microsoft.com) with any additional questions or comments.
|
|
|
|
## Formatting
|
|
The code in this project is formatted using formatter-maven-plugin.
|
|
Code that isn't formatted will not be accepted.
|
|
|
|
To format your code, run the following command:
|
|
`mvn formatter:format`
|
|
|
|
It is also recommended importing the format file `kusto-style.xml` into your editor (the file is in the eclipse xml format).
|