H2集群部署

1、H2集群部署

H2官网下载最新的安装文件:http://www.h2database.com/html/main.html

解压后,目录如下:
H2集群部署_第1张图片

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.1 机器1

将安装包,上传到机器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.2 机器2

将安装包,上传到机器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)

1.3 集群

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。

1.4 访问方式

1.4.1 web访问

集群搭建好后,可以通过web浏览器方式进行访问,具体如下:
H2集群部署_第2张图片

其中:

saved settings,选择server模式,

JDBC URL: jdbc:h2:tcp://192.168.61.95:9101,192.168.63.59:9101/~/test3

输入用户名和密码,点击connection进行登录。

1.4.2 java方式

以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: 指定的数据库脚本(初始化数据),会自动执行,

以上两个参数,在项目首次启动完成后(也就是在创建完成数据库后),需要注释掉,否则会报错。

2、 H2知识点

2.1 自动创建

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 "$@"

2.2 JDBC模式(TCP)

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

其中,~为系统用户登录时默认的目录,也可以使用绝对路径

2.3 AUTO_INCREMENT

H2在集群模式下,在创建表的主键时,是不支持AUTO_INCREMENT约束的。

2.4 常用命令

在官网上,可以查看到命令的具体使用方式

H2集群部署_第3张图片

你可能感兴趣的:(研发管理,数据库)