• <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)

            隨筆檔案

            文章分類

            文章檔案

            我的鏈接

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久久久婷婷| 999久久久免费国产精品播放| 久久久久亚洲AV成人网人人网站| 国内精品久久久久影院网站| 久久国产影院| 国产精品无码久久久久久| 国产成人无码精品久久久久免费| 国内精品久久久久久不卡影院| 久久青青国产| 青青青国产成人久久111网站| 久久免费99精品国产自在现线| 漂亮人妻被黑人久久精品| 久久国产免费| 国产人久久人人人人爽| 国产精品亚洲综合久久| 国产99久久久久久免费看| 中文国产成人精品久久不卡| 66精品综合久久久久久久| 久久久久亚洲AV片无码下载蜜桃| 精品久久国产一区二区三区香蕉 | 精品久久久久成人码免费动漫 | 久久青草国产精品一区| 亚洲日韩欧美一区久久久久我| 99国产精品久久| 伊人久久大香线蕉综合Av| 午夜精品久久久久久久无码| 国产精品美女久久久久网| 久久精品国产亚洲av日韩| 亚洲精品乱码久久久久66| 久久国产欧美日韩精品免费| 国产精品无码久久综合网| 中文字幕成人精品久久不卡| 精品久久久久久无码专区不卡| 中文字幕乱码人妻无码久久| 国产欧美久久久精品影院| 2021国内久久精品| 中文字幕久久精品无码| 亚洲综合熟女久久久30p| 亚洲国产欧洲综合997久久| 亚洲国产精品18久久久久久| 久久大香香蕉国产|