• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            我的程序人生

            2011年8月14日 #

            oracle 死鎖查詢及處理(轉(zhuǎn))

            SELECT    bs.username "Blocking User", bs.username "DB User",
                      ws.username "Waiting User", bs.SID "SID", ws.SID "WSID",
                      bs.serial# "Serial#", bs.sql_address "address",
                      bs.sql_hash_value "Sql hash", bs.program "Blocking App",
                      ws.program "Waiting App", bs.machine "Blocking Machine",
                      ws.machine "Waiting Machine", bs.osuser "Blocking OS User",
                      ws.osuser "Waiting OS User", bs.serial# "Serial#",
                      ws.serial# "WSerial#",
                      DECODE (wk.TYPE,
                              'MR', 'Media Recovery',
                              'RT', 'Redo Thread',
                              'UN', 'USER Name',
                              'TX', 'Transaction',
                              'TM', 'DML',
                              'UL', 'PL/SQL USER LOCK',
                              'DX', 'Distributed Xaction',
                              'CF', 'Control FILE',
                              'IS', 'Instance State',
                              'FS', 'FILE SET',
                              'IR', 'Instance Recovery',
                              'ST', 'Disk SPACE Transaction',
                              'TS', 'Temp Segment',
                              'IV', 'Library Cache Invalidation',
                              'LS', 'LOG START OR Switch',
                              'RW', 'ROW Wait',
                              'SQ', 'Sequence Number',
                              'TE', 'Extend TABLE',
                              'TT', 'Temp TABLE',
                              wk.TYPE
                             ) lock_type,
                      DECODE (hk.lmode,
                              0, 'None',
                              1, 'NULL',
                              2, 'ROW-S (SS)',
                              3, 'ROW-X (SX)',
                              4, 'SHARE',
                              5, 'S/ROW-X (SSX)',
                              6, 'EXCLUSIVE',
                              TO_CHAR (hk.lmode)
                             ) mode_held,
                      DECODE (wk.request,
                              0, 'None',
                              1, 'NULL',
                              2, 'ROW-S (SS)',
                              3, 'ROW-X (SX)',
                              4, 'SHARE',
                              5, 'S/ROW-X (SSX)',
                              6, 'EXCLUSIVE',
                              TO_CHAR (wk.request)
                             ) mode_requested,
                      TO_CHAR (hk.id1) lock_id1, TO_CHAR (hk.id2) lock_id2,
                      DECODE
                         (hk.BLOCK,
                          0, 'NOT Blocking',          /**//* Not blocking any other processes */
                          1, 'Blocking',              /**//* This lock blocks other processes */
                          2, 'Global',           /**//* This lock is global, so we can't tell */
                          TO_CHAR (hk.BLOCK)
                         ) blocking_others
                 FROM v$lock hk, v$session bs, v$lock wk, v$session ws
                WHERE hk.BLOCK = 1
                  AND hk.lmode != 0
                  AND hk.lmode != 1
                  AND wk.request != 0
                  AND wk.TYPE(+) = hk.TYPE
                  AND wk.id1(+) = hk.id1
                  AND wk.id2(+) = hk.id2
                  AND hk.SID = bs.SID(+)
                  AND wk.SID = ws.SID(+)
                  AND (bs.username IS NOT NULL)
                  AND (bs.username <> 'SYSTEM')
                  AND (bs.username <> 'SYS')
            ORDER BY 1;

            --------------------------------------------------------------------------------
            查詢發(fā)生死鎖的select語句

            select sql_text from v$sql where hash_value in 
            (select sql_hash_value from v$session where sid in
            (select session_id from v$locked_object))


            ---------------------------------------------------------
            關(guān)于數(shù)據(jù)庫死鎖的檢查方法

            一、         數(shù)據(jù)庫死鎖的現(xiàn)象
            程序在執(zhí)行的過程中,點擊確定或保存按鈕,程序沒有響應(yīng),也沒有出現(xiàn)報錯。
            二、         死鎖的原理
            當對于數(shù)據(jù)庫某個表的某一列做更新或刪除等操作,執(zhí)行完畢后該條語句不提
            交,另一條對于這一列數(shù)據(jù)做更新操作的語句在執(zhí)行的時候就會處于等待狀態(tài),
            此時的現(xiàn)象是這條語句一直在執(zhí)行,但一直沒有執(zhí)行成功,也沒有報錯。
            三、         死鎖的定位方法
            通過檢查數(shù)據(jù)庫表,能夠檢查出是哪一條語句被死鎖,產(chǎn)生死鎖的機器是哪一臺。
            1)用dba用戶執(zhí)行以下語句
            select username,lockwait,status,machine,program from v$session where sid in
            (select session_id from v$locked_object)
            如果有輸出的結(jié)果,則說明有死鎖,且能看到死鎖的機器是哪一臺。字段說明:
            Username:死鎖語句所用的數(shù)據(jù)庫用戶;
            Lockwait:死鎖的狀態(tài),如果有內(nèi)容表示被死鎖。
            Status: 狀態(tài),active表示被死鎖
            Machine: 死鎖語句所在的機器。
            Program: 產(chǎn)生死鎖的語句主要來自哪個應(yīng)用程序。
            2)用dba用戶執(zhí)行以下語句,可以查看到被死鎖的語句。
            select sql_text from v$sql where hash_value in 
            (select sql_hash_value from v$session where sid in
            (select session_id from v$locked_object))

            四、         死鎖的解決方法
                 一般情況下,只要將產(chǎn)生死鎖的語句提交就可以了,但是在實際的執(zhí)行過程中。用戶可
            能不知道產(chǎn)生死鎖的語句是哪一句。可以將程序關(guān)閉并重新啟動就可以了。
             經(jīng)常在Oracle的使用過程中碰到這個問題,所以也總結(jié)了一點解決方法。

              1)查找死鎖的進程:

            sqlplus "/as sysdba" (sys/change_on_install)
            SELECT s.username,l.OBJECT_ID,l.SESSION_ID,s.SERIAL#,
            l.ORACLE_USERNAME,l.OS_USER_NAME,l.PROCESS 
            FROM V$LOCKED_OBJECT l,V$SESSION S WHERE l.SESSION_ID=S.SID;

              2)kill掉這個死鎖的進程:

              alter system kill session ‘sid,serial#’; (其中sid=l.session_id)

              3)如果還不能解決:

            select pro.spid from v$session ses,
            v$process pro where ses.sid=XX and 
            ses.paddr=pro.addr;

              其中sid用死鎖的sid替換:

            exit
            ps -ef|grep spid

              其中spid是這個進程的進程號,kill掉這個Oracle進程。

            本文轉(zhuǎn)自:http://sungang-82.iteye.com/blog/310781

            posted @ 2011-08-14 21:52 lancey 閱讀(777) | 評論 (0)編輯 收藏

            2011年7月10日 #

            ZK spring 當中@EventHandler不能生效的解決方案

            最次換新東家。公司的管理系統(tǒng)用的是zk,而我又是喜歡使用spring的。
            對于第一次使用zk,看了一次文檔后,就想使用其自身提供的zk與spring的組合了。
            所有的配置也完成了,但在@EventHandler上就是不生效
            添加的事件不啟動。看過源碼后。
            發(fā)現(xiàn)GenericSpringComposer.java當中
            private void processEventsAnnotation(Component comp, String annotationValue, String mdname) {
                    
            if (annotationValue == null) {
                        
            return;
                    }
                    List
            <String> annotationValueTokens = (List<String>) CollectionsX.parse(new ArrayList<String>(), annotationValue, ',');
                    
            for (String annotationValueToken : annotationValueTokens) {
                        String srccompid 
            = annotationValueToken.substring(0, annotationValueToken.indexOf('.'));
                        String srcevt  
            = annotationValueToken.substring(annotationValueToken.indexOf('.'+ 1, annotationValueToken.length());
                        String eventName 
            = srcevt + "." + srccompid;
                        
            Object o = SpringUtil.getBean(srccompid);
                        
            if(o instanceof Component) {
                            Component c 
            = (Component) o;
                            List
            <String> methodNames = eventsMap.get(eventName); 
                            
            if(methodNames == null) {
                                methodNames 
            = new ArrayList<String>();
                                methodNames.add(mdname);
                                eventsMap.put(eventName, methodNames);
                            } 
            else {
                                methodNames.add(mdname);
                                eventsMap.put(eventName, methodNames);
                            }
                            comp.addEventListener(eventName, 
            this);
                            ((Component) o).addForward(srcevt, comp, eventName);
                        }
                    }
                }

            看到上面的Object o = SpringUtil.getBean(srccompid);個人認為是從spring當中取bean來對比是否是Component。應(yīng)該是從當前zul當中去取Component對象才對。
            所以改這句為
            Object o=comp.getFellow(srccompid);

            再重新編譯即可


            posted @ 2011-07-10 20:58 lancey 閱讀(767) | 評論 (0)編輯 收藏

            2011年1月5日 #

            Warning: initial dialog data is out of range.

            在mfc Debug模式下出現(xiàn)"Warning: initial dialog data is out of range."提示。。
            原因是出現(xiàn)在 DDV_MinMaxInt

            對應(yīng)的值在某個范圍,但變量在初始化時值不在此范圍內(nèi)

            posted @ 2011-01-05 17:39 lancey 閱讀(1483) | 評論 (0)編輯 收藏

            2010年11月28日 #

            wtl 當中CUpdateUI 不定義情況

            error C2504: “CUpdateUI”: 未定義基類
            error C2143: 語法錯誤 : 缺少“,”(在“<”的前面)
            error C3646: “END_UPDATE_UI_MAP”: 未知重寫說明符
            出現(xiàn)上面的情況時需要include <atlframe.h>頭文件

            posted @ 2010-11-28 11:40 lancey 閱讀(1006) | 評論 (0)編輯 收藏

            2010年7月27日 #

            libssl.a(s2_clnt.o): relocation R_X86_64_32 against

            在linux 64bit上編譯curl with-ssl時出現(xiàn)下面的錯誤

            /usr/bin/ld: /usr/lib/gcc/x86_64-linux-gnu/4.3.2/../../../../lib/libssl.a(s2_clnt.o): relocation R_X86_64_32 against `a local symbol' can not be used when making a shared object; recompile with -fPIC

            /usr/lib/gcc/x86_64-linux-gnu/4.3.2/../../../../lib/libssl.a: could not read symbols: Bad value
            collect2: ld returned 1 exit status


            變更方法:
            env PKG_CONFIG_PATH="openssl path" ./configure --disable-file --without-pic --disable-shared --with-ssl

            posted @ 2010-07-27 10:20 lancey 閱讀(2354) | 評論 (0)編輯 收藏

            2010年4月8日 #

            c++ 線程池的實現(xiàn)(原)

                 摘要: 看群里有同志老是在找線程池的實現(xiàn),聽說網(wǎng)上曾經(jīng)發(fā)布的都是不正確的,今天我就自己弄了一個,不正確的地方大家指點指點mutex.hxx 互斥類  1#ifndef INCLUDE_MUTEX_HH 2#define INCLUDE_MUTEX_HH 3#include <pthread.h> 4 5class...  閱讀全文

            posted @ 2010-04-08 15:43 lancey 閱讀(7252) | 評論 (9)編輯 收藏

            2010年3月19日 #

            OOD設(shè)計原則

            單一職責原則(SRP)
            就一個類而言,應(yīng)該只有一個引起變化的原因
            如果你能想到多余一個的動機去改變一個類,
            那么這個類就具有多于一個的職責。

            開放封閉原則(OCP)
            對于擴展是開放的
            對于更改是封閉的

            Liskov替換原則(LSP)
            子類型(subtype)必須能夠替換掉它們的基類型(base type)

            依賴倒置原則(DIP)
            高層模塊不應(yīng)該依賴于底層模塊。二者都應(yīng)該依賴于抽象

            抽象不應(yīng)該依賴于細節(jié)。細節(jié)應(yīng)該依賴于抽象。
            任何變量都不應(yīng)該持有一個指向具體的指針或引用
            任何類都不應(yīng)該從具體類派生
            任何方法都不應(yīng)該覆寫他的任何基類中的已經(jīng)實現(xiàn)了的方法


            接口隔離原則(ISP)
            不應(yīng)該強迫客戶依賴于它們不用的方法

             

            posted @ 2010-03-19 14:22 lancey 閱讀(421) | 評論 (0)編輯 收藏

            2009年3月26日 #

            轉(zhuǎn)載 配置多個jboss在同一機器上的端口號修改

            jboss4.2

            1.   $JBoss_home/server/default/deploy/ejb3.deployer/META-INF/jboss-service.xml
                 修改3873端口的值;
            2.   $JBoss_home/server/default/deploy/jboss-web.deployer/server.xml
                 修改8080,8009,8443端口值。
            3.   $JBoss_home/server/default/conf/jboss-service.xml
                 修改8083,1098,1099,4444,4445,4446端口值
            4.   $JBoss_home/server/default/conf/jboss-minimal.xml
                 修改1099端口值,與3中保持一致。
            5.   $JBoss_home/server/default/deploy/jms/uil2-service.xml
                 修改8093端口值。

            posted @ 2009-03-26 13:53 lancey 閱讀(960) | 評論 (0)編輯 收藏

            2009年1月13日 #

            鏈接錯誤error LNK2005可能原因之一

            lib工程里的"C/C++"->"Code Generation"->"Runtime Library"里面的內(nèi)容和exe工程里面的內(nèi)容不一致造成的

            posted @ 2009-01-13 14:15 lancey 閱讀(614) | 評論 (0)編輯 收藏

            僅列出標題  

            My Links

            Blog Stats

            常用鏈接

            留言簿(2)

            隨筆檔案

            文章分類

            文章檔案

            我的鏈接

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            精品熟女少妇a∨免费久久| 日韩av无码久久精品免费| 久久国产精品二国产精品| 国产巨作麻豆欧美亚洲综合久久| 国产AV影片久久久久久| 日韩一区二区三区视频久久| 无码人妻久久一区二区三区免费丨 | 国内精品久久久久影院网站| 久久久久久国产a免费观看黄色大片 | 一本久久知道综合久久| 97久久精品午夜一区二区| 欧美大战日韩91综合一区婷婷久久青草 | 久久中文字幕精品| 精品久久香蕉国产线看观看亚洲| 久久一区二区三区99| 精品一区二区久久| 一级做a爰片久久毛片看看| 精品一区二区久久久久久久网站| 欧美日韩久久中文字幕| 丁香久久婷婷国产午夜视频| 久久久无码精品亚洲日韩按摩 | 亚洲国产精品久久久久婷婷软件| 久久无码AV一区二区三区| 91精品国产色综久久| 久久AV高清无码| 亚洲国产欧洲综合997久久| 久久久亚洲精品蜜桃臀| 99久久精品免费看国产一区二区三区 | 亚洲美日韩Av中文字幕无码久久久妻妇| 国产精品禁18久久久夂久| 亚洲精品国精品久久99热一| 国产精品久久久久久久app| 国内精品久久久久久麻豆| 国内精品久久久久久久涩爱| 国产99久久久久久免费看| 国产午夜精品久久久久九九| 91麻精品国产91久久久久| 99久久www免费人成精品| 精品国产热久久久福利| 久久久亚洲精品蜜桃臀| 欧美久久天天综合香蕉伊|