TiKV Java Client
Go to file
Jia Fan c12047a026
[to #788] Reduce the number of ObjectMapper creations to improve performance (#787)
Signed-off-by: Jia Fan <fanjiaeminem@qq.com>
2025-03-29 18:39:33 +08:00
.github [close #772] Fix flaky integration tests (#770) 2023-10-07 16:01:36 +08:00
dev [to #555] enable api v2 (#575) 2022-06-02 16:33:28 +08:00
docs [close #666] Fix some issues in example and README (#667) 2022-12-02 11:57:10 +08:00
metrics/grafana [close #671] remove shadowing of netty && grpc (#781) 2024-03-28 08:12:38 +00:00
scripts [to #421] add a python script to analyze slow log stats (#527) 2022-02-22 15:52:02 +08:00
src [to #788] Reduce the number of ObjectMapper creations to improve performance (#787) 2025-03-29 18:39:33 +08:00
.gitignore [to #348] Add javadoc (#447) 2021-12-28 09:33:26 +08:00
LICENSE init 2018-11-15 17:11:42 +08:00
Makefile [close #467] clean pb repo and target while make clean (#468) 2022-01-04 18:17:05 +08:00
README.md [close #666] Fix some issues in example and README (#667) 2022-12-02 11:57:10 +08:00
pom.xml [close #782] bump grpc to 1.60.0 (#783) 2024-03-28 08:47:59 +00:00

README.md

Maven Central Slack codecov

TiKV JAVA Client

A Java client for TiKV. It is supposed to:

  • Communicate via gRPC
  • Talk to Placement Driver searching for a region
  • Talk to TiKV for reading/writing data

Quick Start

TiKV Java Client is designed to communicate with PD and TiKV, please run PD and TiKV in advance.

Build Java client from source file:

mvn clean install -Dmaven.test.skip=true

Add maven dependency to pom.xml:

<dependency>
	<groupId>org.tikv</groupId>
	<artifactId>tikv-client-java</artifactId>
	<version>3.3.0</version>
</dependency>

Create a transactional KVClient and communicates with TiKV:

import org.tikv.common.TiConfiguration;
import org.tikv.common.TiSession;
import org.tikv.txn.KVClient;

public class Main {
	public static void main(String[] args) throws Exception {
		TiConfiguration conf = TiConfiguration.createDefault(YOUR_PD_ADDRESSES);
		TiSession session = TiSession.create(conf);
		KVClient client = session.createKVClient();
	}
}

Or create a RawKVClient if you don't need the transaction semantic:

import org.tikv.common.TiConfiguration;
import org.tikv.common.TiSession;
import org.tikv.raw.RawKVClient;

public class Main {
	public static void main(String[] args) throws Exception {
		TiConfiguration conf = TiConfiguration.createRawDefault(YOUR_PD_ADDRESSES);
		TiSession session = TiSession.create(conf);
		RawKVClient client = session.createRawClient();
	}
}

Find more demo in TiKV Java Client User Documents

Documentation

See Java Client Documents for references about how to config and monitor Java Client.

A Maven site is also available. It includes:

  1. API reference
  2. Spotbugs Reports
  3. Source Code Xref

Community

Forum

Contribute to TiKV Java Client

See Contribution Guide for references about how to contribute to this project.

License

Apache 2.0 license. See the LICENSE file for details.