hsqldb in Eucalyptus
Eucalyptus中数据库
Eucalyptus中数据库为hsqldb
Hsqldb简介
HSQLDB是一个轻量级的纯Java开发的开放源代码的关系数据库系统,其体积小,占用空间小,使用简单,支持内存运行方式等特点。
Eucalyptus中数据库
Eucalyptus中数据库为hsqldb
Hsqldb简介
HSQLDB是一个轻量级的纯Java开发的开放源代码的关系数据库系统,其体积小,占用空间小,使用简单,支持内存运行方式等特点。
Hsqldb三种运行模式:
HSqlDB不适合管理大型数据,例如百万数量级记录的数据库应用。HSQLDB简介它具有Server模式,进程内模式(In-Process)和内存模式(Memory-Only)三种。运行Hsqldb需要hsqldb.jar包, 它包含了一些组件和程序。 在其官网可以获得最新的程序源代码及jar包文件,也可以直接从eucalyptus\eucalyptus-2.0.0\clc\lib拷贝hsqldb-1.8.0.10.jar。 接下来我们对Hsqldb的三种模式进行简单介绍,同时包括部分工具的启动的方式。
一、 Server模式
Server模式提供了最大的可访问性。应用程序(客户端)通过Hsqldb的JDBC驱动连接服务器。在服务器模式中,服务器在运行的时候可以被指定为最多10个数据库。根据客户端和服务器之间通信协议的不同,Server模式可以分为以下三种:
1、 Hsqldb Serve 这种模式是首选的也是最快的。它采用HSQLDB专有的通信协议。启动服务器需要编写批处理命令。Hsqldb提供的所有工具都能以java class归档文件(也就是jar)的标准方式运行。假如hsqldb.jar位于相对于当前路径的../lib下面。我们的命令将这样写:
java -cp ../lib/hsqldb.jar org.hsqldb.Server-database.0 mydb -dbname.0 demoDB
现在你可能会疑惑,[-database.0 ]、[dbname.0]为什么在后面加[0]。_… …我们不是在前面说服务模式运行的时候可以指定10个数据库吗,如有多个数据库,则继续写命令行参数-database.1 aa -dbname.1 aa -database.2bb-dbname.2 bb … … 新建文本文件保存上面命令,文件名可以随意,将后缀名改成bat,然后直接执行批处理文件即可。在以后介绍的执行启动工具的命令采用同样方法。 上面启动服务器的命令启动了带有一个(默认为一个数据库)数据库的服务器,这个数据库是一个名为”mydb.*”文件,这些文件就是mydb.Properties、mydb.script、mydb.log等文件。其中demoDB是mydb的别名,可在连接数据库时使用。
2、 Hsqldb Web Server 这种模式只能用在通过HTTP协议访问数据库服务器主机,采用这种模式唯一的原因是客户端或服务器端的防火墙对数据库对网络连接强加了限制。其他情况下,这种模式不推荐被使用。 运行web服务器的时候,只要将刚才命令行中的主类(main class)替换成:org.hsqldb.WebServer
3、 Hsqldb Servlet 这种模式和WebServer一样都采用HTTP协议,当如Tomcat或Resin等servlet引擎(或应用服务器)提供数据库的访问时,可以使用这种模式。但是Servlet模式不能脱离servlet引擎独立启动。为了提供数据库的连接,必须将HSQLDB.jar中的hsqlServlet类放置在应用服务器的相应位置。 Web Server和Servlet模式都只能在客户端通过JDBC驱动来访问。Servlet模式只能启动一个单独的数据库。请注意做为应用程序服务器的数据库引擎通常不使用这种模式。 连接到以Server模式运行的数据库 当HSQLDB服务器运行时,客户端程序就可以通过hsqldb.jar中带有的HSQLDB JDBC Driver连接数据库。 java代码 try{ Class.forName(“org.hsqldb.jdbcDriver”) ; }catch(ClassNotFoundExceptione){ e.printStackTrace(); } Connectionc = DriverManager.getConnection(“jdbc:hsqldb:hsql:localhost/xdb”, “sa”, ””);
hsqldb的默认用户是sa密码为空。修改默认密码的方法我们将在工具使用部分做出介绍。
二、 In-Process模式
In-Process模式又称Standalone模式。这种模式下,数据库引擎作为应用程序的一部分在同一个JVM中运行。对于一些应用程序来说,这种模式因为数据不用转换和通过网络的传送而使得速度更快一些。其主要的缺点就是默认的不能从应用程序外连接到数据库。所以当应用程序正在运行的时候,你不能使用类似于Database Manager的外部工具来查看数据库的内容。在1.8.0版本中,你可以从同一个JVM的一个线程里面来运行一个服务器实例,从而可以提供外部连接来访问你的In-Process数据库。 推荐的使用In-Process模式方式是:开发的时候为数据库使用一个HSQLDB 服务器实例,然后在部属的时候转换到In-Process内模式。 一个In-Process模式数据库是从JDBC语句开始启动的,在连接URL中带有指定的数据库文件路径作为JDBC的一部分。例如,假如数据库名称为testdb,它的数据库文件位于与确定的运行应用程序命令相同的目录下,下面的代码可以用来连接数据库: Connection c = DriverManager.getConnection(“jdbc:hsqldb:file:testdb”, “sa”, ””); 数据库文件的路径格式在Linux主机和Windows主机上都被指定采用前斜线(”/“)。所以相对路径或者是相对于相同分区下相同目录路径的表达方式是一致的。使用相对路径的时候,这些路径表示的是相对于用于启动JVM的shell命令的执行路径。
三、Memry-Only数据库
Memory-Only数据库不是持久化的而是全部在随机访问的内存中。因为没有任何信息写在磁盘上。这种模式通过mem:协议的方式来指定: Connection c =DriverManager.getConnection(“jdbc:hsqldb:mem:dbName”, “sa”, ””);
你也可以在server.properties中指定相同的URL来运行一个Memory-Only(仅处于内存中)服务器实例。 注意事项:当一个服务器实例启动或者建立一个in-process数据库连接的时候,如果指定的路径没有数据库存在,那么就会创建一个新的空的数据库。这个特点的副作用就是让那些新用户产生疑惑。在指定连接已存在的数据库路径的时候,如果出现了什么错误的话,就会建立一个指向新数据库的连接。为了解决这个问题,你可以指定一个连接属性ifexists=true只允许和已存在的数据库建立连接而避免创建新的数据库,如果数据库不存在的话,getConnection()方法将会抛出异常。
表單的頂端
表單的底部
还原eucalyptus中数据库
eucalyptus中数据库的位置
默认安装好的eucalyptus的数据库在/var/lib/eucalyptus/db 中,拷贝这个文件夹出来,打开”*.script”文件,找到CREATE USER SA PASSWORD,将后面的密码用””代替,清除密码
开启数据库
从eucalyptus\eucalyptus-2.0.0\clc\lib拷贝hsqldb-1.8.0.10.jar到这个目录下,在终端输入:
java –cphsqldb-1.8.0.10.jarorg.hsqldb.util.DatabaseManager
出现如下界面:
选Standalone模式,在URL中输入一个数据库名称,如:
jdbc:hsqldb:file:eucalyptus_auth
点击”OK”,进入如下界面:
在中间的空白处可以输入sql语句