TimesTen 应用层数据库缓存学习:17. 全局数据缓存(cache grid)的高可用性

本文主要是介绍TimesTen 应用层数据库缓存学习:17. 全局数据缓存(cache grid)的高可用性,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概述

本文有两个目的:
1. 介绍TimesTen Global Cache Grid的高可用性
2. 给出了一个简单的建立和清理Global Cache Grid的过程,前面已经有一篇文章: TimesTen 应用层数据库缓存学习:13. 全局数据缓存(cache grid),但那个Cache Group太复杂

建立一个简单的Global Cache Grid

首先建立两个TimesTen instance,一个为tt1122, 一个为ttnew。
之所以建立两个实例,是为了停instance方便。现在还没有找到一个方法来停DB。

详细的过程如下:
在tt1122实例上,建立cachedb1的DSN

[cachedb1]
Driver=/home/oracle/TimesTen/tt1122/lib/libtten.so
DataStore=/home/oracle/TimesTen/tt1122/info/DemoDataStore/cachedb1
PermSize=32
TempSize=64
LogFileSize=32
LogBufMB=32
DatabaseCharacterSet=AL32UTF8
OracleNetServiceName=ttorcl

在ttnew实例上,建立cachedb2的DSN

[cachedb2]
Driver=/home/oracle/TimesTen/tt1122/lib/libtten.so
DataStore=/home/oracle/TimesTen/tt1122/info/DemoDataStore/cachedb2
PermSize=32
TempSize=64
LogFileSize=32
LogBufMB=32
DatabaseCharacterSet=AL32UTF8
OracleNetServiceName=ttorcl

建立cachedb1中的schema用户


$ ttisql -v1 cachedb1
Command> set prompt 'cachedb1> '
cachedb1> create user tthr identified by tthr;
User created.
cachedb1> grant admin to tthr;

在cachedb1和cachedb2中设置cacheadm的用户名和口令

$ ttadmin -connstr "dsn=cachedb1;uid=tthr;pwd=tthr;oraclepwd=tthr" -cacheUidPwdSet -cacheUid cacheadm -cachePwd oracle

cachedb1上创建cache grid

$ ttisql -v1 -e "set prompt 'cachedb1> '" "dsn=cachedb1;uid=tthr;pwd=tthr;oraclepwd=oracle" 
cachedb1> call ttGridCreate ('samplegrid');
cachedb1> call ttGridInfo;
< SAMPLEGRID, CACHEADM, Linux x86-64, 64-bit, 11, 2, 2 >
cachedb1> call ttGridNameSet ('samplegrid');

启动cachedb1上的cache agent

ttadmin -cacheStart cachedb1

创建Oracle中的Schema:

$ sqlplus tthr/oracle@ttorcl
create table a(id int, name varchar(32), primary key(id));SQL> grant select, insert, delete, update on a to cacheadm;SQL> insert into a values(1, 'beijing');
SQL> insert into a values(2, 'shanghai');
SQL> insert into a values(3, 'guangzhou');

cachedb1上创建Global Dynamic Asynchronous Writethrough Cache Group

CREATE DYNAMIC ASYNCHRONOUS WRITETHROUGH GLOBAL CACHE GROUP "G_AWT" FROM"TTHR"."A" ("ID"   NUMBER(38)        NOT NULL,"NAME" VARCHAR2(32 BYTE),PRIMARY KEY("ID"))

cachedb1上启动replication agent:

ttadmin -repStart cachedb1

将cachedb1 attach到cache grid

$ ttisql -v1 -e "set prompt 'cachedb1> '" "dsn=cachedb1;uid=tthr;pwd=tthr" 
cachedb1> call ttGridNodeStatus;
cachedb1> call ttGridAttach (1,'cachedb1','localhost',9991);
cachedb1> call ttGridNodeStatus;
< SAMPLEGRID, 1, 1, T, localhost, SAMPLEGRID_cachedb1_1, 127.0.0.1, 9991, <NULL>, <NULL>, <NULL>, <NULL>, <NULL> >

确认cachedb1可以访问数据

$  ttisql -v1 -e "set prompt 'cachedb1> '" "dsn=cachedb1;uid=tthr;pwd=tthr;oraclepwd=oracle"
cachedb1> select * from a;
cachedb1> select * from a where id = 1;
< 1, beijing >

建立cachedb2中的schema用户

$ ttisql -v1 -e "set prompt 'cachedb2> '" cachedb2
cachedb2> create user tthr identified by tthr;
User created.
cachedb2> grant admin to tthr;

cachedb2上设置cache admin账户信息,等等…

