LoadRunner遇到的問題

1. :html

答: 打開任務管理器,關閉ThumbProcess.exe進程node

 

一、LoadRunner超時錯誤:在錄製Web服務器端,若是超過120秒服務器協議腳本回放時超時狀況常常出現,產生錯誤的緣由也有不少,解決的方法也不一樣。

錯誤現象1:Action.c(16): Error -27728: Step download timeout (120 seconds) has expired when downloading non-resource(s)。

錯誤分析:對於HTTP協議,默認的超時時間是120秒(能夠在LoadRunner中修改),客戶端發送一個請求到
端尚未返回結果,則出現超時錯誤。

解決辦法:首先在運行環境中對超時進行設置,默認的超時時間能夠設置長一些,再設置屢次迭代運行,若是還有超時現象,須要在「Runtime Setting」>「Internet Protocol:Preferences」>「Advanced」區域中設置一個「winlnet replay instead of sockets」選項,再回放是否成功。

 web

2.LoadRunner腳本中出現亂碼:在錄製Web協議腳本時出現中文亂碼,在回放腳本時會使回放中止在亂碼位置,腳本沒法運行。
錯誤現象:某個連接或者圖片名稱爲中文亂碼,腳本運行沒法經過。
錯誤分析:腳本錄製可能採用的是URL-based script方式,若是程序定義的字符集合採用的是國際標準,腳本就會出現亂碼現象。
解決辦法:從新錄製腳本,在錄製腳本前,打開錄製選項配置對話框進行設置,在「Recording Options」的「Advanced」選項裏先將「Surport Charset」選中,而後選中支持「UTF-8」的選項。

3.LoadRunner HTTP服務器狀態代碼:在錄製Web協議腳本回放腳本的過程當中,會出現HTTP服務器狀態代碼,例如常見的頁面-404錯誤提示、-500錯誤提示。
錯誤現象1:-404 Not Found服務器沒有找到與請求URI相符的資源,但還能夠繼續運行直到結束。
錯誤分析:此處與請求URI相符的資源在錄製腳本時已經被提交過一次,回放時不可再重複提交一樣的資源,而須要更改提交資源的內容,每次回放一次腳本都要改變提交的數據,保證模擬實際環境,形成必定的負載壓力。
解決辦法:在出現錯誤的位置進行腳本關聯,在必要時插入相應的函數。

錯誤現象2:-500 Internal Server Error服務器內部錯誤,腳本運行中止。
錯誤分析:服務器碰到了意外狀況,使其沒法繼續迴應請求。
解決辦法:出現此錯誤是致命的,說明問題很嚴重,須要從問題的出現位置進行檢查,此時須要此程序的開發人員配合來解決,並且產生的緣由根據實際狀況來定,測試人員沒法單獨解決問題,並且應該儘快解決,以便於後面的測試。

4.LoadRunner請求沒法找到:在錄製Web協議腳本回放腳本的過程當中,會出現請求沒法找到的現象,而致使腳本運行中止。
錯誤現象:Action.c(41): Error -27979: Requested form. not found [MsgId: MERR-27979]
Action.c(41): web_submit_form. highest severity level was "ERROR",0 body bytes, 0 header bytes [MsgId: MMSG-27178]"
這時在tree view中看不到此組件的相關URL。
錯誤分析:所選擇的錄製腳本模式不正確,一般狀況下,基於瀏覽器的Web應用會使用「HTML-based script」模式來錄製腳本;而沒有基於瀏覽器的Web應用、Web應用中包含了與服務器進行交互的 代碼、基於瀏覽器的應用中使用HTTPSJava Applet、基於瀏覽器的應用中包含了向服務器進行通訊的JavaScript/VBScript 安全協議,這時則使用「URL-based script」模式進行錄製。
解決辦法:打開錄製選項配置對話框進行設置,在「Recording Options」的「Internet Protocol」選項裏的「Recording」中選擇「Recording Level」爲「HTML-based script」,單擊「HTML Advanced」,選擇「Script. Type」爲「A script. containing explicit」。而後再選擇使用「URL-based script」模式來錄製腳本。

5. Abnormal termination, caused by mdrv process termination
解決:修改LR中的D:\Program Files\Mercury\LoadRunner\dat\protocols 中的http.lrp信息,在[Vugen]下面新加一條MaxThreadPerProcess=要設置的vuser數量 。

6.LoadRunner錄製腳本時爲何不彈出IE瀏覽器?
答:啓動瀏覽器,打開Internet選項對話框,切換到高級標籤,去掉「啓用第三方瀏覽器擴展(須要重啓動)」的勾選,而後再次運行VuGen便可解決問題;

7.LoadRunner錄製腳本時提示默認瀏覽器不支持解決方法?
答:在Recording Options->Browser->修改瀏覽器設置->改成IE瀏覽器訪問,從新啓動LoadRunner錄製腳本就ok;

8.LR錄製Web腳本時,生成的腳本中存在亂碼該如何解決?
答:錄製腳本前,打開錄製選項配置對話框Record-Options,進入到Advanced標籤,先勾選「Support charset」,選擇支持UTF-8。從新錄製,就不會出現中文亂碼問題了。

9.HTML-based script與URL-based script的腳本有什麼區別?
答:使用「HTML-based script」的模式錄製腳本,VuGen爲用戶的每一個HTML操做生成單獨的步驟,這種腳本看上去比較直觀;使用「URL-based script」模式錄製腳本時,VuGen能夠捕獲全部做爲用戶操做結果而發送到服務器的HTTP請求,而後爲用戶的每一個請求分別生成對應方法。一般,基 於瀏覽器的Web應用會使用「HTML-based script」模式來錄製腳本;而沒有基於瀏覽器的Web應用、Web應用中包含了與服務器進行交互的Java Applet、基於瀏覽器的應用中包含了向服務器進行通訊的JavaScript/VBScript代碼、基於瀏覽器的應用中使用了HTTPS安全協議, 這時使用「URL-based script」模式進行錄製。

10.爲何腳本中添加了檢查方法Web-find,可是腳本回放時卻沒有執行?
答:LoadRunner默認關閉了對文本及圖像的檢查。進入「Run-time Setting」對話框,依次進入「Internet Protocol→Preferences」,勾選Checks下的「Enable Image and text check」選項便可。
備註:推薦web_reg_find函數針對文本及圖像的檢查。

11.運行時的Pacing設置主要影響什麼?
答:Pacing主要用來設置重複迭代腳本的間隔時間。共有三種方法:上次迭代結束後馬上開始、上次迭代結束後等待固定時間、按固定或隨機的時間間隔開始執行新的迭代。根據實際須要設置迭代便可。一般,沒有時間間隔會產生更大的壓力。

12.運行時設置Log標籤中,若是沒有勾選「Enable logging」,則手工消息能夠發送嗎?
答:Enable logging選項僅影響自動日誌記錄和經過lr_log_message發送的消息。即便沒有勾選,虛擬用戶腳本中若是使用lr_message、lr_output_message、lr_error_message,仍然會記錄其發出的消息。

13.LoadRunner如何在IE7+Win2003環境下錄製腳本?
答: 方法一: 巧借IE6內核錄製腳本
在系統安裝目錄下C:\WINDOWS\ie7\iexplore.exe,而後在Recording Options->Browser,指定Ie6內核;設置完成確認後,便可以用LoadRunner錄製腳本;
方法二 查看了下官方提供LoadRunner解決方法:
安裝LoadRunner 8.1 Feature Pack 4->而後安裝:Internet Explorer 7 (IE 7) support for LoadRunner 8.1 Feature Pack 4;

14.LoadRunner 8.0版本的VuGen在錄製Web Services協議的腳本時一切正常,但回放時報錯誤「Error:server returned an incorrectly formatted SOAP response」?
答:緣由是LoadRunner 8.0的VuGen在錄製Web Service協議的腳本時存在一個缺陷:若是服務器的操做系統是中文的,VuGen會自動將WSDL文件的頭改成<?xml version=」1.0」 encoding=」zh_cn」?>,所以會有上面的錯誤提示。
因此須要打上補丁:「LR80WebservicesFPI_setup.exe」和「lrunner_web_sevices_path_1.exe」。

15.VuGen支持Netscape的客戶證書嗎?
答:不支持。目前的VuGen 8.0版本中僅支持Internet Explorer的客戶端證書。錄製腳本時能夠 先從Netscape中導出所需的證書,而後將其導入到Internet Explorer中,並確保以相同的順序導出和導入這些證書。並且,在每臺將要錄製或運行須要證書的Web Vuser腳本的計算機上都要重複執行前面的過程。

16. LoadRunner場景執行時第1次報錯 error:missing newline in d:\test\test1.dat,第2次場景執行時不報錯?
答:Loadruner參數設置test1.dat文本時,須要在最後一個參數後回車確認一下。

17.LoadRunner場景執行時出現錯誤:「load generator is currently running the maximum number of vuser of this type」
答:Loadruuner默認場景併發最大用戶數=1000,因此需 要設置load generator->Details->Vuser limits->Other Vusers更換參數值便可,如10000;固然須要你的序列號是支持,目前最大支持6.2w的序列號。

