博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
oracle负载均衡方案,Oracle负载均衡配置代码
阅读量:1533 次
发布时间:2019-04-21

本文共 3473 字,大约阅读时间需要 11 分钟。

对于专业的数据处理存储的Oracle ARC而言,负载均衡的设置就更为重要了。那么如何对Oracle负载均衡进行配置呢?就让我们一起看看本文来学习一下吧。我们将从客户端和服务器端来进行解说。

Oracle负载均衡主要是指新会话连接到RAC数据库时,如何判定这个新的连接要连到哪个节点进行工作。在Oracle负载均衡中分为两种,一种是基于客户端连接的,另外一种是基于服务器端的。

客户端的Oracle负载均衡配置相对简单,只需要在tnsnames.ora中添加LOAD_BALANCE=ON这么一个选项即可。比如下面的TNS:

RAC =

(DESCRIPTION =

(ADDRESS = (PROTOCOL = TCP)(HOST = rac1-vip)(PORT = 1521))

(ADDRESS = (PROTOCOL = TCP)(HOST = rac2-vip)(PORT = 1521))

(LOAD_BALANCE =ON)

(FAILOVER =ON)

(CONNECT_DATA =

(SERVER = DEDICATED)

(SERVICE_NAME = rac)

)

)

这样当客户端连接RAC数据库时,会随机在TNS里面挑个监听地址进行连接。在Oracle10g以前,假如有节点宕机或者类似事故时,客户端可能还是选择连接到这个节点,这样会发生较长时间的TCP等待超时。而在10g以后,由于VIP和FAN的引入,这样的情况可以得到很大程度的改善。客户端的Oracle负载均衡在通常情况下能够较好地工作,但是由于连接是在客户端随机发起的,这样客户端并不知道RAC各节点的负荷及连接数情况,有可能负荷大的节点还会源源不断地增加新的连接,导致RAC节点无法均衡工作。

从Oracle 10g开始,服务器端的Oracle负载均衡可以根据RAC中各节点的负荷及连接数情况,而判定将新的客户端连接分配到负荷最小的节点上去。RAC中各节点的PMON进程每3秒会将各自节点的负荷(包括LOAD、***LOAD、CPU使用率)及连接数更新到service_register里面,然后假如节点的负荷有发生变化,将会通知到监听程序,由监听程序再决定新的客户端连接分配至哪个节点。假如RAC中一个节点的监听失败了,PMON每一分钟会去检查一次是否已经恢复正常。

服务器端的监听配置是在各节点的tnsnames.ora里面添加一个连接到各个节点监听的条目,然后再在初始化参数里面设置remote_listeners这个参数。比如:

LISTENERS_RAC =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = TCP)(HOST = rac1-vip)(PORT = 1521))

(ADDRESS = (PROTOCOL = TCP)(HOST = rac2-vip)(PORT = 1521))

)

ALTERSYSTEMSETREMOTE_LISTENER = LISTENERS_RAC;

这样服务器端的Oracle负载均衡便配置完成。

但是有时候由于PMON取节点负荷的延迟,导致客户端连接可能还是会连接到负荷较大的节点上,这时候便可以在服务器各节点的listener.ora里面加入PREFER_LEAST_LOADED_NODE=OFF这么一行,这样服务器端的Oracle负载均衡将不再根据节点的负荷来进行分配,而是根据节点的连接数进行分配,达到各个节点连接数比较平衡的效果。

另外一个不得不说的便是并行操作,假如有个会话连接以后要进行并行操作。由于连接时是按负荷或连接数连接,这样可能连接时各个节点连接数和负荷等比较平衡,但是这个并行会话启动多个并行进程以后,那么这个节点的负荷及连接数就会有可能上升得比较快。如果在RAC中开启了节点并行,那么有可能会把并行进程分配到多个节点运行以达到负载均衡的效果。

从Oracle 10.2开始,Oracle引入了Load Balance Advisor,对Oracle负载均衡有了进一步的改进。结合Service,可以对不同的SERVICE设置不同的Oracle负载均衡策略。Load Balance Advisor的配置可以通过DBMS_SERVICE包对SERVICE进行更改而完成。在Load Balance Advisor首先必须设置SERVICE负载均衡的目标,目标分为3种:

GOAL_NONE Disables theloadbalancing advisory

GOAL_SERVICE_TIME The LBA calculates a weighted moving averageofthe total elapsedtimeforcompletedworkplus the bandwidth that's availabletothe servicetocalculate the service goodness. This goalisidealforservices whose workload may change dramatically over a short periodoftime, e.g. an application that services a “clicksandmortar" store that provides customer self-service through an internet-based shopping web site.

GOAL_THROUGHPUT The LBA calculates a weighted moving averageofthroughput (i.e. the rateatwhichworkiscompleted)inadditiontothe bandwidth availabletothe servicetocalculate the service goodness. This goalisbest suitedforlong-duration tasks that are typically queuedtorun serially, e.g. scheduled jobs that handle large batchesoftransactions.

另外可以额外设置连接的负载均衡:

CLB_GOAL_SHORT TheLoadBalancing Advisory will be usedforconnectionloadbalancingonlyif itisenabled (i.e.settoother than GOAL_NONE). If the LBA has been disabled,connectionloadbalancing will utilize abridged advice determinedbyCPU utilization.

CLB_GOAL_LONGConnectionloadbalancing will be determinedbyfirsttallying the total numberofconnections per instance,andthenbycounting the numberofsessions per each service. Oracle recommends using this settingforservices whose applications tendtoconnectforlong periodsoftime(e.g. Oracle Forms). TheLoadBalancing Advisory can be usedinconjunctionwiththis settingaslongastheconnectionpool has been sizedtoaccommodate “gravitation “ within the pool without addingorsubtracting connections. Oracle recommends thisoptionasthe most efficient design.

【责任编辑:佟媛微 TEL:(010)68476606】

点赞 0

转载地址:http://saddy.baihongyu.com/

你可能感兴趣的文章
和 LeetCode Battle (8、移除元素)
查看>>
走上Git之路(二)
查看>>
和 LeetCode Battle (9、实现 strStr() 函数 )
查看>>
学习笔记 | 核主成分分析(KPCA)及其若干应用
查看>>
SLAM学习 | Ubuntu16.04 下从零开始配置环境并运行ORB-SLAM2(TUM, ROS+USB, 自制数据集)
查看>>
SLAM学习 | 单目相机标定(附代码实测可用)
查看>>
SLAM学习 | 对ORB-SLAM2运行结果KeyFrameTrajectory.txt内容的说明
查看>>
MNIST | 基于朴素贝叶斯分类器的0-9数字手写体识别
查看>>
MNIST | 基于k-means和KNN的0-9数字手写体识别
查看>>
Java之Collections工具类方法使用以及源码分析(三)
查看>>
Flink之Java 8
查看>>
Flink之修改StreamExecutionEnvironment配置Job
查看>>
Why Apache Flink®?
查看>>
Flink DataSet API Programming Guide学习&译文(未完待续)
查看>>
Flink关于加速器的使用
查看>>
Flink广播的使用
查看>>
Flink分布式缓存
查看>>
如何选择合适的数据类型
查看>>
学习MySQL(一)
查看>>
学习MySQL(二)数据库各项约束
查看>>