• <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 死鎖查詢及處理(轉)

            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;

            --------------------------------------------------------------------------------
            查詢發生死鎖的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))


            ---------------------------------------------------------
            關于數據庫死鎖的檢查方法

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

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

              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進程。

            本文轉自:http://sungang-82.iteye.com/blog/310781

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

            2011年7月10日 #

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

            最次換新東家。公司的管理系統用的是zk,而我又是喜歡使用spring的。
            對于第一次使用zk,看了一次文檔后,就想使用其自身提供的zk與spring的組合了。
            所有的配置也完成了,但在@EventHandler上就是不生效
            添加的事件不啟動。看過源碼后。
            發現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。應該是從當前zul當中去取Component對象才對。
            所以改這句為
            Object o=comp.getFellow(srccompid);

            再重新編譯即可


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

            2011年1月5日 #

            Warning: initial dialog data is out of range.

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

            對應的值在某個范圍,但變量在初始化時值不在此范圍內

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

            2010年11月28日 #

            wtl 當中CUpdateUI 不定義情況

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

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

            2010年7月27日 #

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

            在linux 64bit上編譯curl with-ssl時出現下面的錯誤

            /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 閱讀(2346) | 評論 (0)編輯 收藏

            2010年4月8日 #

            c++ 線程池的實現(原)

                 摘要: 看群里有同志老是在找線程池的實現,聽說網上曾經發布的都是不正確的,今天我就自己弄了一個,不正確的地方大家指點指點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 閱讀(7249) | 評論 (9)編輯 收藏

            2010年3月19日 #

            OOD設計原則

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

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

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

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

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


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

             

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

            2009年3月26日 #

            轉載 配置多個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 閱讀(954) | 評論 (0)編輯 收藏

            2009年1月13日 #

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

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

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

            僅列出標題  

            My Links

            Blog Stats

            常用鏈接

            留言簿(2)

            隨筆檔案

            文章分類

            文章檔案

            我的鏈接

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国产精品成人99久久久久| 2021国产精品久久精品| 97精品久久天干天天天按摩| 久久久精品2019免费观看| 香蕉久久一区二区不卡无毒影院| 精品久久久久久无码人妻蜜桃| 亚洲精品国产综合久久一线| 久久精品人成免费| 人妻中文久久久久| 好久久免费视频高清| 国产精品99久久久久久宅男小说| 久久婷婷五月综合97色| 久久伊人五月天论坛| AAA级久久久精品无码片| 香蕉久久久久久狠狠色| 18岁日韩内射颜射午夜久久成人| 2021最新久久久视精品爱| 久久艹国产| 99国内精品久久久久久久| 97r久久精品国产99国产精| 久久天天躁夜夜躁狠狠| 久久久久久国产精品美女| 久久99国产精品久久久| 天堂久久天堂AV色综合| 综合久久久久久中文字幕亚洲国产国产综合一区首| 欧洲成人午夜精品无码区久久| 女人高潮久久久叫人喷水| 国内精品免费久久影院| 老司机国内精品久久久久| 久久精品一本到99热免费| 囯产极品美女高潮无套久久久| 久久久久综合国产欧美一区二区| 国产亚洲精品美女久久久| 国产综合久久久久| 999久久久无码国产精品| 韩国三级大全久久网站| 九九久久99综合一区二区| 久久青青草原精品影院| 99久久免费只有精品国产| 国内精品久久久久久不卡影院| 久久99精品久久久久久野外|