18.VuGen會修改錄製瀏覽器中的代理服務器設置嗎?
答:會修改。在開始錄製基於瀏覽器的Web Vuser腳本時,VuGen首先會啓動指定的瀏覽器。而後,VuGen會指示瀏覽器訪問VuGen代理服務器。爲此,VuGen會修改錄製瀏覽器上的代 理服務器設置。默認狀況下,VuGen會當即將代理服務器設置更改成Localhost:7777。錄製以後,VuGen會將原始代理服務器設置還原到該 錄製瀏覽器中。所以,在VuGen進行錄製的過程當中,不能夠更改代理服務器設置,不然將沒法正常進行。

19.在LoadRunner腳本如何輸出當前系統時間?
答:LoadRunner提供了char *ctime(const time_t *time)函數,調用參數爲一個Long型的整數指針,用於存放返回時間的數值表示。

20.Loadruner在一些Web虛擬用戶腳本錄製後馬上回放沒有任何問題,可是當設置迭代次數大於1時,若是進行回放則只能成功迭代一次。從第二次迭代開始發生錯誤?
答:「Run-time Setting」的「Browse Emulation」的設置中,勾選了「Simulate a new user on each iteration」及其下面的選項「Clear cache on each iteration」這兩個選項的含義是每次迭代時模擬一個新的用戶及每次迭代時清除緩存。

21.LoadRunner中「Run-time Setting」中的線程和進程運行方式的區別?
答:若是選擇「Run Vuser as a process」,則場景運行時會爲每個虛擬用戶建立一個進程;選擇「Run Vuser as a thread」則將每一個虛擬用戶做爲一個線程來運行,在任務管理器中只看到一個mmdrv.exe,這種方式的運行效率更高,能形成更大的壓力,時默認選 項。另外,若是啓用了IP欺騙功能,則先在Controller中選中Tools菜單下的「Expert Mode」,而後將Tools菜單下的「Options>General」標籤頁中的IP地址分配方式也設置爲與Vuser運行方式一致,同爲線程 或進程方式。

22.在Controller中運行Web相關測試場景時,常常會有不少超時錯誤提示,如何處理這類問題?
答:這主要有腳本的默認超時設置引發。當回放Web腳本時,有時候由 於服務器響應時間較長,會產生超時的錯誤。這時須要修改腳本的運行時配置。進入「Run-time Setting」對話框後,依次進入「Internet Protocol→Preference」。而後點擊「Options…」按鈕,進入高級設置對話框,能夠修改各種超時設置的默認值。

23.爲何Windows系統中的CPU、內存等資源仍然充足,可是模擬的用戶數量卻上不去?
答:在Windows計算機的標準設置下,操做系統的默認限制只能使 用幾百個Vuser,這個限制與CPU或內存無關,主要是操做系統自己規定了默認的最大線程數所致使。要想突破Windows這個限制,須修改 Windows註冊表。以Windows XP Professional爲例。
1)打開註冊表後,進入註冊表項HKEY_LOCAL_MACHINE中的下列關鍵字:System\CurrentControlSet\Control\Session Manager\SubSystems。
(2)找到Windows關鍵字,Windows關鍵字以下所示:
  %SystemRoot%\system32\csrss.exe bjectDirectory=\Windows
  SharedSection=1024,3072,512 Windows=On SubSystemType=Windows ServerDll=basesrv,1
  ServerDll=winsrv:UserServerDllInitialization,3 ServerDll=winsrv:ConServerDllInitialization,2
  ProfileControl=Off MaxRequestThreads=16
  SharedSection=1024,3072,512關鍵字的格式爲xxxx,yyyy,zzz。其中,xxxx定義了系統範圍堆的最大值(以KB爲單位),yyyy定義每一個桌面堆得大小。
3)將yyyy的設置從3072更改成8192(即8MB),增長SharedSection參數值。
  經過對註冊表的更改,系統將容許運行更多的線程,於是能夠在計算機上運行更多的Vuser。這意味着可以模擬的最大併發用戶數量將不受Windows操做系統的限制,而只受硬件和內部可伸縮性限制的約束。

24.Controller中設置了用戶併發數量,可是運行時爲什麼初始化的用戶數量少於實際數量?
答:主要時設置問題。在Tools→options→Run- time setting中能夠設置每次最多初始化的虛擬用戶。若是須要100個併發用戶,則將該值設置爲大於100的數值。另外,注意LoadRunner相關協 議License的更新,確保使用的License可以容許所須要的併發用戶數量。

25.如何讓場景的用戶執行發生錯誤繼續運行,以保證不間斷進行壓力測試?
答:用VuGen打開虛擬用戶腳本後,進入「Run-time Settings」對話框後,依次進入「General→Miscellaneous」,能夠看到Miscellaneous設置中關於「Error Handling」的配置。勾選「Continue on error」便可讓虛擬用戶發生錯誤繼續運行。

26.爲何.NET虛擬用戶有時不能在遠程主機執行?
答:主要時LoadRunner的版本問題。根據筆者的經驗,若是是Microsoft Visual Studio 2005開發的虛擬用戶,同時LoadRunner客戶端的版本低於8.1,執行Controller的主機將會發生錯誤。
所以要想正確的運行Microsoft Visual Studio 2005開發的.NET虛擬用戶,客戶端最好裝8.1以上的版本,Controller的主機則安裝8.0和8.1兩個版本都可。此外,產生壓力的 LoadRunner客戶端上預先應該安裝.NET運行環境,若是Microsoft Visual Studio 2005開發的是.NET虛擬用戶,則應該安裝Microsoft .NET Framework SDK v2.0。

27.測試分析結果中會統計Action時間,而實際上可能並不需要這些數據,如何只顯示本身定義的用戶事務?
答:進入腳本的運行時設置,依次進入General→Miscellaneous。 默認狀況下,自動事務配置「Automatic Transactions」下有兩個選項:第一個是把腳本的Action部分定義爲一個事務;第二個時把腳本的每一部分定義爲一個事務。去掉這兩個勾選 後,測試結果將會只顯示本身定義的用戶事務。

28.測試結果中,Summary和平均事務響應時間圖裏的各個事務的最大值、平均值、最小值爲何顯示不同?
答:主要是受採樣時間的影響。Summary裏的事務平均響應時間是 根據整個場景執行過程獲得的數據計算所得,最大值與最小值也是從整個場景中獲得的。平均事務響應時間圖主要時按照LoadRunner分析出來的採樣頻率 來獲取事務響應時間的最大值與最小值,而後計算平均值。能夠經過「Set Granularity」來修改平均事務響應時間圖的採樣頻率。若是把「Granularity」設爲場景執行時間,則統計結果將會一致。

29.統計結果中的總點擊量Total Hits時用戶的鼠標點擊次數嗎?
答:Total Hits不時按照用戶的鼠標點擊次數來計算的,而是按照各個虛擬客戶端向後臺發起的總的請求數來進行統計的。例如在向服務器請求的一個頁面中,若是該頁面 包含5個圖片,用戶只要單擊鼠標就能夠訪問該頁面,而單個虛擬用戶在LoadRunner訪問的點擊量爲1+5=6次。

30.有些Web測試結果分析圖(例如每秒返回頁面數)在測試結果分析圖中沒法看到,如何進行配置?
答:用VuGen打開虛擬用戶腳本後,進入「Run-time Settings」對話框後,依次進入「Internet Protocol>Preference」,能夠看到一些Web性能圖配置。勾選上面得選項後,Controller將會在測試執行過程當中生成數 據,而後可在Analysis中查看相應的性能結果分析圖。
、Step download timeout (120 seconds)
解決辦法:
一、修改run time setting中的請求超時時間,增長到600s,其中有三項的參數能夠一次都修改了,HTTP-request connect timeout,HTTP-request receieve timeout,Step download timeout,分別建議修改成600、600、5000;run time setting設置完了後記住還須要在control組件的option的run time setting中設置相應的參數;
二、辦法一不能解決的狀況下,解決辦法以下:
設置runt time setting中的internet protocol-preferences中的advaced區域有一個winlnet replay instead of sockets選項,選項後再回放就成功了。切記此法只對windows系統起做用,此法來自zee的資料。

31.問題描述Connection reset by peer
這個問題很少碰見,通常是因爲下載的速度慢,致使超時,因此,須要調整一下超時時間
解決辦法:Run-time setting窗口中的‘Internet Protocol’-‘Preferences’設置set advanced options(設置高級選項),從新設置一下「HTTP-request connect timeout(sec),能夠稍微設大一些」;

32.問題描述connection refused
這個的錯誤的緣由比較複雜,也可能很簡單也可能須要查看好幾個地方,解決起來不一樣的操做系統方式也不一樣;
一、首先檢查是否是鏈接weblogic服務過大部分被拒絕,須要監 控weblogic的鏈接等待狀況,此時須要增長acceptBacklog,每次增長25%來提升看是否解決,同時還須要增長鏈接池和調整執行線程數, (鏈接池數*Statement Cache Size)的值應該小於等於oracle數據庫鏈接數最大值;
二、若是方法一操做後沒有變化,此時須要去查看服務器操做系統中是否對鏈接數作了限制,AIX下能夠直接vi文件limits修改其中的鏈接限制數,還有tcp鏈接等待時間間隔大小,wiodows相似,只不過wendows修改註冊表,具體修改方法查手冊,註冊表中有TcpDelayTime項;

