TimesTen内存数据库,可否一解Oracle所遇之困

2023-10-09 12:20

本文主要是介绍TimesTen内存数据库,可否一解Oracle所遇之困,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Oracle是家喻户晓的传统数据库厂商,虽然在她的领域目前还无敌手,但是整个传统数据库行业却受到NoSQL的严重挑战,在云计算和大数据时代,NoSQL不但百花齐放、产品丰富,而且能够更好的匹配不同数据处理场景,以开放、开源的趋势向世人诠释她的魅力。

关注“架构师技术联盟”微信公众号,直接回复“TimesTen”关键字,获取更多有关Oracle TimesTen架构分析资料。

Oracle也在逆境中如同其他传统IT厂商一样,寻求突破和转型,在云计算战略上也在步步紧跟,但是传统厂商的一大诟病就是有点历史包袱,体现在老客户、老产品、老市场;这使得他们不敢动大手笔、大创新。TimesTen算是Oracle比较符合时代发展的收购了,TimesTen虽然在各行各业都有成功案例,但是其规模和辐射效应远远没有达到人们的预期。

所以,个人主观认为,Oracle基于自身的优势,TimesTen和Oracle的结合可以擦出更亮的火花,而不该调整提高AWS、Azure平台用户的授权费用短期获利;软件定义时代,商业模式的创新也是必不可少的。同样是内存数据库,SAP HANA做的就非常不错。

谈起内存数据库,我们首先想到的应该是SAP HAHA,的确HANA在SAP应用上太广泛了,SAP公司也推出了HANA一体机和联合方案,包括HANA单节点、集群和TDI开放解决方案。但是HANA内存数据库主要是绑着SAP公司自己的软件玩,如ERP、CRM,SCM和PLM等等,对通用应用软件的支持不是强项。今天我们讨论的是另一个内存数据库,它叫Oracle TimesTen In-Memory Database内存数据库。

TimesTen 源于HP试验室,当时主要目的是针对电信网络应用,在1996年发布TimesTen第一个商用版本(TimesTen2.0),后来产品中增加Cache Connect组件,产品可以和Oracle无缝集成。Oracle 收购了内存中数据库软件的领先供应商TimesTen。Oracle 数据库与 TimesTen 数据库的结合为端到端数据管理提供了独有的单供应商解决方案。

Oracle TimesTen支持很多原生接口标准,如应用程序通过 JDBC或 ODBC接口发出 SQL命令。用于定义数据存储区和复制配置的语句也遵守 SQL 语法惯例。使用 SNMP发出标准化的系统管理警报。另外,Oracle TimesTen 还提供具有标准 JMS 接口的开放式事务日志 API (XLA) 来读取事务日志,XLA 是一个轻型“触发器”,用于创建响应数据库更新的应用程序。它还用于构建从Oracle TimesTen 到其他数据库系统的自定义数据复制。

TimesTen内存数据库架构

Oracle TimesTen在架构上由共享库、内存中数据结构、系统进程(后台程序、子后台程序、代理)管理程序和磁盘上的检查点和日志文件组成。

共享库包含SQL 操作的例程和相关函数,开发人员将这些库链接到应用程序并作为应用程序进程的一部分执行。TimesTen通过共享库(不同于常规的RDBMS链接库)和称作“MicroLogging”的专利算法,保护自身不受应用程序进程故障的影响。

内存中数据库在操作系统的共享内存段中维护,它包含所有用户数据、索引、系统目录、日志缓冲区、锁表和临时空间。

检查点和日志文件定期将数据存储区和事务日志的更改写入磁盘。检查点和日志文件使用普通的磁盘文件系统。可以将 Oracle TimesTen 配置为执行无磁盘操作。

一般情况,如果应用程序要求不能丢失更改,则在提交事务的过程中将把日志记录保存到磁盘上。否则,可不用频繁地将日志记录写入磁盘,而是与每次提交事务异步进行。日志记录起两个作用。首先,日志记录可以在系统发生故障后根据永久数据存储区恢复事务。其次,在共享访问模式下使用时,日志记录使 Oracle TimesTen 数据管理器可以检测和消除死锁。

Oracle TimesTen与RDBMS相比,内存数据库技术更加节省CPU 资源,并且避免了用于管理内存缓冲区并处理多个数据位置,对磁盘和内存的操作开销。

Oracle TimesTen产品组成

