H2官网下载最新的安装文件:http://www.h2database.com/html/main.html
bin目录下有启动脚本和jar包。
搭建H2集群,需要使H2数据库运行在server模式下,也就是在启动的时候调用:org.h2.tools.Server,具体脚本如下:
#!/bin/sh
dir=$(dirname "$0")
java -cp "$dir/h2-1.4.200.jar:$H2DRIVERS:$CLASSPATH" org.h2.tools.Server -tcpAllowOthers -tcpPort 9101 -webAllowOthers -webPort 8081 "$@"
其中:
-tcpAllowOthers: 允许远程机器通过TCP方式访问
-tcpPort: TCP访问时的端口
-webAllowOthers: 允许远程机器通过浏览器访问
-webPort 8081: web端访问的端口
将安装包,上传到机器1上(192.168.61.95)。将以上的shell脚本内容,保存到h2-server.sh文件,并放到bin目录下。然后启动h2-server.sh脚本
eyecool@eyecool-OptiPlex-7060:~/h2/bin$ ./h2-server.sh
TCP server running at tcp://localhost:9101 (others can connect)
PG server running at pg://localhost:5435 (only local connections)
Web Console server running at http://localhost:8081 (others can connect)
将安装包,上传到机器1上(192.168.63.59)。将以上的shell脚本内容,保存到h2-server.sh文件,并放到bin目录下。然后启动h2-server.sh脚本
[zhanglei@docker1 bin]$ ./h2-server.sh
TCP server running at tcp://192.168.63.59:9101 (others can connect)
PG server running at pg://192.168.63.59:5435 (only local connections)
Web Console server running at http://192.168.63.59:8081 (others can connect)
H2集群,使用CreateCluster工具,创建一个数据库副本并分到另外一台机器上,并初始化集群。
java -cp h2-1.4.200.jar org.h2.tools.CreateCluster -urlSource "jdbc:h2:tcp://192.168.61.95:9101/~/test" -urlTarget "jdbc:h2:tcp://192.168.63.59:9101/~/test" -user "sa" -serverList "192.168.61.95:9101,192.168.63.59:9101"
其中,
urlSource,主数据库
urlTarget,副本数据库
注意
Server1停掉后,server2能继续提供数据库服务,集群工具自动不会同步数据,此时只能靠手工删除server1中的数据库,把server2的复制过去,重启集群服务(重新执行1.3的命令)。
集群的时候,如果server2,停掉后,server1能继续提供数据库服务,在server2删掉数据文件后重启,需要重新在用集群工具建立集群,此时需要注意urlSource 应为server1,urlTarget 应为server2。
其中:
saved settings,选择server模式,
JDBC URL: jdbc:h2:tcp://192.168.61.95:9101,192.168.63.59:9101/~/test3
输入用户名和密码,点击connection进行登录。
以springboot项目为例,需要修改application.yml文件:
spring:
datasource:
driver-class-name: org.h2.Driver
# 第一次启动需要放开
#schema: classpath:db/schema-h2.sql
#data: classpath:db/data-h2.sql
#以下是H2集群模式
url: jdbc:h2:tcp://192.168.61.95:9101,192.168.63.59:9101/~/test4
username: test
password: test
其中:
schema: 指定的数据库脚本,在项目启动时,会自动执行
data: 指定的数据库脚本(初始化数据),会自动执行,
以上两个参数,在项目首次启动完成后(也就是在创建完成数据库后),需要注释掉,否则会报错。
H2数据库在先前的版本时,会自动创建数据库,不需事先创建,但是在1.4.x版本后,默认是不允许自动创建的。此时我们可以在启动脚本时,增加参数:-ifNotExists
#!/bin/sh
dir=$(dirname "$0")
java -cp "$dir/h2-1.4.200.jar:$H2DRIVERS:$CLASSPATH" org.h2.tools.Server -tcpAllowOthers -tcpPort 9101 -webAllowOthers -webPort 9999 -ifNotExists "$@"
H2在server模式下,支持以下几种JDBC书写方式
jdbc:h2:tcp://<server>[:<port>]/[<path>]<databaseName>
jdbc:h2:tcp://localhost/~/test
jdbc:h2:tcp://dbserv:8084/~/sample
jdbc:h2:tcp://localhost/mem:test
其中,~为系统用户登录时默认的目录,也可以使用绝对路径
H2在集群模式下,在创建表的主键时,是不支持AUTO_INCREMENT约束的。
在官网上,可以查看到命令的具体使用方式