33.問題描述open many files
答:問題通常都在壓力較大的時候出現,因爲服務器或者應用中間件自己對於打開的文件數有最大值限制形成,解決辦法:
一、修改操做系統的文件數限制,aix下面修改limits下的nofiles限制條件,增大或者設置爲沒有限制,儘可能對涉及到的服務器都做修改;
二、方法一解決不了狀況下再去查看應用服務器weblogic的commonEnv.sh文件,修改其中的nofiles文件max-nofiles數增大,應該就能夠經過了,具體就是查找到nofiles方法,修改其中else條件的執行體,把文件打開數調大;修改前記住備份此文件,防止修改出錯;

34.問題描述has shut down the connection prematurely
  通常是在訪問應用服務器時出現,大用戶量和小用戶量均會出現;
  來自網上的解釋:
  1> 應用訪問死掉。小用戶時:程序上的問題。程序上存在數據庫的問題
  2> 應用服務沒有死
    應用服務參數設置問題
  例如:
  在許多客戶端鏈接Weblogic應用服務器被拒絕,而在服務器端沒有錯誤顯示,則有多是Weblogic中的server元素的AcceptBacklog屬性值設得太低。若是鏈接時收到connection refused消息,說明應提升該值,每次增長25%
  Java鏈接池的大小設置,或JVM的設置等
  3> 數據庫的鏈接
  在應用服務的性能參數可能過小了
  數據庫啓動的最大鏈接數(跟硬件的內存有關)
  以上信息有必定的參考價值,實際狀況能夠參考此類調試。
  若是是以上所說的小用戶時:程序上的問題。程序上存在數據庫的問題,那就必須採用更加專業的工具來抓取出現問題的程序,主要是程序中執行效率很低的 sql語句,weblogic能夠採用introscope定位,期間能夠注意觀察一下jvm的垃圾回收狀況看是否正常,我在實踐中併發500用戶和 600用戶時曾出現過jvm鋸齒型的變化,上升降低都很快,這應該是不太正常的。

35.問題描述Failed to connect to server
這個問題通常是客戶端連接到服務失敗,緣由有兩個客戶端鏈接限制(也就是壓力負載機器),一個網絡延遲嚴重,解決辦法:
  一、修改負載機器的tcpdelaytime註冊表鍵值,改小;
  二、檢查網絡延遲狀況,看問題出在什麼環節;
  建議爲了減小這種狀況,辦法一最好測試前就完成了,保證乾淨的網絡環境,每一個負載機器的壓力測試用戶數不易過大,儘可能平均每臺負載器的用戶數,這樣以上問題出現的機率就很小了。

36.問題描述:Overlapped transmission of request to ... WSA_IO_PENDING
解決方法:
  一、方法一,在腳本前加入web_set_sockets_option("OVERLAPPED_SEND", "0"),禁用TTFB細分,問題便可解決,可是TTFB細分圖將不能再使用,附圖。
  二、方法二,能夠經過增長鏈接池和應用系統的內存,每次增長25%。

37.問題描述:Deleted the current transaction ... since response time is not accurate
這個問題很少碰見,通常出如今壓力機器上發生ping值爲負數(AMD雙核CPU),能夠從新啓動pc機或者打補丁,附圖。

38.問題描述:HTTP Status-Code=500 (Internal Server Error) for
一、應用服務當掉,從新啓動應用服務。
二、當應用系統處於的可用內存處於閥值如下時,出現HTTP Status-Code=500的機率很是高,此時只要增長應用系統的內存,問題便可解決。

39.問題描述:Failed to transmit data to network: [10057] Socket is not connected
這個錯誤是由網絡緣由形成的,PC1 和PC2上面都裝了相同的loadrunner 9.0,且以相同數量的虛擬用戶數運行相同的業務(機器上的其餘條件都相同),PC1上面有少部分用戶報錯,PC2上的用戶所有執行經過。

40.問題描述:Error -27257: Pending web_reg_save_param/reg_find/create_html_param[_ex] request(s) detected and reset at the end of iteration number 1
解決方法:web_reg_save_param位置放錯了,應該放到請求頁面前面。

41.問題描述:經過Controler調用遠程代理時報錯,Error: CCI security error:You are running under secure mode and the function system is not allowed in this mode.
解決方法:在代理開啓的時候,去掉勾選防火牆選項。

42.Error -27796: Failed to connect to server "10.102.8.201:80": [10048] Address already in use
Try changing the registry value
HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\tcpip\Parameters\TcpTimedWaitDelay to 30and HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\tcpip\Parameters\MaxUserPort to 65534 and rebooting the machine
See the readme.doc file for more information
解決辦法:由於負載生成器的性能太好,發數據包特別快,服務器也響應特別快,從而致使負載生成器的機器的端口在沒有timeout以前就所有佔滿了。在所有佔滿後,就會出現上面的錯誤。執行netstat –na命令,能夠看到打開了不少端口。因此就調整TCP的time out。即在最後一個端口尚未用到時,前面已經有端口在釋放了。
1. 打開LoadRunner負載機所在機器的註冊表,將 HKEY_LOCAL_MACHINESystemCurrentControlSetServicestcpipParameters項中的 TcpTimedWaitDelay值設置爲5s或者其它(按須要調整)也能夠把MaxUserPort值調大(若是這個值不是最大值的話),同時增長腳 本的think time,再重啓機器。
2.取消勾選controller的run-setting-times-browser-browser emulation 「simulate a new user on each iteration」項。

43.Action.c(6): Error -27792: Failed to transmit data to network: [10054] Connection reset by peer
解決辦法:腳本和場景迭代延遲時間設置要相同
 
44.Files transfer error: C:\Documents and Settings\Administrator.SCMCC\Local Settings\Temp\brr_YAR.313\netdir\e\測試組\生產環境\UUC接口\uuc_shell\綜合場景2\results\res\10.101.11.82_2073.eve
 
Write failure on machine 10.101.11.82. Check the available disk space.
All Vusers on this machine will stop running
 
Error: Failed to write data to the .eve file. Check that the remote host has enough disk space: system error - 磁盤空間不足
 
Error: Failed returning to the last proper record in the .eve file: "C:\Documents and Settings\Administrator.SCMCC\Local Settings\Temp\brr_YAR.313\netdir\e\測試組\生產環境\UUC接口\uuc_shell\綜合場景2\results\res\10.101.11.82_2073.eve".
 
解決辦法:壓力機磁盤空間不足形成的。

45.Action.c(38): Error -27492: "HttpSendRequest" failed, Windows error code=12002 and retry limit (0) exceeded for URL
解決辦法:在runtime setting中的preferences- ->options-->http-request connect timeout(sec)的值設爲999。

46.Action.c(6): Error -26612: HTTP Status-Code=500 (Internal Server Error) for http://192.168.0.8:10001/logonConsole.do;jsessionid={JSESSIONID2}
解決辦法:形成HTTP-500錯誤以下幾個可能:
一、運行的用戶數過多,對服務器形成的壓力過大,服務器沒法響應,則報HTTP500錯誤。減少用戶數或者場景持續時間,問題獲得解決。
二、該作關聯的地方沒有去作關聯,則報HTTP500錯誤。進行手工或者自動關聯,問題獲得解決。
三、錄製時請求的頁面、圖片等,在回放的時候服務器找不到,則報HTTP500錯誤,若該頁面可有可無,則能夠在腳本中註釋掉,問題將會獲得解決。例如:有驗證碼的狀況下,儘管測試時已經屏蔽了,可是錄製的時候提交了請求,但回放的時候不存在響應。
四、參數化時的取值有問題,則報HTTP500錯誤。可將參數化列表中的數值,拿到實際應用系統中進行測試,可排除問題。
五、更換了應用服務器(中間件的更換,如tomcat、websphere、jboss等),仍是利用原先錄製的腳本去運行,則極可能報HTTP500錯誤。由於各類應用服務器處理的機制不同,所錄製的腳本也不同,解決辦法只有從新錄製腳本。
六、Windows xp2 與ISS組件不兼容,則有可能致使HTTP500錯誤。對ISS組件進行調整後問題解決。
七、系統開發程序寫的有問題,則報HTTP500錯誤。例若有些指針問題沒有處理好的,有空指針狀況的存在。修改程序後問題解決。
日誌發現報了不少0ra-01000錯誤,這是oracle達到最大遊標參數值,google了下,最大緣由多是JDBC鏈接沒關閉。最後查找weblogic鏈接池出了問題,不少鏈接沒關閉。 查找後臺

47.Action.c(15): 錯誤-27496: 內部錯誤(呼叫客戶服務): _eStat (7) != LRW_ITEM_STAT_ENUM_UNHANDLED for HandledTask at 048E180C
Action.c(56): Error -27995: Requested link ("Text=計劃管理") not found  [MsgId: MERR-27995]
解決方法:在IE中的工具—>Internet選項—>高級—>HTML設置中選擇第二個腳本類型。

48.錯誤 -27279:內部錯誤(呼叫客戶服務):Report initialization failed , error code = -2147467259 [MsgId : MERR-27279 ]
解決辦法:建議重裝一下LR。這種問題有可能和你安裝有關.dll文件出錯不是說寫的程序就能修改的。

49. Error -10489 : Exception was raised when calling per-thread-terminate function
在用Loadrunner實施性能測試時,採用Goal模式加壓,存在若是持續長 時加壓時LoadRunner的Controller會報 Error -10489 : Exception was raised when calling per-thread-terminate function錯誤;
產生緣由:
 Unlike the earlier Windows versions, Windows 2000 and Windows XP have the default environment set to C:\Document and Settings\<user-name>\Local Settings\Temp instead of C:\Windows\temp. This long path with a space can cause several problems for LoadRunner. To resolve the issue, change to a directory without empty spaces。

