TimesTen 应用层数据库缓存学习:17. 全局数据缓存(cache grid)的高可用性
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了TimesTen 应用层数据库缓存学习:17. 全局数据缓存(cache grid)的高可用性,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含5133字,纯文字阅读大概需要8分钟。
内容图文
![TimesTen 应用层数据库缓存学习:17. 全局数据缓存(cache grid)的高可用性](/upload/InfoBanner/zyjiaocheng/466/5ce5894eab2b4b5f94e5af25801c4007.jpg)
在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;
好久都没出来!一直都没出来!!!
结论
- Cache Grid中的每个成员,如果是单节点,此架构是没有弹性(Resilience)的。数据不会重新分布,查询操作会超时或者HANG
- Cache Grid的每个成员的保护,通常是通过Active Standby Pair来保护的,每一个节点都需要配一个standby,不过这样的架构比较重
- Cache Grid(Global Cache Group)适用的场景较少,可扩展性方面是有限制的。
- TimesTen 未来会推出12版,应该可以替代掉现在的Cache Grid功能。
TimesTen 应用层数据库缓存学习:17. 全局数据缓存(cache grid)的高可用性
标签:
本文系统来源:http://blog.csdn.net/stevensxiao/article/details/51678364
内容总结
以上是互联网集市为您收集整理的TimesTen 应用层数据库缓存学习:17. 全局数据缓存(cache grid)的高可用性全部内容,希望文章能够帮你解决TimesTen 应用层数据库缓存学习:17. 全局数据缓存(cache grid)的高可用性所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。