ttadmin -connstr "dsn=cachedb2;uid=tthr;pwd=tthr;oraclepwd=tthr" -cacheUidPwdSet -cacheUid cacheadm -cachePwd oracle[oracle@timesten-hol ~]$ ttisql -v1 -e "set prompt 'cachedb2> '" "dsn=cachedb2;uid=tthr;pwd=tthr;oraclepwd=oracle"
cachedb2> call ttGridInfo;
< SAMPLEGRID, CACHEADM, Linux x86-64, 64-bit, 11, 2, 2 >
cachedb2> call ttGridNameSet ('samplegrid');
cachedb2> call ttCacheStart();
cachedb2> CREATE DYNAMIC ASYNCHRONOUS WRITETHROUGH GLOBAL CACHE GROUP "G_AWT" >  FROM>   "TTHR"."A" (>     "ID"   NUMBER(38)        NOT NULL,>     "NAME" VARCHAR2(32 BYTE),>     PRIMARY KEY("ID")>   );
cachedb2> call ttrepstart();
cachedb2> call ttGridAttach (1,'cachedb2','localhost',9992);
cachedb2> call ttGridNodeStatus;
< SAMPLEGRID, 1, 1, T, localhost, SAMPLEGRID_cachedb1_1, 127.0.0.1, 9991, <NULL>, <NULL>, <NULL>, <NULL>, <NULL> >
< SAMPLEGRID, 2, 1, T, localhost, SAMPLEGRID_cachedb2_2, 127.0.0.1, 9992, <NULL>, <NULL>, <NULL>, <NULL>, <NULL> >cachedb1> autocommit 0
cachedb1> CALL ttOptSetFlag('GlobalProcessing', 1);
cachedb1> select * from a;
< 2, shanghai >
< 1, beijing >cachedb1>  SELECT id, TTGRIDUSERASSIGNEDNAME(), TTGRIDMEMBERID() FROM a; 
< 1, cachedb1, 1 >
< 2, cachedb2, 2 >

Cache Grid中某节点异常时的情况

以上即演示,一切正常,下面来看一下异常的情况。

若某一grid member宕机

[oracle@timesten-hol ~]$ ttdaemonadmin -stop
TimesTen Daemon stopped.
[oracle@timesten-hol ~]$ ttstatus cachedb1
ttStatus: Could not connect to the TimesTen daemon.
If the TimesTen daemon is not running, please start it
by running "ttDaemonAdmin -start".
[oracle@timesten-hol ~]$ [oracle@timesten-hol ~]$ ttisql -v1 -e "set prompt 'cachedb2> '" "dsn=cachedb2;uid=tthr;pwd=tthr;oraclepwd=oracle"
cachedb2> show autocommit;
autocommit = 1 (ON)
cachedb2> select * from a;
< 2, shanghai >
cachedb2> select * from a where id = 1;3333: Time out waiting for a response from member SAMPLEGRID_cachedb2_2 <- 大致一分钟
cachedb2> cachedb2> autocommit 0;
cachedb2>  CALL ttOptSetFlag('GlobalProcessing', 1);
cachedb2> select * from a;
好久都没出来!一直都没出来!!!

结论

  1. Cache Grid中的每个成员,如果是单节点,此架构是没有弹性(Resilience)的。数据不会重新分布,查询操作会超时或者HANG
  2. Cache Grid的每个成员的保护,通常是通过Active Standby Pair来保护的,每一个节点都需要配一个standby,不过这样的架构比较重
  3. Cache Grid(Global Cache Group)适用的场景较少,可扩展性方面是有限制的。
  4. TimesTen 未来会推出12版,应该可以替代掉现在的Cache Grid功能。

这篇关于TimesTen 应用层数据库缓存学习:17. 全局数据缓存(cache grid)的高可用性的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

MyBatis延迟加载与多级缓存全解析

《MyBatis延迟加载与多级缓存全解析》文章介绍MyBatis的延迟加载与多级缓存机制,延迟加载按需加载关联数据提升性能,一级缓存会话级默认开启,二级缓存工厂级支持跨会话共享,增删改操作会清空对应缓... 目录MyBATis延迟加载策略一对多示例一对多示例MyBatis框架的缓存一级缓存二级缓存MyBat

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码

C#使用iText获取PDF的trailer数据的代码示例

《C#使用iText获取PDF的trailer数据的代码示例》开发程序debug的时候,看到了PDF有个trailer数据,挺有意思,于是考虑用代码把它读出来,那么就用到我们常用的iText框架了,所... 目录引言iText 核心概念C# 代码示例步骤 1: 确保已安装 iText步骤 2: C# 代码程

Pandas处理缺失数据的方式汇总

《Pandas处理缺失数据的方式汇总》许多教程中的数据与现实世界中的数据有很大不同,现实世界中的数据很少是干净且同质的,本文我们将讨论处理缺失数据的一些常规注意事项,了解Pandas如何表示缺失数据,... 目录缺失数据约定的权衡Pandas 中的缺失数据None 作为哨兵值NaN:缺失的数值数据Panda

C++中处理文本数据char与string的终极对比指南

《C++中处理文本数据char与string的终极对比指南》在C++编程中char和string是两种用于处理字符数据的类型,但它们在使用方式和功能上有显著的不同,:本文主要介绍C++中处理文本数... 目录1. 基本定义与本质2. 内存管理3. 操作与功能4. 性能特点5. 使用场景6. 相互转换核心区别

Java 缓存框架 Caffeine 应用场景解析

《Java缓存框架Caffeine应用场景解析》文章介绍Caffeine作为高性能Java本地缓存框架,基于W-TinyLFU算法,支持异步加载、灵活过期策略、内存安全机制及统计监控,重点解析其... 目录一、Caffeine 简介1. 框架概述1.1 Caffeine的核心优势二、Caffeine 基础2

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