解決方法:在C盤(或是其它盤都可以)新建TEMP文件夾(爲了後續設置臨時文件準備),右鍵"個人電腦"->高級->環境變量->編輯修改TEMP變量目錄,指身上面新建的目錄,如個人指向C:\TEMP->保存便可。
50.Error -27727: Step download timeout (120 seconds)has expired when downloading resource(s). Set the 「Resource Page Timeout is a Warning」 Run-Time Setting to Yes/No to have this message as a warning/error, respectively
解決方法:Run-Time Setting → Internet Protocol →Preferences→Option →Step download timeout(sec)改成32000
      A、應用服務參數設置太大致使服務器的瓶頸
  B、頁面中圖片太多
  C、在程序處理表的時候檢查字段太大或多

51.Action.c(16): Error -27728: Step download timeout (120 seconds) has expired when downloading non-resource(s)。
錯誤分析:對於HTTP協議,默認的超時時間是120秒(能夠在LoadRunner中修改),客戶端發送一個請求到服務器端,若是超過120秒服務器端尚未返回結果,則出現超時錯誤。

解決辦法:首先在運行環境中對超時進行設置,默認的超時時間能夠設置長一些,再設置屢次迭代運行,若是還有超時現象,須要在"Runtime Setting">"Internet Protocol:Preferences">"Advanced"區域中設置一個"winlnet replay instead of sockets"選項,再回放是否成功。

5二、Action.c(38): Error -27492: "HttpSendRequest" failed, Windows error code=12002 and retry limit (0) exceeded for URL
解決辦法:在runtime setting中的preferences- ->options-->http-request connect timeout(sec)的值設爲999。

5三、Action.c(81):Continuing after Error -27498: Timed out while processing URL=http://172.18.20.70:7001/workflow/bjtel/leasedline/ querystat/ subOrderQuery.do
錯誤分析:這種錯誤經常是由於併發壓力過大,服務器端太繁忙,沒法及時響應客戶端的請求而形成的,因此這個錯誤是正常現象,是壓力過大形成的。若是壓力很小就出現這個問題,多是腳本某個地方有錯誤,要仔細查看腳本,提示的錯誤信息會定位某個具體問題發生的位置。

解決辦法:例如上面的錯誤現象問題定位在某個URL上,須要再次運行一下場景,同時在其餘機器上訪問此URL。若是不能訪問或時間過長,多是服務器或者 此應用不能支撐如此之大的負載。分析一下服務器,最好對其性能進行優化。若是再次運行場景後還有超時現象,就要在各類圖形中分析一下緣由,例如能夠查看是 否服務器、DNS、網絡等方面存在問題。最後,增長一下運行時的超時設置,在"Run-Time Settings">"Internet Protocol:Preferences"中,單擊"options",增長"HTTP-request connect timeout" 或者"HTTP-request receive"的值。

5四、用strtok函數分割字符串
須要在loadrunner裏面得到「15」(下面紅色高亮的部分),並作成關聯參數。
//Body response 內容: <BODY><; PRE>//OK[8,7,5,15,6,5,0,4,0,3,0,3,2,0,0,0,1
用web_reg_save_param取出「8,7,5,15,6,5,0,4,0,3,0,3,2,0,0,0,1」這一段,而後用strtok函數切割出一個個數字,第四個數字就是要找的值
例如:
extern char * strtok(char * string, const char * delimiters ); // Explicit declaration
char separators[] = ",";
char * token;
lr_save_string("1,2,3,4,5,6","str");
token = (char *)strtok(lr_eval_string("{str}"), separators); // Get the first token
if (!token) {
        lr_output_message ("No tokens found in string!");
        return( -1 );
    }
while (token != NULL ) { // While valid tokens are returned
       lr_output_message ("%s", token );
       token = (char *)strtok(NULL, separators); // Get the next token
   }

5五、測試RTMP協議應該在LoadRunner選擇什麼協議來錄製?
解決辦法:用flex協議,有這幾個函數可用:
flex_rtmp_connect Connects a client to an RTMP server and sets connection options. 
flex_rtmp_disconnect Disconnects a client from an RTMP server. 
flex_rtmp_send Sends messages to an RTMP server. 
flex_rtmp_receive Receives responses from an RTMP server
Flex can record and replay scripts involving RTMP (Real Time Messaging Protocol). In order to enable RTMP simulation, you must configure the recording options for the Flex protocol.
To enable RTMP:
1 Open the Recording Options dialog box by selecting Tools > Recording Options or clicking the Options button in the Start Recording dialog box.
2 In the Network > Port Mapping node click Options.
3 Set the Send-Receive buffer size threshold to 1500.

5六、如何在LoadRunner中運行QTP腳本?
一、運行準備:
1)勾選QTP的Tools--Options--Run的"Alow other Mercury products to run tests and components"
2)錄製須要在lr中運行的QTP腳本,而且在QTP腳本中設置事務,Services.StartTransaction "start"與Services.EndTransaction "start"
二、運行QTP腳本
在LR中運行時選擇QTP腳本,爲QTP腳本存放目錄下文件擴展名爲.usr的文件。
注:LR中運行QTP腳本時,只能有一個Vuser,不然將報錯:
The load generator is currently running the maximum number of Vusers of this type

5七、在LR中如何忽略Socket接收數據的驗證
在LR中對Socket進行性能測試時,LR會本身判斷lrs_receive回來的數據的長度,而若是長度不符的話會有時間延遲的狀況(這是性能測試徹底不能接受的事情),若是作到這一點呢,通過反覆嘗試,發現一種簡單的方法(用*代替具體的長度):
相似於將:
recv buf1 12
"Hello, Denny"
改成:
recv buf1 *
"Hello, Denny"
一切OK。

5八、LoadRunner9.5的Controller中不能添加Apache的監控
在C:\Program Files\HP\LoadRunner\dat\online_graphs中找到online_resource_graphs.rmd文件,修改[Apache]部分中的EnableInUI爲1
參考:
http://forums11.itrc.hp.com/service/forums/questionanswer.do?admit=109447626+1274450165814+28353475&threadId=1229523

5九、VB Vuser開發ADO腳本,提示「user-defined type not defined」
想在VB Vuser寫入模擬數據操做的過程,而後在VB Vuser裏定義了這個全局變量
Private m_Conn As ADODB.Connection '鏈接對象
Private m_Reco As ADODB.Recordset '結果集
可是在VB Vuser中不識別這個對象,報出user-defined type not defined
須要在Run-Time 設置中的VBA部分把ADO的庫選上
若是用VB Script虛擬用戶來開發就不要,直接用CreateObject來建立ADO對象便可

60、loadrunner9.5錄製腳本時出現c:\PROGRA~1\MICROS~1\office12\Grooveutil.DLL時出錯內存位置訪問無效
解決辦法:Office2007的問題,IE加載項禁用Groove GFSBrowser Helper 組件

6一、LR自帶的例子端口號怎麼修改?
LR自帶的例子端口號是1080,我怎麼樣把這個端口設置我本身想用的端口號8088,在什麼地方設置
在LR安裝目錄下,找到Xitami.config文件,找到portbase,能夠修改它(默認是1000);默認的端口號是portbase+80;要把端口號改爲8088,就把portionbase改成8008,保存以後就是了(8088=8008+80)。

6二、用Web_reg_find查找中文字符串時查找不到?
解決辦法:腳本文件裏有個default.cfg ,裏面有個參數是 UTF8InputOutput ,將其值改成1

6三、替代IP Wizard的腳本
http://hi.baidu.com/higkoo/blog/item/39bbb21bc33d76dcac6e751c.html
LoadRunner自帶的「IP Wizard」用起來很是麻煩,要不停的點,重要的是最後還必須重啓系統生效。
因而乎寫個腳本替代之:
1. 假設客戶端IP爲 192.168.10.31
2. 假設服務端IP爲 192.168.10.10
3. 須要模擬的IP爲 110.119.120.122
那麼,客戶端提供添加虛擬IP的BAT腳本:
netsh  interface   ip    add    address    本地鏈接  110.119.120.122  255.255.0.0
對應的刪除設置爲:
netsh   interface   ip    del    address    本地鏈接    110.119.120.122
對應服務器添加虛擬路由的Shell腳本:
route add -host 110.119.120.122 gw 192.168.10.31
刪除路由的腳本:
route del -host 110.119.120.122 gw 192.168.10.31
這樣就很是方便了,不用重啓任何機器,執行腳本就生效,再執行腳本就取消。

6四、如何從命令行調用LoadRunner腳本?
 Here is the command line that you need to execute to run a VuGen script from the command prompt:
<LoadRunner>\bin\mmdrv.exe -usr <path to usr file>
Note:
In order to get all the other options that go with the command, run mmdrv.exe from the command prompt without any options.

6五、請問"int64這個類型,在LR中怎麼表示"。我將一段C的代碼放在LR中,LR不認int64這個類型,怎麼解決?
解決辦法:把那段C代碼作成DLL,而後在LR中調用。
 
 
http://blog.csdn.net/barebear/article/details/16355817
 

