继续说一说Oracle的MTS

来源:互联网 发布:淘宝云客服培训平台 编辑:程序博客网 时间:2024/06/06 19:22

    在csdn上写了一篇关于MTS的文章后收到了一些网友的mail或是留言,他们还有好多关乎于MTS的一些问题。与piner,fenng,biti及其它的一些网友在聊天中,他们都对使用MTS有些不赞同,那天与Oracle的工程师交流中他也是有些反对,不过在我的实际应用过程中虽遇到了一些问题,但总体MTS还是让我很满意的,使我的一台Oracle Server在peak time的内存利用率由95%降到了78%,而且应用的速度还很不错。如下我便以问题的形式对MTS再进行几点补充。

1、在Oracle Server调整为MTS方式后,一些客户端出现了连不上Oracle Server的状况,大部分报的错为TNS-12509,如何解决?

回答:
    在实际过程中是存在着这方面的情况,我总结了一下,大部是由Oracle8 的client引起的,就是那些配服务名还得挂着个.world的那种客户端,其实解决起来很简单,只需要把tnsname.ora这个文件中你的那个服务名配置的"sid="改成"service_name=",这就Ok了。

2、我使用了成都迈普公司的"隧道网关"这种产品,以前在dedicated方式是好好的,可是改成MTS后,为什么Client死活连不是Oracle的Server呢?

回答:
    其实我们公司也用了这种产品,在MTS应用之初也遇到了这个问题。出现这个问题的原因为迈普的这种产品只为监测静态的端返回,它认为Oracle的监听端口即为返回端口,实际在MTS中不是这样的,多进行几次连接,用netstat -n在客户端观看一下就会明白,MTS返回的端口是动态的,所以迈普的这个产品就不好用了。解燃眉之急的办法可以这样:在MTS客户端配置"服务名"时,请求个Dedicate的连接,即使用SERVER = DEDICATED选项,这就把问题解决了。

3、如何跟踪一下MTS的dispatcher和shared server进程?

回答:
    这需用到诊断事件了,dispatcher的诊断事件号为10248,shared server的为10249,如下以shared server为例简单说一下,假定s015的操作系统的进程号为13161.

sql>conn sys/pass as sysdba
sql>oradebug setospid 13161 
sql>oradebug TRACEFILE_NAME   --看一下跟踪文件的名称
sql>oradebug EVENT 10249 trace name context forever, level 10

也可以在init<SID>.ora中加入如下两行完成trace:

 event="10248 trace name context forever, level X"  -- dispatchers
 event="10249 trace name context forever, level X"  -- shared servers

4、如何在MTS中设置IPC

回答:
   如下的配置样例来自Metalink
LISTENER.ORA:
=============
 
LISTENER=
  (ADDRESS_LIST=
     (ADDRESS=
        (PROTOCOL=IPC)
        (KEY=<sid name>)
     )
     (ADDRESS=
        (PROTOCOL=IPC)
        (KEY=<alias in tnsnames.ora for the sid>)
     )
  )
CONNECT_TIMEOUT_LISTENER=10
STARTUP_WAIT_TIME_LISTENER=0
SID_LIST_LISTENER=
  (SID_LIST=
    (SID_DESC=
      (SID_NAME=<sid name>) 
      (ORACLE_HOME=<home directory path for Oracle>)
    )
  )
 
地址列表中可以使用其它的协议,加入应的地址。这个例子完全是一个IPC的例子
 
TNSNAMES.ORA:
=============
 
<alias>=
  (DESCRIPTION=
     (ADDRESS=
        (PROTOCOL=IPC)
        (KEY=<sid name>)
     )
     (CONNECT_DATA=
        (SID=<sid name>)
     )
  )
 
 
INIT.ORA entries for MTS:
=========================
 
MTS_DISPATCHERS="IPC,2"
MTS_SERVERS=1
MTS_MAX_DISPATCHERS=6
MTS_MAX_SERVERS=3
MTS_SERVICE=<sid name>
MTS_LISTENER_ADDRESS="(ADDRESS=(PROTOCOL=IPC)(KEY=<sid name>))"


5、如何查看一下某个shared_server正在忙什么?

回答:
    其实这与Dedicated方式的查看方法是一样的,还以s015为例,它的spid为13161,使用如下的sql便可查

出:

SELECT a.username,
       a.machine,
       a.program,
       a.sid,
       a.serial#,
       a.status,
       c.piece,
       c.sql_text
  FROM v$session a,
       v$process b,
       v$sqltext c
 WHERE b.spid=13161
   AND b.addr=a.paddr
   AND a.sql_address=c.address(+)
 ORDER BY c.piece  

6、我在unix看到一个shared server的进程占用了大量的CPU资源,通过select addr from v$process where spid=<os process pid>查到进程的address,而select * from v$session where paddr=<paddr>确没的结果,所以我无法得知我的这个shared server在忙什么,我该怎么办呢?

回答:

SELECT status FROM v$circuit
 WHERE CIRCUIT IN
  (
   SELECT circuit FROM v$shared_server
    WHERE paddr=<your paddr>
  )
如果status的返回是EOF,说明实际这个shared server已经掉死了,你可以把它在操作系统上清除掉了:
eg:
  oracle$kill -9 <shared server's pid>

你不用担心kill掉会有什么大的影响,其它几分钟之后,pmon会为你把这个shared server进程给重新启动的。

7、如何在非down库的情况下恢复到Dedicate的连接方式,及启用更多的dispatcher?

回答:
7.1关掉:
  sql>ALTER SYSTEM SET MTS_DISPATCHERS='TCP,0';

7.2启用更多的dispatcher
  sql>ALTER SYSTEM SET MTS_DISPATCHERS='TCP,40';

部分内容参照Metalink的Note:47684.1

 

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 被派出所拘留 车怎么办 被公安怀疑贩毒怎么办 报案后证据不足怎么办 担心丈夫复嫖怎么办 交通事故当事人重伤笔录怎么办 交通事故做完笔录后怎么办 罚款单子丢了怎么办 刑事案件人跑了怎么办 打架当事人跑了怎么办 赌博被派出所抓怎么办 治安案件人跑了怎么办 去警察局做笔录怎么办 未成年打架留下案底怎么办 土地被别人侵占怎么办 在公安局有案底怎么办 做小姐有案底怎么办 党员被黑社会打怎么办 周期内被扣15分怎么办 驾证扣了50分怎么办? 酒驾拘留工作怎么办 开电动车被拘留怎么办 有一次吸毒案底怎么办 家里收到拘留书怎么办 吸毒有案底结婚怎么办 坐牢了房子按揭怎么办 被刑事拘留15天怎么办 看守所没人交生活费怎么办 判刑后看守所拒收怎么办 上海小孩怎么办图书证 渝北区回兴怎么办户口 赌博罪进看守所怎么办 无法盘腿坐疼怎么办 在看守所不会盘腿怎么办 广州入户信息卡怎么办 工商局被投诉了怎么办 公安到预审阶段怎么办 找的律师不行怎么办 犯了刑事案件该怎么办 在派出所被打怎么办 判刑了身上手机怎么办 12123登不上去怎么办