ShardingSphere example.
Example for 1.x please see tags in https://github.com/apache/incubator-shardingsphere/tree/${tag}/sharding-jdbc-example
Example for 2.x or 3.x please see tags in https://github.com/apache/incubator-shardingsphere-example/tree/${tag}
Please do not use dev
branch to run your example, example of dev
branch is not released yet.
The manual schema initial script is in https://github.com/apache/incubator-shardingsphere-example/blob/dev/src/resources/manual_schema.sql
,
please execute it before you first run the example.
Please make sure master-slave data sync on MySQL is running correctly. Otherwise this example will query empty data from slave.
before we use docker compose, please install docker first : https://docs.docker.com/compose/install/
- access the docker folder (cd docker/sharding-jdbc/sharding)
- launch the environment by docker compose (docker-compose up -d)
- access mysql / etcd / zookeeper as you want
- if there is conflict on port, just modify the mapper port in docker-compose.yml and then launch docker compose again(docker-compose up -d)
- if you want to stop these environment, use command docker-compose down
- access the docker folder (cd docker/sharding-proxy/sharding)
- launch the environment by docker compose (docker-compose up -d)
- access proxy by
mysql -h127.0.0.1 -P13308 -proot -uroot
- if there is conflict on port, just modify the mapper port in docker-compose.yml and then launch docker compose again(docker-compose up -d)
- if you want to stop these environment, use command docker-compose down
to clean the docker container , you could use docker rm docker ps -a -q
(be careful)
sharding-sphere-example
├── example-common
│ ├── config-utility
│ ├── repository-api
│ ├── repository-jdbc
│ ├── repository-jpa
│ └── repository-mybatis
├── sharding-jdbc-example
│ ├── orchestration-example
│ │ ├── orchestration-raw-jdbc-example
│ │ ├── orchestration-spring-boot-example
│ │ └── orchestration-spring-namespace-example
│ ├── sharding-example
│ │ ├── sharding-raw-jdbc-example
│ │ ├── sharding-spring-boot-jpa-example
│ │ ├── sharding-spring-boot-mybatis-example
│ │ ├── sharding-spring-namespace-jpa-example
│ │ └── sharding-spring-namespace-mybatis-example
│ └── transaction-example
│ ├── transaction-2pc-xa-example
│ └── transaction-base-saga-example
├── sharding-proxy-example
│ └── sharding-proxy-boot-mybatis-example
└── src/resources
└── manual_schema.sql
- sharding databases
- sharding tables
- sharding databases and tables
- master-slave
- sharding & master-slave
you can get more detail from sharding-example
-
local zookeeper/etcd & sharding
local sharding configuration can override the configuration of zookeeper/etcd.
-
cloud zookeeper/etcd & sharding
shardingsphere will load the sharding configuration form zookeeper/etcd directly.
you can get more detail from orchestration-example
- 2pc-xa transaction
- base-saga transaction
you can get more detail from transaction-example
we will add hint example recently.
we will add none-sharding example recently.
we will add broadcast-table example recently.
we will add APM example recently.
we prefer to add encrypt & decrypt example recently.
we prefer to add a docker base example recently.