一、LoadRunner超時錯誤:在錄製Web服務器端,若是超過120秒服務器協議腳本回放時超時狀況常常出現,產生錯誤的緣由也有不少,解決的方法也不一樣。

錯誤現象1:Action.c(16): Error -27728: Step download timeout (120 seconds) has expired when downloading non-resource(s)。

錯誤分析:對於HTTP協議,默認的超時時間是120秒(能夠在LoadRunner中修改),客戶端發送一個請求到
端尚未返回結果,則出現超時錯誤。

解決辦法:首先在運行環境中對超時進行設置,默認的超時時間能夠設置長一些,再設置屢次迭代運行,若是還有超時現象,須要在「Runtime Setting」>「Internet Protocol:Preferences」>「Advanced」區域中設置一個「winlnet replay instead of sockets」選項,再回放是否成功。

 sql

2.LoadRunner腳本中出現亂碼:在錄製Web協議腳本時出現中文亂碼,在回放腳本時會使回放中止在亂碼位置,腳本沒法運行。
錯誤現象:某個連接或者圖片名稱爲中文亂碼,腳本運行沒法經過。
錯誤分析:腳本錄製可能採用的是URL-based script方式,若是程序定義的字符集合採用的是國際標準,腳本就會出現亂碼現象。
解決辦法:從新錄製腳本,在錄製腳本前,打開錄製選項配置對話框進行設置,在「Recording Options」的「Advanced」選項裏先將「Surport Charset」選中,而後選中支持「UTF-8」的選項。

3.LoadRunner HTTP服務器狀態代碼:在錄製Web協議腳本回放腳本的過程當中,會出現HTTP服務器狀態代碼,例如常見的頁面-404錯誤提示、-500錯誤提示。
錯誤現象1:-404 Not Found服務器沒有找到與請求URI相符的資源,但還能夠繼續運行直到結束。
錯誤分析:此處與請求URI相符的資源在錄製腳本時已經被提交過一次,回放時不可再重複提交一樣的資源,而須要更改提交資源的內容,每次回放一次腳本都要改變提交的數據,保證模擬實際環境,形成必定的負載壓力。
解決辦法:在出現錯誤的位置進行腳本關聯,在必要時插入相應的函數。

錯誤現象2:-500 Internal Server Error服務器內部錯誤,腳本運行中止。
錯誤分析:服務器碰到了意外狀況,使其沒法繼續迴應請求。
解決辦法:出現此錯誤是致命的,說明問題很嚴重,須要從問題的出現位置進行檢查,此時須要此程序的開發人員配合來解決,並且產生的緣由根據實際狀況來定,測試人員沒法單獨解決問題,並且應該儘快解決,以便於後面的測試。

4.LoadRunner請求沒法找到:在錄製Web協議腳本回放腳本的過程當中,會出現請求沒法找到的現象,而致使腳本運行中止。
錯誤現象:Action.c(41): Error -27979: Requested form. not found [MsgId: MERR-27979]
Action.c(41): web_submit_form. highest severity level was "ERROR",0 body bytes, 0 header bytes [MsgId: MMSG-27178]"
這時在tree view中看不到此組件的相關URL。
錯誤分析:所選擇的錄製腳本模式不正確,一般狀況下,基於瀏覽器的Web應用會使用「HTML-based script」模式來錄製腳本;而沒有基於瀏覽器的Web應用、Web應用中包含了與服務器進行交互的 代碼、基於瀏覽器的應用中使用HTTPSJava Applet、基於瀏覽器的應用中包含了向服務器進行通訊的JavaScript/VBScript 安全協議,這時則使用「URL-based script」模式進行錄製。
解決辦法:打開錄製選項配置對話框進行設置,在「Recording Options」的「Internet Protocol」選項裏的「Recording」中選擇「Recording Level」爲「HTML-based script」,單擊「HTML Advanced」,選擇「Script. Type」爲「A script. containing explicit」。而後再選擇使用「URL-based script」模式來錄製腳本。

5. Abnormal termination, caused by mdrv process termination
解決:修改LR中的D:\Program Files\Mercury\LoadRunner\dat\protocols 中的http.lrp信息,在[Vugen]下面新加一條MaxThreadPerProcess=要設置的vuser數量 。

6.LoadRunner錄製腳本時爲何不彈出IE瀏覽器?
答:啓動瀏覽器,打開Internet選項對話框,切換到高級標籤,去掉「啓用第三方瀏覽器擴展(須要重啓動)」的勾選,而後再次運行VuGen便可解決問題;

7.LoadRunner錄製腳本時提示默認瀏覽器不支持解決方法?
答:在Recording Options->Browser->修改瀏覽器設置->改成IE瀏覽器訪問,從新啓動LoadRunner錄製腳本就ok;

8.LR錄製Web腳本時,生成的腳本中存在亂碼該如何解決?
答:錄製腳本前,打開錄製選項配置對話框Record-Options,進入到Advanced標籤,先勾選「Support charset」,選擇支持UTF-8。從新錄製,就不會出現中文亂碼問題了。

9.HTML-based script與URL-based script的腳本有什麼區別?
答:使用「HTML-based script」的模式錄製腳本,VuGen爲用戶的每一個HTML操做生成單獨的步驟,這種腳本看上去比較直觀;使用「URL-based script」模式錄製腳本時,VuGen能夠捕獲全部做爲用戶操做結果而發送到服務器的HTTP請求,而後爲用戶的每一個請求分別生成對應方法。一般,基 於瀏覽器的Web應用會使用「HTML-based script」模式來錄製腳本;而沒有基於瀏覽器的Web應用、Web應用中包含了與服務器進行交互的Java Applet、基於瀏覽器的應用中包含了向服務器進行通訊的JavaScript/VBScript代碼、基於瀏覽器的應用中使用了HTTPS安全協議, 這時使用「URL-based script」模式進行錄製。

10.爲何腳本中添加了檢查方法Web-find,可是腳本回放時卻沒有執行?
答:LoadRunner默認關閉了對文本及圖像的檢查。進入「Run-time Setting」對話框,依次進入「Internet Protocol→Preferences」,勾選Checks下的「Enable Image and text check」選項便可。
備註:推薦web_reg_find函數針對文本及圖像的檢查。

11.運行時的Pacing設置主要影響什麼?
答:Pacing主要用來設置重複迭代腳本的間隔時間。共有三種方法:上次迭代結束後馬上開始、上次迭代結束後等待固定時間、按固定或隨機的時間間隔開始執行新的迭代。根據實際須要設置迭代便可。一般,沒有時間間隔會產生更大的壓力。

12.運行時設置Log標籤中,若是沒有勾選「Enable logging」,則手工消息能夠發送嗎?
答:Enable logging選項僅影響自動日誌記錄和經過lr_log_message發送的消息。即便沒有勾選,虛擬用戶腳本中若是使用lr_message、lr_output_message、lr_error_message,仍然會記錄其發出的消息。

13.LoadRunner如何在IE7+Win2003環境下錄製腳本?
答: 方法一: 巧借IE6內核錄製腳本
在系統安裝目錄下C:\WINDOWS\ie7\iexplore.exe,而後在Recording Options->Browser,指定Ie6內核;設置完成確認後,便可以用LoadRunner錄製腳本;
方法二 查看了下官方提供LoadRunner解決方法:
安裝LoadRunner 8.1 Feature Pack 4->而後安裝:Internet Explorer 7 (IE 7) support for LoadRunner 8.1 Feature Pack 4;

14.LoadRunner 8.0版本的VuGen在錄製Web Services協議的腳本時一切正常,但回放時報錯誤「Error:server returned an incorrectly formatted SOAP response」?
答:緣由是LoadRunner 8.0的VuGen在錄製Web Service協議的腳本時存在一個缺陷:若是服務器的操做系統是中文的,VuGen會自動將WSDL文件的頭改成<?xml version=」1.0」 encoding=」zh_cn」?>,所以會有上面的錯誤提示。
因此須要打上補丁:「LR80WebservicesFPI_setup.exe」和「lrunner_web_sevices_path_1.exe」。

15.VuGen支持Netscape的客戶證書嗎?
答:不支持。目前的VuGen 8.0版本中僅支持Internet Explorer的客戶端證書。錄製腳本時能夠 先從Netscape中導出所需的證書,而後將其導入到Internet Explorer中,並確保以相同的順序導出和導入這些證書。並且,在每臺將要錄製或運行須要證書的Web Vuser腳本的計算機上都要重複執行前面的過程。

16. LoadRunner場景執行時第1次報錯 error:missing newline in d:\test\test1.dat,第2次場景執行時不報錯?
答:Loadruner參數設置test1.dat文本時,須要在最後一個參數後回車確認一下。

17.LoadRunner場景執行時出現錯誤:「load generator is currently running the maximum number of vuser of this type」
答:Loadruuner默認場景併發最大用戶數=1000,因此需 要設置load generator->Details->Vuser limits->Other Vusers更換參數值便可,如10000;固然須要你的序列號是支持,目前最大支持6.2w的序列號。

18.VuGen會修改錄製瀏覽器中的代理服務器設置嗎?
答:會修改。在開始錄製基於瀏覽器的Web Vuser腳本時,VuGen首先會啓動指定的瀏覽器。而後,VuGen會指示瀏覽器訪問VuGen代理服務器。爲此,VuGen會修改錄製瀏覽器上的代 理服務器設置。默認狀況下,VuGen會當即將代理服務器設置更改成Localhost:7777。錄製以後,VuGen會將原始代理服務器設置還原到該 錄製瀏覽器中。所以,在VuGen進行錄製的過程當中,不能夠更改代理服務器設置,不然將沒法正常進行。

