1.美图
2.简介
1H2 是一个用 Java 开发的嵌入式数据库,它本身只是一个类库
,即只有一个 jar 文件,可以直接嵌入到应用项目中。H2 主要有如下三个用途:
- 第一个用途,也是最常使用的用途就在于可以同应用程序打包在一起发布,这样可以非常方便地存储少量结构化数据。
- 第二个用途是用于单元测试。启动速度快,而且可以关闭持久化功能,每一个用例执行完随即还原到初始状态。
- 第三个用途是作为缓存,即当做内存数据库,作为NoSQL的一个补充。当某些场景下数据模型必须为关系型,可以拿它当Memcached使,作为后端MySQL/Oracle的一个缓冲层,缓存一些不经常变化但需要频繁访问的数据,比如字典表、权限表。
2.下载安装
2.1 下载
h2 数据库下载地址:http://www.h2database.com/html/main.html 或者 http://www.h2database.com/html/download.html
选择 “All Platforms” 版本,是一个压缩包,解压后即可使用既可用于 Windows 平台,也可用于 Linux 平台。
2.2 H2 目录结构
h2
|---bin
| |---h2-1.1.116.jar //H2数据库的jar包(驱动也在里面)
| |---h2.bat //Windows控制台启动脚本
| |---h2.sh //Linux控制台启动脚本
| |---h2w.bat //Windows控制台启动脚本(不带黑屏窗口)
|---docs //H2数据库的帮助文档(内有H2数据库的使用手册)
|---service //通过wrapper包装成服务。
|---src //H2数据库的源代码
|---build.bat //windows构建脚本
|---build.sh //linux构建脚本
3.管理终端
3.1 启动
进入H2 的 bin 目录,如果在 Window 环境下使用,可以运行 h2.bat 或 h2w.bat。区别只是后者是后台静默运行。
如果你在 Linux 环境下,可运行./h2.sh 文件来启动数据库服务。但不建议这样直接启动,因为还有一些参数可以设置。可进行如下修改:
- 复制h2.sh为h2_server.sh文件;
- 编辑h2_server.sh,如下:
# 原始
#!/bin/sh
dir=$(dirname "$0")
java -cp "$dir/h2-1.4.200.jar:$H2DRIVERS:$CLASSPATH" org.h2.tools.Console "$@"
# 修改为
#!/bin/sh
dir=$(dirname "$0")
java -cp "$dir/h2-1.4.200.jar:$H2DRIVERS:$CLASSPATH" org.h2.tools.Server -tcpAllowOthers -webAllowOthers -webPort 8082 "$@"
说明:
- org.h2.tools.Server: 以服务器模式启动
- -tcpAllowOthers: 允许远程机器通过TCP方式访问
- -webAllowOthers: 允许远程机器通过浏览器访问
- -webPort 8082: 默认的访问端口(8082为未被占用的端口,如果此端口已经被其他端口占用,则改为其他端口)
具体的运行方式
chmod修改文件权限;
(base) lcc@lcc bin$ chmod 777 h2_server.sh
(base) lcc@lcc bin$
先直接启动
(base) lcc@lcc bin$ ./h2_server.sh
TCP server running at tcp://localhost:9092 (others can connect)
PG server running at pg://localhost:5435 (only local connections)
Web Console server running at http://localhost:8082 (others can connect)
输入nohup ./h2_server.sh &
回车。这样可以后台运行。
(base) lcc@lcc bin$ nohup ./h2_server.sh &
[1] 7695
(base) lcc@lcc bin$ appending output to nohup.out
(base) lcc@lcc bin$
nohup 命令可以在你退出账户之后继续运行相应的进程。nohup 就是不挂起的意思(no hang up)。& 表示让该进程实现后台运行。该命令的一般形式为:
# nohup command &
系统会进入:
或者自己打开浏览器,输入地址:http://localhost:8082
访问 H2 数据库的 Web Console。这里就需要说明一下 ~
这个符号在window操作系统下代表什么意思,在Window操作系统下,"~"这个符号代表的就是当前登录到操作系统的用户对应的用户目录,与 Linux 系统中的意义相同,代表用户家目录。
最上方可以选择 language,可以进行语言切换。如切换成中文:
点击蓝色字体配置,可以跳转到配置H2数据库的另一个页面,点击工具,会给你提供一堆对H2数据库操作的功能,比如:备份、还原、恢复、集群、运行脚本、删除文件等等。点击帮助,会提示一些关于 H2 数据库使用的帮助信息。接下来就是最重要的配置数据库连接信息,驱动类和 JDBC URL 是默认的,如果你想创建一个新的数据库,直接修改 jdbc:h2:[输入你想创建的数据库文件的路径],就可以为你自动创建一个新的数据库(在指定路径下会创建对应的数据库文件 xxxx.mv.db),用户名密码由用户自行定义,连接数据库之前还可以点击测试连接,测试是否可以正确连接。
什么都不配置会直接报错
输入账号和密码(默认账号是sa,密码为空),进入数据库。
但是仍然报错,除非开启自动建库。
参考:https://www.jianshu.com/p/39f92797f9d2