Introduction to the

If you contact ShardingSphere-Proxy for the first time, please check the official introduction

After reading it, try to explain proxy in your own words:

  • From the point of view of developers, proxy basically achieves no user awareness and little intrusion into code, making it as simple and convenient to use as a common database
  • Compared to ShardingSphere-JDBC, proxy functions at the ORM layer and is essentially a proxy service: user ->proxy-> database

So much for now, here’s a trip to stomp pits…

Start the ShardingSphere – Proxy

Based on the development environment prepared in the previous article (ShardingSphere code clone to the local), the blogger chose to directly modify the local configuration file and start the Bootstrap mode to start the local proxy service.

Specific steps

1. Modify the configuration file

Project: shardingsphere – proxy – the bootstrap

Yaml, config-sharding.yaml, config-readwrite-splitting.yaml, config-encrypt.yaml

Example:

Let go of the comment configuration in server.yaml and modify SQL-show for later debugging

rules: - ! AUTHORITY users: - root@:root - sharding@:sharding provider: type: NATIVE props: max-connections-size-per-query: 1 executor-size: 16 # Infinite by default. proxy-frontend-flush-threshold: 128 # The default value is 128. # LOCAL: Proxy will run with LOCAL transaction. # XA: Proxy will run with XA transaction. # BASE: Proxy will run with B.A.S.E transaction. proxy-transaction-type: LOCAL proxy-opentracing-enabled: false proxy-hint-enabled: false sql-show: true check-table-metadata-enabled: falseCopy the code

Release the comment configuration in config-sharding.yaml

SchemaName: sharding_db dataSources: ds_0: url: JDBC: mysql: / / 127.0.0.1:3306 / demo_ds_0? serverTimezone=UTC&useSSL=false username: root password: connectionTimeoutMilliseconds: 30000 idleTimeoutMilliseconds: 60000, 1800000: maxLifetimeMilliseconds maxPoolSize: 50 minPoolSize: 1 ds_1: url: JDBC: mysql: / / 127.0.0.1:3306 / demo_ds_1? serverTimezone=UTC&useSSL=false username: root password: connectionTimeoutMilliseconds: 30000 idleTimeoutMilliseconds: 60000 maxLifetimeMilliseconds: 1800000 maxPoolSize: 50 minPoolSize: 1Copy the code

Pay attention to

In the config-shardingyaml file, there is schemaName sharding_db, which is the logical library name of sharding policy. It will be used when the example project is started and the policy is verified.

Config-readwrite-splitter. yaml and config-encrypt.yaml are also processed in the same way

2. Start the Bootstrap

3. Navicat tests the connection

Before starting the proxy service:

After the proxy service is started:

Therefore, for the user, after proxy takes effect, it is equivalent to a database service!

Run the example

Data fragmentation

1. Initialize the database

CREATE SCHEMA IF NOT EXISTS demo_ds_0;
CREATE SCHEMA IF NOT EXISTS demo_ds_1;
Copy the code

2. Modify the project configuration file

Project: shardingsphere – proxy – the boot – mybatis – example

File path: SRC \main\resources\application.properties

Modified as follows:

mybatis.config-location=classpath:META-INF/mybatis-config.xml spring.datasource.type=com.zaxxer.hikari.HikariDataSource spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3307/sharding_db? useServerPrepStmts=true&cachePrepStmts=true spring.datasource.username=root spring.datasource.password=rootCopy the code

Note that the IP address and port of the database are local proxy services. The database uses the logical database Sharding_DB, which corresponds to data fragments

3. Execute use cases

Comment out the delete and drop operations in the code for a better view:

Run ProxySpringBootStarterExample

4. Observe the results

The console logs of the example project are normal:

To check the database, the order data does realize the table:

The console log of the proxy service shows that the sharding policy is implemented:

Reading and writing separation

1. Initialize the database

CREATE SCHEMA IF NOT EXISTS demo_write_ds;
CREATE SCHEMA IF NOT EXISTS demo_read_ds_0;
CREATE SCHEMA IF NOT EXISTS demo_read_ds_1;

CREATE TABLE IF NOT EXISTS demo_read_ds_0.t_order (order_id BIGINT NOT NULL AUTO_INCREMENT, user_id INT NOT NULL, status VARCHAR(50), PRIMARY KEY (order_id));
CREATE TABLE IF NOT EXISTS demo_read_ds_1.t_order (order_id BIGINT NOT NULL AUTO_INCREMENT, user_id INT NOT NULL, status VARCHAR(50), PRIMARY KEY (order_id));
CREATE TABLE IF NOT EXISTS demo_read_ds_0.t_order_item (order_item_id BIGINT NOT NULL AUTO_INCREMENT, order_id BIGINT NOT NULL, user_id INT NOT NULL, status VARCHAR(50), PRIMARY KEY (order_item_id));
CREATE TABLE IF NOT EXISTS demo_read_ds_1.t_order_item (order_item_id BIGINT NOT NULL AUTO_INCREMENT, order_id BIGINT NOT NULL, user_id INT NOT NULL, status VARCHAR(50), PRIMARY KEY (order_item_id));
Copy the code

2. Modify the project configuration file

Readwrite-splitting_db: splitting_db: splitting_db

mybatis.config-location=classpath:META-INF/mybatis-config.xml spring.datasource.type=com.zaxxer.hikari.HikariDataSource spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3307/readwrite-splitting_db? useServerPrepStmts=true&cachePrepStmts=true spring.datasource.username=root spring.datasource.password=rootCopy the code

3. Execute use cases

Same as above

4. Observe the results

If you focus on the console log of the proxy service, you can see that the read and write go to different libraries

encryption

1. Initialize the database

CREATE SCHEMA IF NOT EXISTS demo_ds_0;
CREATE SCHEMA IF NOT EXISTS demo_ds_1;
Copy the code

2. Modify the project configuration file

As above, it is important to note that the logical library is changed to: encrypt_DB

mybatis.config-location=classpath:META-INF/mybatis-config.xml spring.datasource.type=com.zaxxer.hikari.HikariDataSource spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3307/encrypt_db? useServerPrepStmts=true&cachePrepStmts=true spring.datasource.username=root spring.datasource.password=rootCopy the code

3. Execute use cases

Same as above

4. Observe the results

From the proxy service console log, you can see that the project is executing normally, but the data is not encrypted.

Encryption is not effective pit, still need to fill (today is too late, later find time to test a.

(Updated at 2021.08.25, to fill in the hole)

Yaml configuration in config-encrypt.yaml and the description of encryption configuration items in official documents show that data is not encrypted because configuration items are not correctly filled in. O (╯ / ╰) o

Quickly change a (pay attention to the encrypted field data type, with encrypted data type is consistent, this step to choose the appropriate algorithm)

End result:

conclusion

Compared with JDBC on the first day, proxy debugging is much smoother, and I still need to make persistent efforts!!

The process of stepping on pits also revealed a lot of problems:

  1. I didn’t have enough preparation, either to read the document thoroughly or to think about the content of the document carefully, so I made too many stupid mistakes (many of which could have been avoided if I was careful enough).
  2. Only in the process of tuning, no further sink to consider the realization of the principle