Oracle TimesTen 实时数据管理软件由三个基于内存中数据库、数据复制和高速缓存技术的产品组成,即一个产品和两个功能选项。

  • 内存优化关系数据库(TimesTen In-Memory Database)

是针对物理内存而特别设计优化的数据库。作为嵌入式数据库被部署在应用程序层中,它利用标准的 SQL 接口对完全位于物理内存中的数据存储区进行操作。

  • 内存中数据库 (IMDB) 技术

是Oracle TimesTen 产品的基础技术,关系数据库运行时数据都位于内存中。与完全高速缓存的RDBMS 相比,IMDB 技术避免了用于管理内存缓冲区并处理多个磁盘和内存数据的开销,对内存数据库来说,磁盘用于实现持久保存和恢复,而不是用作主要的数据库存储位置。

  • 数据复制技术

Oracle TimesTen In-Memory Database 的一个选项,它支持服务器间的实时数据复制,以获得高可用性和负载共享。数据复制配置可以是双机热备份 (active-standby) 或负载均衡 (active-active),可以使用异步或同步传输,对于相同表具有多个主服务器的情况,可以包含冲突检测和冲突解决以及在故障服务器恢复后自动重新同步。数据复制与 Cache Connect to Oracle 选项完全兼容。

支持异步和同步TimesTen 到 TimesTen复制,同步复制基于同步传送交易数据,在返回控制权给应用之前,提交的交易能确保被传送到远端节点,同步复制可以由应用系统在交易层面来进行控制“开启” 或“关闭”。

异步复制基于异步传送交易数据,非常快的应用响应时间,适合于需要高性能、低延迟的应用场景,异步复制流程大致如下。

在发送方提交交易后,依据应用系统的设置,交易日志被记录到日志缓冲区或同步写到磁盘日志文件。当日志缓冲区“满”了,交易日志会被写到磁盘的日志文件里面。然后复制代理向接收方发送这批交易信息。

接收方代理在data-store上执行这批交易,强制写磁盘交易日志文件。最后接收方代理向发送方发送确认响应,发送方代理更新日志文件的Bookmark。

另外,TimesTen支持很多丰富的特性优化数据复制,如压缩传送,压缩复制的信息,支持可用于广域网传送。主节点自动恢复,交易由主节点发起,但是没有执行成功,在主节点恢复后,远端节点可以主节点上重新执行失败的交易;基于时间戳的冲突检测与消除机制。

  • Cache Connect to Oracle特性

Oracle TimesTen In-Memory Database 的一个选项,它为位于应用程序层中的 Oracle 数据创建实时、可更新的高速缓存。它免除了后端系统的计算负担,并支持反应灵敏且可伸缩的实时应用程序。

Cache Connect to Oracle 能够将 Oracle 数据的子集(可以选择您需要装载的表或者指定表的某些列)加载到 TimesTen 中,无需任何编码就能够实现双向数据同步更新,从而实现和Oracle无缝集成。

需要被缓存到 TimesTen data store里的Oracle数据库的数据集合,称之为缓存组(Cache Group)。Oracle数据库的变化能自动刷新到TimesTen缓存组中。Autorefresh 是基于“快照”(snap-shot)的复制,Cache agent 执行自动刷新,对应用系统完全透明。

可更新缓存组支持以下特性,应用程序可以对高速缓存组执行读取和写入操作,可以自动或手动刷新高速缓存组(将 Oracle 数据库数据置于高速缓存组中),可以自动或手动清理高速缓存组(将高速缓存更新传播到 Oracle 表);可以自动跟踪对 Oracle 表或高速缓存组的更改。

Cache Connect to Oracle能够双向传播更新,并能够在故障之后自动重新同步数据;另外,它与TimesTen to TimesTen Replication 选项完全兼容。

Oracle TimesTen的兼容能力

TimesTen支持广泛的OS平台和CPU,支持HP-UX、IBM AIX、SUN Solaris和Suse、Redhat和Windows操作系统,支持PA-RISC、IA等RISC指令架构CPU和X86 CISC复杂指令体系架构CPU,具有非常强的兼容性。

Oracle TimesTen在指挥和控制系统以及证券交易系统的生产环境中部署使用,并在时间关键的行业和实时企业中发挥了出色的作用。全球范围内的数百家公司在生产应用程序中使用了 Oracle TimesTen,其中包括Amdocs、Aspect、Avaya、Cisco、Ericsson、JP Morgan、Lucent、Nokia和 Sprint等。

