Dataguard网络优化调整


Oracle Management(192) 
版权声明:本文为博主原创文章,未经博主允许不得转载。
author:skate
time:2011/09/07
 
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配置,配置方式同SDU。
3.Network Device Queue Sizes
        为了避免tcp上的缓存溢出,需要增加网络设备的队列大小。以 Linux 为例,存在两种队列:transmit queue(传送队列)/receive queue(接收队列)。
        发送队列由txqueuelen控制,接收队列由netdev_max_backlog控制。
echo 1 > /proc/sys/net/ipv4/route/flush
echo 20000 > /proc/sys/net/core/netdev_max_backlog
ifconfig eth0 txqueuelen 10000
 
 
 
 
--------end------------
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值