19.在LoadRunner腳本如何輸出當前系統時間?
答:LoadRunner提供了char *ctime(const time_t *time)函數,調用參數爲一個Long型的整數指針,用於存放返回時間的數值表示。

20.Loadruner在一些Web虛擬用戶腳本錄製後馬上回放沒有任何問題,可是當設置迭代次數大於1時,若是進行回放則只能成功迭代一次。從第二次迭代開始發生錯誤?
答:「Run-time Setting」的「Browse Emulation」的設置中,勾選了「Simulate a new user on each iteration」及其下面的選項「Clear cache on each iteration」這兩個選項的含義是每次迭代時模擬一個新的用戶及每次迭代時清除緩存。

21.LoadRunner中「Run-time Setting」中的線程和進程運行方式的區別?
答:若是選擇「Run Vuser as a process」,則場景運行時會爲每個虛擬用戶建立一個進程;選擇「Run Vuser as a thread」則將每一個虛擬用戶做爲一個線程來運行,在任務管理器中只看到一個mmdrv.exe,這種方式的運行效率更高,能形成更大的壓力,時默認選 項。另外,若是啓用了IP欺騙功能,則先在Controller中選中Tools菜單下的「Expert Mode」,而後將Tools菜單下的「Options>General」標籤頁中的IP地址分配方式也設置爲與Vuser運行方式一致,同爲線程 或進程方式。

22.在Controller中運行Web相關測試場景時,常常會有不少超時錯誤提示,如何處理這類問題?
答:這主要有腳本的默認超時設置引發。當回放Web腳本時,有時候由 於服務器響應時間較長,會產生超時的錯誤。這時須要修改腳本的運行時配置。進入「Run-time Setting」對話框後,依次進入「Internet Protocol→Preference」。而後點擊「Options…」按鈕,進入高級設置對話框,能夠修改各種超時設置的默認值。

23.爲何Windows系統中的CPU、內存等資源仍然充足,可是模擬的用戶數量卻上不去?
答:在Windows計算機的標準設置下,操做系統的默認限制只能使 用幾百個Vuser,這個限制與CPU或內存無關,主要是操做系統自己規定了默認的最大線程數所致使。要想突破Windows這個限制,須修改 Windows註冊表。以Windows XP Professional爲例。
1)打開註冊表後,進入註冊表項HKEY_LOCAL_MACHINE中的下列關鍵字:System\CurrentControlSet\Control\Session Manager\SubSystems。
(2)找到Windows關鍵字,Windows關鍵字以下所示:
  %SystemRoot%\system32\csrss.exe bjectDirectory=\Windows
  SharedSection=1024,3072,512 Windows=On SubSystemType=Windows ServerDll=basesrv,1
  ServerDll=winsrv:UserServerDllInitialization,3 ServerDll=winsrv:ConServerDllInitialization,2
  ProfileControl=Off MaxRequestThreads=16
  SharedSection=1024,3072,512關鍵字的格式爲xxxx,yyyy,zzz。其中,xxxx定義了系統範圍堆的最大值(以KB爲單位),yyyy定義每一個桌面堆得大小。
3)將yyyy的設置從3072更改成8192(即8MB),增長SharedSection參數值。
  經過對註冊表的更改,系統將容許運行更多的線程,於是能夠在計算機上運行更多的Vuser。這意味着可以模擬的最大併發用戶數量將不受Windows操做系統的限制,而只受硬件和內部可伸縮性限制的約束。

24.Controller中設置了用戶併發數量,可是運行時爲什麼初始化的用戶數量少於實際數量?
答:主要時設置問題。在Tools→options→Run- time setting中能夠設置每次最多初始化的虛擬用戶。若是須要100個併發用戶,則將該值設置爲大於100的數值。另外,注意LoadRunner相關協 議License的更新,確保使用的License可以容許所須要的併發用戶數量。

25.如何讓場景的用戶執行發生錯誤繼續運行,以保證不間斷進行壓力測試?
答:用VuGen打開虛擬用戶腳本後,進入「Run-time Settings」對話框後,依次進入「General→Miscellaneous」,能夠看到Miscellaneous設置中關於「Error Handling」的配置。勾選「Continue on error」便可讓虛擬用戶發生錯誤繼續運行。

26.爲何.NET虛擬用戶有時不能在遠程主機執行?
答:主要時LoadRunner的版本問題。根據筆者的經驗,若是是Microsoft Visual Studio 2005開發的虛擬用戶,同時LoadRunner客戶端的版本低於8.1,執行Controller的主機將會發生錯誤。
所以要想正確的運行Microsoft Visual Studio 2005開發的.NET虛擬用戶,客戶端最好裝8.1以上的版本,Controller的主機則安裝8.0和8.1兩個版本都可。此外,產生壓力的 LoadRunner客戶端上預先應該安裝.NET運行環境,若是Microsoft Visual Studio 2005開發的是.NET虛擬用戶,則應該安裝Microsoft .NET Framework SDK v2.0。

27.測試分析結果中會統計Action時間,而實際上可能並不需要這些數據,如何只顯示本身定義的用戶事務?
答:進入腳本的運行時設置,依次進入General→Miscellaneous。 默認狀況下,自動事務配置「Automatic Transactions」下有兩個選項:第一個是把腳本的Action部分定義爲一個事務;第二個時把腳本的每一部分定義爲一個事務。去掉這兩個勾選 後,測試結果將會只顯示本身定義的用戶事務。

28.測試結果中,Summary和平均事務響應時間圖裏的各個事務的最大值、平均值、最小值爲何顯示不同?
答:主要是受採樣時間的影響。Summary裏的事務平均響應時間是 根據整個場景執行過程獲得的數據計算所得,最大值與最小值也是從整個場景中獲得的。平均事務響應時間圖主要時按照LoadRunner分析出來的採樣頻率 來獲取事務響應時間的最大值與最小值,而後計算平均值。能夠經過「Set Granularity」來修改平均事務響應時間圖的採樣頻率。若是把「Granularity」設爲場景執行時間,則統計結果將會一致。

29.統計結果中的總點擊量Total Hits時用戶的鼠標點擊次數嗎?
答:Total Hits不時按照用戶的鼠標點擊次數來計算的,而是按照各個虛擬客戶端向後臺發起的總的請求數來進行統計的。例如在向服務器請求的一個頁面中,若是該頁面 包含5個圖片,用戶只要單擊鼠標就能夠訪問該頁面,而單個虛擬用戶在LoadRunner訪問的點擊量爲1+5=6次。

30.有些Web測試結果分析圖(例如每秒返回頁面數)在測試結果分析圖中沒法看到,如何進行配置?
答:用VuGen打開虛擬用戶腳本後,進入「Run-time Settings」對話框後,依次進入「Internet Protocol>Preference」,能夠看到一些Web性能圖配置。勾選上面得選項後,Controller將會在測試執行過程當中生成數 據,而後可在Analysis中查看相應的性能結果分析圖。
、Step download timeout (120 seconds)
解決辦法:
一、修改run time setting中的請求超時時間,增長到600s,其中有三項的參數能夠一次都修改了,HTTP-request connect timeout,HTTP-request receieve timeout,Step download timeout,分別建議修改成600、600、5000;run time setting設置完了後記住還須要在control組件的option的run time setting中設置相應的參數;
二、辦法一不能解決的狀況下,解決辦法以下:
設置runt time setting中的internet protocol-preferences中的advaced區域有一個winlnet replay instead of sockets選項,選項後再回放就成功了。切記此法只對windows系統起做用,此法來自zee的資料。

31.問題描述Connection reset by peer
這個問題很少碰見,通常是因爲下載的速度慢,致使超時,因此,須要調整一下超時時間
解決辦法:Run-time setting窗口中的‘Internet Protocol’-‘Preferences’設置set advanced options(設置高級選項),從新設置一下「HTTP-request connect timeout(sec),能夠稍微設大一些」;

32.問題描述connection refused
這個的錯誤的緣由比較複雜,也可能很簡單也可能須要查看好幾個地方,解決起來不一樣的操做系統方式也不一樣;
一、首先檢查是否是鏈接weblogic服務過大部分被拒絕,須要監 控weblogic的鏈接等待狀況,此時須要增長acceptBacklog,每次增長25%來提升看是否解決,同時還須要增長鏈接池和調整執行線程數, (鏈接池數*Statement Cache Size)的值應該小於等於oracle數據庫鏈接數最大值;
二、若是方法一操做後沒有變化,此時須要去查看服務器操做系統中是否對鏈接數作了限制,AIX下能夠直接vi文件limits修改其中的鏈接限制數,還有tcp鏈接等待時間間隔大小,wiodows相似,只不過wendows修改註冊表,具體修改方法查手冊,註冊表中有TcpDelayTime項;

33.問題描述open many files
答:問題通常都在壓力較大的時候出現,因爲服務器或者應用中間件自己對於打開的文件數有最大值限制形成,解決辦法:
一、修改操做系統的文件數限制,aix下面修改limits下的nofiles限制條件,增大或者設置爲沒有限制,儘可能對涉及到的服務器都做修改;
二、方法一解決不了狀況下再去查看應用服務器weblogic的commonEnv.sh文件,修改其中的nofiles文件max-nofiles數增大,應該就能夠經過了,具體就是查找到nofiles方法,修改其中else條件的執行體,把文件打開數調大;修改前記住備份此文件,防止修改出錯;