TimesTen提供多种模式的复制技术应用于异地数据容灾,并在表级别或数据存储区级别指定复制。复制可以是单向或双向的,从而实现了一个简单的热备用配置或负载平衡配置。

Oracle TimesTen 内存数据库通过嵌入到应用程序内部,从而消除了上下文切换和不必要的网络操作,在内存中管理数据、优化数据结构和访问算法,为位于应用程序层中的 Oracle 数据创建实时、可更新的高速缓存。它免除了后端系统的计算负担,并支持反应灵敏且可伸缩的实时应用程序。关注“架构师技术联盟”微信公众号,直接回复“TimesTen”关键字,获取更多有关Oracle TimesTen架构分析资料。

这篇关于TimesTen内存数据库,可否一解Oracle所遇之困的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/172800

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

深入理解数据库的 4NF:多值依赖与消除数据异常

在数据库设计中, "范式" 是一个常常被提到的重要概念。许多初学者在学习数据库设计时,经常听到第一范式(1NF)、第二范式(2NF)、第三范式(3NF)以及 BCNF(Boyce-Codd范式)。这些范式都旨在通过消除数据冗余和异常来优化数据库结构。然而,当我们谈到 4NF(第四范式)时,事情变得更加复杂。本文将带你深入了解 多值依赖 和 4NF,帮助你在数据库设计中消除更高级别的异常。 什么是

DM8数据库安装后配置

1 前言 在上篇文章中,我们已经成功将库装好。在安装完成后,为了能够更好地满足应用需求和保障系统的安全稳定运行,通常需要进行一些基本的配置。下面是一些常见的配置项: 数据库服务注册:默认包含14个功能模块,将这些模块注册成服务后,可以更好的启动和管理这些功能;基本的实例参数配置:契合应用场景和发挥系统的最大性能;备份:有备无患;… 2 注册实例服务 注册了实例服务后,可以使用系统服务管理,

速了解MySQL 数据库不同存储引擎

快速了解MySQL 数据库不同存储引擎 MySQL 提供了多种存储引擎,每种存储引擎都有其特定的特性和适用场景。了解这些存储引擎的特性,有助于在设计数据库时做出合理的选择。以下是 MySQL 中几种常用存储引擎的详细介绍。 1. InnoDB 特点: 事务支持:InnoDB 是一个支持 ACID(原子性、一致性、隔离性、持久性)事务的存储引擎。行级锁:使用行级锁来提高并发性,减少锁竞争

Oracle type (自定义类型的使用)

oracle - type   type定义: oracle中自定义数据类型 oracle中有基本的数据类型,如number,varchar2,date,numeric,float....但有时候我们需要特殊的格式, 如将name定义为(firstname,lastname)的形式,我们想把这个作为一个表的一列看待,这时候就要我们自己定义一个数据类型 格式 :create or repla

开源分布式数据库中间件

转自:https://www.csdn.net/article/2015-07-16/2825228 MyCat:开源分布式数据库中间件 为什么需要MyCat? 虽然云计算时代,传统数据库存在着先天性的弊端,但是NoSQL数据库又无法将其替代。如果传统数据易于扩展,可切分,就可以避免单机(单库)的性能缺陷。 MyCat的目标就是:低成本地将现有的单机数据库和应用平滑迁移到“云”端

ORACLE 11g 创建数据库时 Enterprise Manager配置失败的解决办法 无法打开OEM的解决办法

在win7 64位系统下安装oracle11g,在使用Database configuration Assistant创建数据库时,在创建到85%的时候报错,错误如下: 解决办法: 在listener.ora中增加对BlueAeri-PC或ip地址的侦听,具体步骤如下: 1.启动Net Manager,在“监听程序”--Listener下添加一个地址,主机名写计

Oracle Start With关键字

Oracle Start With关键字 前言 旨在记录一些Oracle使用中遇到的各种各样的问题. 同时希望能帮到和我遇到同样问题的人. Start With (树查询) 问题描述: 在数据库中, 有一种比较常见得 设计模式, 层级结构 设计模式, 具体到 Oracle table中, 字段特点如下: ID, DSC, PID; 三个字段, 分别表示 当前标识的 ID(主键), DSC 当