日期:2014-05-16  浏览次数:20493 次

Dataguard网络优化调整

?

Dataguard网络优化调整

??

Dataguard依赖一个健康的网络,尤其是高负载的系统和网络环境,网络上有调整的需求。

?

1.Oracle Net Session Data Unit (SDU)?Size

?????? Oracle Net在将数据进行网络传输的时候,先将数据放在SDU中,该参数在10gR2默认为2k,适当增加大小,可以提高网络性能和利用率。

?????? Oracle推荐该参数取值为32767(最大值),有两种办法调整该参数。

?

(1)globally

?????? 配置sqlnet.ora,增加参数 DEFAULT_SDU_SIZE=32767.

?

(2)connect descriptor

????? 配置listener.ora和tnsnames.ora,增加SDU描述,需要注意,在connect descriptor中配置SDU并不对动态服务注册生效,通过动态注册服务的connect,将继承sqlnet.ora中的DEFAULT_SDU_SIZE配置。

listener.ora:

SID_LIST_<listener_name>=

(SID_LIST=

(SID_DESC=

(SDU=32767)

(SID_NAME=<sid_name>)

(ORACLE_HOME=<oracle_home>)))

tnsnames.ora

<tnsnames>=

(DESCRIPTION=

(SDU=32767)

(ADDRESS=(PROTOCOL=tcp)(HOST=<host_name>)(PORT=<port>))

(CONNECT_DATA=

(SERVICE_NAME=<service_name>)))

?

2.TCP socket buffer

???????? TCP? socket buffer 可以通过OS层内核参数调整,也可以通过Oracle Net层调整,由于过大的size可能对OS上其他的TCP连接带来影响,因此建议在Oracle Net隔离设置。

???????? Oracle推荐的socket buffer 计算方法如下:

socket buffer?size?= 3 * bandwidth * delay

???????? 3.是BDP系数,oracle给出的工程经验值。

???????? BDP?=bandwidth * delay ,其中bandwidth表示带宽,假设我们的带宽为1000Mbps,delay表示主备库之间的网络延迟,假设我们环境为20ms,那么socket buffer?size= 3*1000Mbps*25ms/8 = 7500000?bytes

???????? TCP socket buffer 参数通过SEND_BUF_SIZE/RECV_BUF_SIZE配置,配置方式同