34.問題描述has shut down the connection prematurely
  通常是在訪問應用服務器時出現,大用戶量和小用戶量均會出現;
  來自網上的解釋:
  1> 應用訪問死掉。小用戶時:程序上的問題。程序上存在數據庫的問題
  2> 應用服務沒有死
    應用服務參數設置問題
  例如:
  在許多客戶端鏈接Weblogic應用服務器被拒絕,而在服務器端沒有錯誤顯示,則有多是Weblogic中的server元素的AcceptBacklog屬性值設得太低。若是鏈接時收到connection refused消息,說明應提升該值,每次增長25%
  Java鏈接池的大小設置,或JVM的設置等
  3> 數據庫的鏈接
  在應用服務的性能參數可能過小了
  數據庫啓動的最大鏈接數(跟硬件的內存有關)
  以上信息有必定的參考價值,實際狀況能夠參考此類調試。
  若是是以上所說的小用戶時:程序上的問題。程序上存在數據庫的問題,那就必須採用更加專業的工具來抓取出現問題的程序,主要是程序中執行效率很低的 sql語句,weblogic能夠採用introscope定位,期間能夠注意觀察一下jvm的垃圾回收狀況看是否正常,我在實踐中併發500用戶和 600用戶時曾出現過jvm鋸齒型的變化,上升降低都很快,這應該是不太正常的。

35.問題描述Failed to connect to server
這個問題通常是客戶端連接到服務失敗,緣由有兩個客戶端鏈接限制(也就是壓力負載機器),一個網絡延遲嚴重,解決辦法:
  一、修改負載機器的tcpdelaytime註冊表鍵值,改小;
  二、檢查網絡延遲狀況,看問題出在什麼環節;
  建議爲了減小這種狀況,辦法一最好測試前就完成了,保證乾淨的網絡環境,每一個負載機器的壓力測試用戶數不易過大,儘可能平均每臺負載器的用戶數,這樣以上問題出現的機率就很小了。

36.問題描述:Overlapped transmission of request to ... WSA_IO_PENDING
解決方法:
  一、方法一,在腳本前加入web_set_sockets_option("OVERLAPPED_SEND", "0"),禁用TTFB細分,問題便可解決,可是TTFB細分圖將不能再使用,附圖。
  二、方法二,能夠經過增長鏈接池和應用系統的內存,每次增長25%。

37.問題描述:Deleted the current transaction ... since response time is not accurate
這個問題很少碰見,通常出如今壓力機器上發生ping值爲負數(AMD雙核CPU),能夠從新啓動pc機或者打補丁,附圖。

38.問題描述:HTTP Status-Code=500 (Internal Server Error) for
一、應用服務當掉,從新啓動應用服務。
二、當應用系統處於的可用內存處於閥值如下時,出現HTTP Status-Code=500的機率很是高,此時只要增長應用系統的內存,問題便可解決。

39.問題描述:Failed to transmit data to network: [10057] Socket is not connected
這個錯誤是由網絡緣由形成的,PC1 和PC2上面都裝了相同的loadrunner 9.0,且以相同數量的虛擬用戶數運行相同的業務(機器上的其餘條件都相同),PC1上面有少部分用戶報錯,PC2上的用戶所有執行經過。

40.問題描述:Error -27257: Pending web_reg_save_param/reg_find/create_html_param[_ex] request(s) detected and reset at the end of iteration number 1
解決方法:web_reg_save_param位置放錯了,應該放到請求頁面前面。

41.問題描述:經過Controler調用遠程代理時報錯,Error: CCI security error:You are running under secure mode and the function system is not allowed in this mode.
解決方法:在代理開啓的時候,去掉勾選防火牆選項。

42.Error -27796: Failed to connect to server "10.102.8.201:80": [10048] Address already in use
Try changing the registry value
HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\tcpip\Parameters\TcpTimedWaitDelay to 30and HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\tcpip\Parameters\MaxUserPort to 65534 and rebooting the machine
See the readme.doc file for more information
解決辦法:由於負載生成器的性能太好,發數據包特別快,服務器也響應特別快,從而致使負載生成器的機器的端口在沒有timeout以前就所有佔滿了。在所有佔滿後,就會出現上面的錯誤。執行netstat –na命令,能夠看到打開了不少端口。因此就調整TCP的time out。即在最後一個端口尚未用到時,前面已經有端口在釋放了。
1. 打開LoadRunner負載機所在機器的註冊表,將 HKEY_LOCAL_MACHINESystemCurrentControlSetServicestcpipParameters項中的 TcpTimedWaitDelay值設置爲5s或者其它(按須要調整)也能夠把MaxUserPort值調大(若是這個值不是最大值的話),同時增長腳 本的think time,再重啓機器。
2.取消勾選controller的run-setting-times-browser-browser emulation 「simulate a new user on each iteration」項。

43.Action.c(6): Error -27792: Failed to transmit data to network: [10054] Connection reset by peer
解決辦法:腳本和場景迭代延遲時間設置要相同
 
44.Files transfer error: C:\Documents and Settings\Administrator.SCMCC\Local Settings\Temp\brr_YAR.313\netdir\e\測試組\生產環境\UUC接口\uuc_shell\綜合場景2\results\res\10.101.11.82_2073.eve
 
Write failure on machine 10.101.11.82. Check the available disk space.
All Vusers on this machine will stop running
 
Error: Failed to write data to the .eve file. Check that the remote host has enough disk space: system error - 磁盤空間不足
 
Error: Failed returning to the last proper record in the .eve file: "C:\Documents and Settings\Administrator.SCMCC\Local Settings\Temp\brr_YAR.313\netdir\e\測試組\生產環境\UUC接口\uuc_shell\綜合場景2\results\res\10.101.11.82_2073.eve".
 
解決辦法:壓力機磁盤空間不足形成的。

45.Action.c(38): Error -27492: "HttpSendRequest" failed, Windows error code=12002 and retry limit (0) exceeded for URL
解決辦法:在runtime setting中的preferences- ->options-->http-request connect timeout(sec)的值設爲999。

46.Action.c(6): Error -26612: HTTP Status-Code=500 (Internal Server Error) for http://192.168.0.8:10001/logonConsole.do;jsessionid={JSESSIONID2}
解決辦法:形成HTTP-500錯誤以下幾個可能:
一、運行的用戶數過多,對服務器形成的壓力過大,服務器沒法響應,則報HTTP500錯誤。減少用戶數或者場景持續時間,問題獲得解決。
二、該作關聯的地方沒有去作關聯,則報HTTP500錯誤。進行手工或者自動關聯,問題獲得解決。
三、錄製時請求的頁面、圖片等,在回放的時候服務器找不到,則報HTTP500錯誤,若該頁面可有可無,則能夠在腳本中註釋掉,問題將會獲得解決。例如:有驗證碼的狀況下,儘管測試時已經屏蔽了,可是錄製的時候提交了請求,但回放的時候不存在響應。
四、參數化時的取值有問題,則報HTTP500錯誤。可將參數化列表中的數值,拿到實際應用系統中進行測試,可排除問題。
五、更換了應用服務器(中間件的更換,如tomcat、websphere、jboss等),仍是利用原先錄製的腳本去運行,則極可能報HTTP500錯誤。由於各類應用服務器處理的機制不同,所錄製的腳本也不同,解決辦法只有從新錄製腳本。
六、Windows xp2 與ISS組件不兼容,則有可能致使HTTP500錯誤。對ISS組件進行調整後問題解決。
七、系統開發程序寫的有問題,則報HTTP500錯誤。例若有些指針問題沒有處理好的,有空指針狀況的存在。修改程序後問題解決。
日誌發現報了不少0ra-01000錯誤,這是oracle達到最大遊標參數值,google了下,最大緣由多是JDBC鏈接沒關閉。最後查找weblogic鏈接池出了問題,不少鏈接沒關閉。 查找後臺

47.Action.c(15): 錯誤-27496: 內部錯誤(呼叫客戶服務): _eStat (7) != LRW_ITEM_STAT_ENUM_UNHANDLED for HandledTask at 048E180C
Action.c(56): Error -27995: Requested link ("Text=計劃管理") not found  [MsgId: MERR-27995]
解決方法:在IE中的工具—>Internet選項—>高級—>HTML設置中選擇第二個腳本類型。

48.錯誤 -27279:內部錯誤(呼叫客戶服務):Report initialization failed , error code = -2147467259 [MsgId : MERR-27279 ]
解決辦法:建議重裝一下LR。這種問題有可能和你安裝有關.dll文件出錯不是說寫的程序就能修改的。

49. Error -10489 : Exception was raised when calling per-thread-terminate function
在用Loadrunner實施性能測試時,採用Goal模式加壓,存在若是持續長 時加壓時LoadRunner的Controller會報 Error -10489 : Exception was raised when calling per-thread-terminate function錯誤;
產生緣由:
 Unlike the earlier Windows versions, Windows 2000 and Windows XP have the default environment set to C:\Document and Settings\<user-name>\Local Settings\Temp instead of C:\Windows\temp. This long path with a space can cause several problems for LoadRunner. To resolve the issue, change to a directory without empty spaces。

解決方法:在C盤(或是其它盤都可以)新建TEMP文件夾(爲了後續設置臨時文件準備),右鍵"個人電腦"->高級->環境變量->編輯修改TEMP變量目錄,指身上面新建的目錄,如個人指向C:\TEMP->保存便可。
50.Error -27727: Step download timeout (120 seconds)has expired when downloading resource(s). Set the 「Resource Page Timeout is a Warning」 Run-Time Setting to Yes/No to have this message as a warning/error, respectively
解決方法:Run-Time Setting → Internet Protocol →Preferences→Option →Step download timeout(sec)改成32000
      A、應用服務參數設置太大致使服務器的瓶頸
  B、頁面中圖片太多
  C、在程序處理表的時候檢查字段太大或多

51.Action.c(16): Error -27728: Step download timeout (120 seconds) has expired when downloading non-resource(s)。
錯誤分析:對於HTTP協議,默認的超時時間是120秒(能夠在LoadRunner中修改),客戶端發送一個請求到服務器端,若是超過120秒服務器端尚未返回結果,則出現超時錯誤。

解決辦法:首先在運行環境中對超時進行設置,默認的超時時間能夠設置長一些,再設置屢次迭代運行,若是還有超時現象,須要在"Runtime Setting">"Internet Protocol:Preferences">"Advanced"區域中設置一個"winlnet replay instead of sockets"選項,再回放是否成功。

5二、Action.c(38): Error -27492: "HttpSendRequest" failed, Windows error code=12002 and retry limit (0) exceeded for URL
解決辦法:在runtime setting中的preferences- ->options-->http-request connect timeout(sec)的值設爲999。

5三、Action.c(81):Continuing after Error -27498: Timed out while processing URL=http://172.18.20.70:7001/workflow/bjtel/leasedline/ querystat/ subOrderQuery.do
錯誤分析:這種錯誤經常是由於併發壓力過大,服務器端太繁忙,沒法及時響應客戶端的請求而形成的,因此這個錯誤是正常現象,是壓力過大形成的。若是壓力很小就出現這個問題,多是腳本某個地方有錯誤,要仔細查看腳本,提示的錯誤信息會定位某個具體問題發生的位置。

解決辦法:例如上面的錯誤現象問題定位在某個URL上,須要再次運行一下場景,同時在其餘機器上訪問此URL。若是不能訪問或時間過長,多是服務器或者 此應用不能支撐如此之大的負載。分析一下服務器,最好對其性能進行優化。若是再次運行場景後還有超時現象,就要在各類圖形中分析一下緣由,例如能夠查看是 否服務器、DNS、網絡等方面存在問題。最後,增長一下運行時的超時設置,在"Run-Time Settings">"Internet Protocol:Preferences"中,單擊"options",增長"HTTP-request connect timeout" 或者"HTTP-request receive"的值。

5四、用strtok函數分割字符串
須要在loadrunner裏面得到「15」(下面紅色高亮的部分),並作成關聯參數。
//Body response 內容: <BODY><; PRE>//OK[8,7,5,15,6,5,0,4,0,3,0,3,2,0,0,0,1
用web_reg_save_param取出「8,7,5,15,6,5,0,4,0,3,0,3,2,0,0,0,1」這一段,而後用strtok函數切割出一個個數字,第四個數字就是要找的值
例如:
extern char * strtok(char * string, const char * delimiters ); // Explicit declaration
char separators[] = ",";
char * token;
lr_save_string("1,2,3,4,5,6","str");
token = (char *)strtok(lr_eval_string("{str}"), separators); // Get the first token
if (!token) {
        lr_output_message ("No tokens found in string!");
        return( -1 );
    }
while (token != NULL ) { // While valid tokens are returned
       lr_output_message ("%s", token );
       token = (char *)strtok(NULL, separators); // Get the next token
   }

5五、測試RTMP協議應該在LoadRunner選擇什麼協議來錄製?
解決辦法:用flex協議,有這幾個函數可用:
flex_rtmp_connect Connects a client to an RTMP server and sets connection options. 
flex_rtmp_disconnect Disconnects a client from an RTMP server. 
flex_rtmp_send Sends messages to an RTMP server. 
flex_rtmp_receive Receives responses from an RTMP server
Flex can record and replay scripts involving RTMP (Real Time Messaging Protocol). In order to enable RTMP simulation, you must configure the recording options for the Flex protocol.
To enable RTMP:
1 Open the Recording Options dialog box by selecting Tools > Recording Options or clicking the Options button in the Start Recording dialog box.
2 In the Network > Port Mapping node click Options.
3 Set the Send-Receive buffer size threshold to 1500.

5六、如何在LoadRunner中運行QTP腳本?
一、運行準備:
1)勾選QTP的Tools--Options--Run的"Alow other Mercury products to run tests and components"
2)錄製須要在lr中運行的QTP腳本,而且在QTP腳本中設置事務,Services.StartTransaction "start"與Services.EndTransaction "start"
二、運行QTP腳本
在LR中運行時選擇QTP腳本,爲QTP腳本存放目錄下文件擴展名爲.usr的文件。
注:LR中運行QTP腳本時,只能有一個Vuser,不然將報錯:
The load generator is currently running the maximum number of Vusers of this type

5七、在LR中如何忽略Socket接收數據的驗證
在LR中對Socket進行性能測試時,LR會本身判斷lrs_receive回來的數據的長度,而若是長度不符的話會有時間延遲的狀況(這是性能測試徹底不能接受的事情),若是作到這一點呢,通過反覆嘗試,發現一種簡單的方法(用*代替具體的長度):
相似於將:
recv buf1 12
"Hello, Denny"
改成:
recv buf1 *
"Hello, Denny"
一切OK。

5八、LoadRunner9.5的Controller中不能添加Apache的監控
在C:\Program Files\HP\LoadRunner\dat\online_graphs中找到online_resource_graphs.rmd文件,修改[Apache]部分中的EnableInUI爲1
參考:
http://forums11.itrc.hp.com/service/forums/questionanswer.do?admit=109447626+1274450165814+28353475&threadId=1229523

5九、VB Vuser開發ADO腳本,提示「user-defined type not defined」
想在VB Vuser寫入模擬數據操做的過程,而後在VB Vuser裏定義了這個全局變量
Private m_Conn As ADODB.Connection '鏈接對象
Private m_Reco As ADODB.Recordset '結果集
可是在VB Vuser中不識別這個對象,報出user-defined type not defined
須要在Run-Time 設置中的VBA部分把ADO的庫選上
若是用VB Script虛擬用戶來開發就不要,直接用CreateObject來建立ADO對象便可

60、loadrunner9.5錄製腳本時出現c:\PROGRA~1\MICROS~1\office12\Grooveutil.DLL時出錯內存位置訪問無效
解決辦法:Office2007的問題,IE加載項禁用Groove GFSBrowser Helper 組件

6一、LR自帶的例子端口號怎麼修改?
LR自帶的例子端口號是1080,我怎麼樣把這個端口設置我本身想用的端口號8088,在什麼地方設置
在LR安裝目錄下,找到Xitami.config文件,找到portbase,能夠修改它(默認是1000);默認的端口號是portbase+80;要把端口號改爲8088,就把portionbase改成8008,保存以後就是了(8088=8008+80)。

6二、用Web_reg_find查找中文字符串時查找不到?
解決辦法:腳本文件裏有個default.cfg ,裏面有個參數是 UTF8InputOutput ,將其值改成0

6三、替代IP Wizard的腳本
http://hi.baidu.com/higkoo/blog/item/39bbb21bc33d76dcac6e751c.html
LoadRunner自帶的「IP Wizard」用起來很是麻煩,要不停的點,重要的是最後還必須重啓系統生效。
因而乎寫個腳本替代之:
1. 假設客戶端IP爲 192.168.10.31
2. 假設服務端IP爲 192.168.10.10
3. 須要模擬的IP爲 110.119.120.122
那麼,客戶端提供添加虛擬IP的BAT腳本:
netsh  interface   ip    add    address    本地鏈接  110.119.120.122  255.255.0.0
對應的刪除設置爲:
netsh   interface   ip    del    address    本地鏈接    110.119.120.122
對應服務器添加虛擬路由的Shell腳本:
route add -host 110.119.120.122 gw 192.168.10.31
刪除路由的腳本:
route del -host 110.119.120.122 gw 192.168.10.31
這樣就很是方便了,不用重啓任何機器,執行腳本就生效,再執行腳本就取消。

6四、如何從命令行調用LoadRunner腳本?
 Here is the command line that you need to execute to run a VuGen script from the command prompt:
<LoadRunner>\bin\mmdrv.exe -usr <path to usr file>
Note:
In order to get all the other options that go with the command, run mmdrv.exe from the command prompt without any options.

6五、請問"int64這個類型,在LR中怎麼表示"。我將一段C的代碼放在LR中,LR不認int64這個類型,怎麼解決?
解決辦法:把那段C代碼作成DLL,而後在LR中調用。
 
66. apache須要佔用 80和443端口 可是LoadRunner Agent Service佔用的也是443端口 就衝突了
 
67. 錄製請求結束之後, Action裏是空白的, 能夠嘗試作一下以下修改:
start Recording - Options - Network - Port Mapping, 選擇Socket level and WinNet level data.
相關文章
相關標籤/搜索