LR 常見問題收集及總結

一:LoadRunner常見問題整理

      1.LR 腳本爲空的解決方法:

       1.去掉ie設置中的第三方支持取消掉html

       2.在系統屬性-高級-性能-數據執行保護中,添加loadrunner安裝目錄中的vugen.exe文件.node

 有多是因爲錄製的URL地址採用的是localhost的問題,改爲分配的IP地址或127.0.0.1試試。web

3、插入文本檢查點步驟時,使用web_reg_find,一般TextPfx和TextSfx中會包含雙引號,須要進行轉義(用斜槓),例如:面試

       web_reg_find("Search=Body",ajax

              "SaveCount=Welcome",算法

             "TextPfx=歡迎<a class=\"drop\" id=\"viewpro\" onMouseOver=\"showMenu(this.id)\">",數據庫

              "TextSfx=</a>",windows

              LAST)api

 遇到flight界面爲空的解決的可能方法:數組

  1、若是安裝了IE之外的瀏覽器,而且IE不是默認瀏覽器,則沒法生成錄製腳本

  2、若是錄製腳本時IE不能打開,則須要將瀏覽器的IE工具高級選項中,將「啓用第三方瀏覽器擴展」的

勾選去掉

  3、lr自帶的webtours系統,若是點擊Flights選項,出現空白頁面,請檢查本機oracle的 PERL5LIB環境

      2.LoadRunner錄製腳本時爲何不彈出IE瀏覽器?

  當一臺主機上安裝多個瀏覽器時,LoadRunner錄製腳本常常遇到不能打開瀏覽器的狀況,能夠用下面的方法來解決。

  啓動瀏覽器,打開Internet選項對話框,切換到高級標籤,去掉「啓用第三方瀏覽器擴展(須要重啓動)」的勾選,而後再次運行VuGen便可解決問題

  提示:一般安裝Firefox等瀏覽器後,都會勾選上面得選項,致使不能正常錄製。所以建議運行LoadRunner得主機上保持一個乾淨的測試環境。

      3.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」模式進行錄製。

      4.運行時的Pacing設置主要影響什麼?

     Pacing主要用來設置重複迭代腳本的間隔時間。共有三種方法:A:上次迭代結束後馬上開始、 B:上次迭代結束後等待固定時間、C:按固定或隨機的時間間隔開始執行新的迭代。

     根據實際須要設置迭代便可。一般,沒有時間間隔會產生更大的壓力。

    5.運行時設置Log標籤中,若是沒有勾選「Enable logging」,則手工消息能夠發送嗎?

  Enable logging選項僅影響自動日誌記錄和經過lr_log_message發送的消息。即便沒有勾選,虛擬用戶腳本中若是使用lr_message、lr_output_message、lr_error_message,仍然會記錄其發出的消息。

    6.VuGen支持Netscape的客戶證書嗎?

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

   7.VuGen會修改錄製瀏覽器中的代理服務器設置嗎?

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

    8.在LoadRunner腳本如何輸出當前系統時間?

  LoadRunner提供了char *ctime(const time_t *time)函數,調用參數爲一個Long型的整數指針,用於存放返回時間的數值表示。

  調用語句與返回值以下示例:

  typedef long time_t;

  Action()

  {

  time_t t;

  lr_message(「Time in seconds since 1/1/70: %ld\n」,time(&t));

  lr_message(「System time and date: %s」,ctime(&t));

  }

  輸出結果爲:

  Time in seconds since 1/1/70: 1185329968

  System time and date:Wed Jul 25 10:19:28 2007

    9.一些Web虛擬用戶腳本錄製後馬上回放沒有任何問題,可是當設置迭代次數大於1時,若是進行回放則只能成功迭代一次。爲何從第二次迭代開始發生錯誤?

  這種現象可能是因爲在「Run-time Setting」的「Browse Emulation」的設置中,勾選了「Simulate a new user on each iteration」及其下面的選項「Clear cache on each iteration」這兩個選項的含義是每次迭代時模擬一個新的用戶及每次迭代時清除緩存。

  因爲腳本迭代時,init和end只能執行一次,若是每次迭代都模擬一個新的用戶並清除緩存,則用戶登陸信息將一併清除,所以迭代時可能會發生錯誤。

  10.虛擬客戶腳本「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運行方式一致,同爲線程或進程方式。

  11.在Controller中運行Web相關測試場景時,常常會有不少超時錯誤提示,如何處理這類問題?

  這主要有腳本的默認超時設置引發。當回放Web腳本時,有時候因爲服務器響應時間較長,會產生超時的錯誤。這時須要修改腳本的運行時配置。

  進入「Run-time Setting」對話框後,依次進入「Internet Protocol→Preference」。而後點擊「Options…」按鈕,進入高級設置對話框,能夠修改各種超時設置的默認值。

  13爲何Windows系統中的CPU、內存等資源仍然充足,可是模擬的用戶數量卻上不去-27796?

      在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操做系統的限制,而只受硬件和內部可伸縮性限制的約束。

    14.Error -27728: Step download timeout (120 seconds)的解決方法

  loadruner報錯:Error -27728: Step download timeout (120 seconds)如 何解決語法檢查經過,可是在併發執行一個查詢時候報錯Action.c(16): Error -27728: Step download timeout (120 seconds) has expired when downloading non-resource(s),                                 請問有啥子解決方法,我使用web_set_timeout ,好象不起做用,直接在option中設置timeout時間爲600,(單位應該是秒吧)仍是沒有起做用,結果都仍是提示(120seconds),說 明仍是以120秒來判斷的;使用lrs_set_recv_timeout,語法檢查不過,說明庫函數裏面沒有這個函數。嘗試步驟:設置超時時間到600 秒,回放仍是出錯。後來我設置了runt time setting中的internet protocol-preferences中的advaced區域有一個winlnet replay instead of sockets選項,選項後再回放就成功了。   

   首先LR是 經過Microsoft WinInet DLL去錄製web協議的!可是在Control運行的時候它默認經過socket去模擬請求,由於這些能夠真實的模擬帶寬,而採用Microsoft WinInet DLL經過這個DLL去訪問網卡方式去模擬帶寬,使得模擬不是很精確!並且也不支持unix的應用,可是使用這個確實有時沒法處理winnet Dll的一些請求,我認爲是它的一些BUG,好比說:回放時它會檢查Content-Length,可是網頁支持receive more data時,這時socket模擬會一直等待直到timeout!先說了一些優缺點,最後回到這個問題!這個問題分兩個方面分析:

  第一:你要明白web_set_timeout()這 個函數的適用範圍!好比說一個web_submit_data()中實際涵蓋了10個對Server 端的請求,這個函數是針對10個請求的總和時間的!(別犯低級錯誤,timeout分了connect,receive以及download三個部分:) )                                                                            第二:就是我解釋的上面的一些BUG問題!WinInet dll在新版本中處理請求時能夠異步的,就是再也不是那種鏈接等待而後超時模式!可是LR用的socket是同步請求!只有等到timeout纔會退 出!microsoft已經明確表示INTERNET_OPTION_RECEIVE_TIMEOUT 再也不適用於 Microsoft Internet Explorer 5.0,顯而易見,他們處理請求採起了異步處理的方式!呵呵!這下大概能夠圓滿解釋你的問題了!呵呵這裏,

 我補充以下:VuGen專用的基於套接字的重播是一種可伸縮以便進行負載測試的輕型引擎。使用線程時是準確的。基於套接字的引擎不支持socks代理服務器。若是在這樣的環境中錄製,應該使用winInet重播引擎。

    15.性能測試每每須要準備大批量的數據,大批量數據的生成方法有不少種,常見的有:

       (1)編寫SQL語句來插入數據

(2)使用DataFactory等專業的數據生成工具

       (3)經過LoadRunner錄製回放的方式重複執行生成大批量數據

        Tips:

        使用DataFactory插入nchar數據類型的數據時會出現空值的狀況,能夠先修改數據庫的數據類型設置,插完數據後再改回來

 

    16.錄製腳本中包含中文,出現亂碼怎麼辦?

           把錄製選項中的Support charset選中UTF-8

           錄製腳本後,切換到樹視圖中,打開相應的腳本頁面。在右側的PageView中錄製的腳本呈現中文版式,可是當切換到Server Response中,全部的中文所有換成的亂碼,如「勌縗仫訆」。

          緣由是服務器端沒有把響應的編碼設置爲gb2312

在IIS中 找到Web.Config文件,在<system.web>….</system.web>節加 入<globalization requestEncoding="gb2312" responseEncoding="gb2312" fileEncoding="gb2312"/>後再次錄製腳本,亂碼變中文。

    17.LoadRunner回放腳本時,在瀏覽器顯示的中文是亂碼

解決辦法(1):

首先設置Run-Time Settings – Browser – Browser Emulation – User-Agent

而後設置IE:

查看-編碼-鉤上「自動選擇」和Unicode(UTF-8)。

解決辦法(2):

使用lr_convert_string_encoding函數來轉換編碼

下面是一個使用的例子:

lr_convert_string_encoding(lr_eval_string("{ReplyContents}"),LR_ENC_SYSTEM_LOCALE,LR_ENC_UTF8,"ReplyMessage");

       web_submit_data("postreply.aspx_2",

              "Action=http://127.0.0.1/postreply.aspx?infloat=1&topicid=2&&inajax=1",

              "Method=POST",

              "EncType=multipart/form-data",

              "RecContentType=text/xml",

              "Referer=http://127.0.0.1/showtopic-2.aspx",

              "Snapshot=t9.inf",

              "Mode=HTML",

              ITEMDATA,

              "Name=iconid", "Value=0", ENDITEM,

              "Name=title", "Value=", ENDITEM,

              "Name=wysiwyg", "Value=0", ENDITEM,

              "Name=checkbox", "Value=0", ENDITEM,

              "Name=message", "Value=[localimg=180,112]1[/localimg]\r\n\r\n{ReplyMessage}", ENDITEM,

              "Name=e_mediatyperadio", "Value=on", ENDITEM,

              "Name=sl_attachdesc", "Value=", ENDITEM,

              "Name=attachid", "Value=", ENDITEM,

              "Name=attachdesc", "Value=", ENDITEM,

              "Name=localid", "Value=", ENDITEM,

              "Name=attachdesc", "Value=", ENDITEM,

              "Name=localid", "Value=1", ENDITEM,

              "Name=attachdesc", "Value=", ENDITEM,

              "Name=localid", "Value=2", ENDITEM,

              "Name=emailnotify", "Value=on", ENDITEM,

              "Name=postreplynotice", "Value=on", ENDITEM,

              "Name=postfile", "Value=", "File=Yes", ENDITEM,

              "Name=postfile", "Value=D:\\\\圖片收集\\\\It's about time.JPG", "File=Yes", ENDITEM,

              "Name=postfile", "Value=", "File=Yes", ENDITEM,

              "Name=uploadallowmax", "Value=10", ENDITEM,

              "Name=uploadallowtype", "Value=jpg,gif", ENDITEM,

              "Name=thumbwidth", "Value=300", ENDITEM,

              "Name=thumbheight", "Value=250", ENDITEM,

              "Name=noinsert", "Value=0", ENDITEM,

              LAST);

    18.能夠在LR測試腳本的目錄中找到參數文件,直接修改參數文件

            The parameter file is stored in the script directory as .dat file extension.  It can be opened with a simple text editor like Notepad as it is stored in pure text format.  Therefore, you can manipulate the files via the Notepad.  You can also use office applications such as Microsoft Excel or OpenOffice.org Calc to work on the file.  This greatly the amount of work required for maintaining a long list of data.

    19.LR9.x啓動VUGen時提示"Failed to connect to server"

             After upgrading to LoadRunner 9.x I started getting a window popup which said "Failed to connect to server" every time I opened virtual user generator (vugen.exe).

The solution to this was to close virtual user generator and delete the [vugen.ini] file.

vugen.ini is found in the %systemroot% folder on your Windows PC (usually C:\WINDOWS or C:\WINNT).

Once you've deleted the file, virtual user generator will open without any issues and create a new vugen.ini file automatically.

    20.怎樣抓取有相同左右邊界的動態value?

怎樣抓取有相同左右邊界的動態value?例如:

stateID="d7lg0ehmjkkm6uin3s4boei7oq">

stateID="cvopakp46ftsf8mh6l37ti3ubm">

stateID="bv9mja8gtgr39ddibm5t9163re">

web_reg_save_param裏的ORD應該怎樣設置?

ORD: Indicates the ordinal position or instance of the match. The default instance is 1. If you specify "All," it saves the parameter values in an array.

例子:

char outFlightParam[50]; // The name of the parameter for correlation

char outFlightParamVal[50]; // The formatted value of outFlightParam

web_reg_save_param("outFlightVal",

        "LB=outboundFlight value=", "RB=>",

        "ORD=ALL",

        "SaveLen=18",

        LAST);

    web_submit_form("reservations.pl",

        "Snapshot=t4.inf",

        ITEMDATA,

        "Name=depart", "Value=London", ENDITEM,

        "Name=departDate", "Value=11/20/2003", ENDITEM,

        "Name=arrive", "Value=New York", ENDITEM,

        "Name=returnDate", "Value=11/21/2003", ENDITEM,

        "Name=numPassengers", "Value=1", ENDITEM,

        "Name=roundtrip", "Value=<OFF>", ENDITEM,

        "Name=seatPref", "Value=None", ENDITEM,

        "Name=seatType", "Value=Coach", ENDITEM,

        "Name=findFlights.x", "Value=83", ENDITEM,

        "Name=findFlights.y", "Value=16", ENDITEM,

        LAST);

    sprintf(outFlightParam, "{outFlightVal_%s}",

        lr_eval_string("{outFlightVal_count}"));

    sprintf(outFlightParamVal, "Value=%s",

        lr_eval_string(outFlightParam));

    lr_message("The value argument is : %s", outFlightParamVal);

    web_submit_form("reservations.pl_2",

       "Snapshot=t5.inf",

       ITEMDATA,

       "Name=outboundFlight",outFlightParamVal, ENDITEM,

        "Name=reserveFlights.x", "Value=92", ENDITEM,

        "Name=reserveFlights.y", "Value=10", ENDITEM,

        LAST);

    21.運行場景時提示「Step download timeout (120 seconds) has expired when downloading resource(s)」

vuser_init.c(12): Error -27728: Step download timeout (120 seconds) has expired when downloading non-resource(s)(出現個別,能夠忽略)

vuser_init.c(12): Error -27727: Step download timeout (120 seconds) has expired when downloading resource(s). Set the "Step Timeout caused by resources is a warning" Run-Time Setting to Yes/No to have this message as a warning/error, respectively

vuser_init.c(12): Error -27796

            若是以爲下載一個頁面超過2分鐘不是錯誤的話,能夠在Run-Time設置中選擇Preferences->Options,修改Step download timeout(sec)的時間

            

            或者把「Step timeout caused by resources is a warning」設置爲Yes,這樣下載資源超時也只是做爲警告,不做爲錯誤提示,可是對於非資源的下載超時,則老是會提示錯誤的

 

    22.用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

   }

    23.LoadRunner沒有購買webservice協議的license,只有http的,可不能夠徹底用http協議模擬webservice?

 能夠,參考:

   http://blog.testsautomation.com/2009/01/web-services-performance-using-loadrunner/

   http://blog.testsautomation.com/2009/05/validating-web-service-response-with-xpath/

    24.在場景設置中不忽略思考時間,可是在查看響應時間的時候怎樣讓LR自動在響應時間裏減去思考時間?

          在analysis中找到了設置是否在報告中包含思考時間的地方作相應的設置便可:

    25.LoadRunner在運行過程當中停掉1半虛擬用戶

Another issue that I’m facing from time to time is that LoadRunner stops 50% of running users without any notification, issue, error message etc. I’ve find out that it happens only when running with log level set to ‘always send a message’. Because of that, I suggest to run with log level set to ‘Send message only when error occur’.

    26.測試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.

    27.如何在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"

2、運行QTP腳本

在LR中運行時選擇QTP腳本,爲QTP腳本存放目錄下文件擴展名爲.usr的文件。

 注:LR中運行QTP腳本時,只能有一個Vuser,不然將報錯:

  The load generator is currently running the maximum number of Vusers of this type

    28.在LR中如何忽略Socket接收數據的驗證

在LR中對Socket進行性能測試時,LR會本身判斷lrs_receive回來的數據的長度,而若是長度不符的話會有時間延遲的狀況(這是性能測試徹底不能接受的事情),若是作到這一點呢,通過反覆嘗試,發現一種簡單的方法(用*代替具體的長度):

相似於將:

recv buf1 12

"Hello, Denny"

改成:

recv buf1 *

"Hello, Denny"

一切OK。

    29.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

    30.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對象便可

    31.loadrunner9.5錄製腳本時出現c:\PROGRA~1\MICROS~1\office12\Grooveutil.DLL時出錯內存位置訪問無效

              Office2007的問題,IE加載項禁用Groove  GFSBrowser Helper 組件

    32.LR自帶的例子端口號怎麼修改?

          LR自帶的例子端口號是1080,我怎麼樣把這個端口設置我本身想用的端口號8088,在什麼地方設置在LR安裝目錄下,找到Xitami.config文件,找到portbase,能夠修改它(默認是1000);

默認的端口號是portbase+80;要把端口號改爲8088,就把portionbase改成8008,保存以後就是了(8088=8008+80)。

    33.用Web_reg_find查找中文字符串時查找不到

            腳本文件裏有個default.cfg,裏面有個參數是 UTF8InputOutput ,將其值改成0

    34.替代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

這樣就很是方便了,不用重啓任何機器,執行腳本就生效,再執行腳本就取消。

    35.如何從命令行調用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.

    36.請問"int64這個類型,在LR中怎麼表示"。我將一段C的代碼放在LR中,LR不認int64這個類型,怎麼解決?

 把那段C代碼作成DLL,而後在LR中調用

    37.LoadRunner監控遠程機器Windows資源,提示「net use failed」

解決辦法:

在被監控機器上更改本地賬戶的共享和安全模式爲經典模式。控制面板->管理工具->本地安全策略->網絡訪問:本地賬戶的共享和安全模式->經典模式。

監視鏈接前的準備工做:

首先保證被監視的windows系統開啓如下二個服務Remote Procedure Call(RPC) 和Remote Registry Service

被監視的WINDOWS機器:右擊個人電腦,選擇管理->共享文件夾->共享 在這裏面要有C$這個共享文件夾,(要是沒有本身手動加)

而後保證在安裝LR的機器上使用運行.輸入\\被監視機器IP\C$ 而後輸入管理員賬號和密碼,若是能看到被監視機器的C盤了,就說明你獲得了那臺機器的管理員權限,可使用LR去鏈接了

   38.LoadRunner腳本中出現亂碼問題現象某個連接或者圖片名稱爲中文亂碼,腳本運行沒法經過。


  錯誤分析
  腳本錄製可能採用的是URL-based script方式,若是程序定義的字符集合採用的是國際標準,腳本就會出現亂碼現象。
  解決辦法從新錄製腳本,在錄製腳本前,打開錄製選項配置對話框進行設置,在「Recording Options」的「Advanced」選項裏先將「Surport Charset」選中,而後選中支持「UTF-8」的選項。

    39.LoadRunner不執行檢查方法錯誤現象在腳本中插入函數Web_find,在腳本中設置文本以及圖像的檢查點,可是在回放過程當中並無對設置的檢查點進行檢查,即Web_find失效。


  錯誤分析
  因爲檢查功能會消耗必定的資源,所以LoadRunner默認關閉了對文本以及圖像的數據執行保護檢查,因此在設置檢查點後,須要開啓檢查功能。
  解決辦法打開運行環境設置對話框進行設置,在「Run-time Settings」的「Internet Protocol」選項裏的「Perference」中勾選「Check」下的「Enable Image and text check」選項。
   須要注意的是,回放腳本時出現的錯誤有時是程序自身的緣由致使的,所以在解決腳本回放問題前必須保證程序錄製出的腳本是正確的。

  40.LoadRunner超時錯誤:在錄製Web協議腳本回放時超時狀況常常出現,產生錯誤的緣由也有不少,解決的方法也不一樣。

  錯誤現象1: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」選項,再回放是否成功。

 

  錯誤現象 2: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」的值。

  41.LoadRunner腳本中出現亂碼:在錄製Web協議腳本時出現中文亂碼,在回放腳本時會使回放中止在亂碼位置,腳本沒法運行。

  錯誤現象:某個連接或者圖片名稱爲中文亂碼,腳本運行沒法經過。

  錯誤分析:腳本錄製可能採用的是URL-based script方式,若是程序定義的字符集合採用的是國際標準,腳本就會出現亂碼現象。

  解決辦法:從新錄製腳本,在錄製腳本前,打開錄製選項配置對話框進行設置,在「Recording Options」的「Advanced」選項裏先將「Surport Charset」選中,而後選中支持「UTF-8」的選項。

  42.LoadRunner HTTP服務器狀態代碼:在錄製Web協議腳本回放腳本的過程當中,會出現HTTP服務器狀態代碼,例如常見的頁面-404錯誤提示、-500錯誤提示。

  錯誤現象1:-404 Not Found服務器沒有找到與請求URI相符的資源,但還能夠繼續運行直到結束。

  錯誤分析:此處與請求URI相符的資源在錄製腳本時已經被提交過一次,回放時不可再重複提交一樣的資源,而須要更改提交資源的內容,每次回放一次腳本都要改變提交的數據,保證模擬實際環境,形成必定的負載壓力。

解決辦法:在出現錯誤的位置進行腳本關聯,在必要時插入相應的函數。

 

  錯誤現象2:-500 Internal Server Error服務器內部錯誤,腳本運行中止。

  錯誤分析:服務器碰到了意外狀況,使其沒法繼續迴應請求。

  解決辦法:出現此錯誤是致命的,說明問題很嚴重,須要從問題的出現位置進行檢查,此時須要此程序的開發人員配合來解決,並且產生的緣由根據實際狀況來定,測試人員沒法單獨解決問題,並且應該儘快解決,以便於後面的測試。

  43.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應用中包含了與服務器進行交互的Java Applet、基於瀏覽器的應用中包含了向服務器進行通訊的JavaScript/VBScript代碼、基於瀏覽器的應用中使用HTTPS安全協議,這 時則使用「URL-based script」模式進行錄製。

  解決辦法:打開錄製選項配置對話框進行設置,在「Recording Options」 的「Internet Protocol」選項裏的「Recording」中選擇「Recording Level」爲「HTML-based script」,單擊「HTML Advanced」,選擇「Script. Type」爲「A script. containing explicit」。而後再選擇使用「URL-based script」模式來錄製腳本。

  44.LoadRunner不執行檢查方法:在錄製Web協議腳本中添加了檢查方法Web_find,可是在腳本回放的過程當中並無執行。

  錯誤現象:在腳本中插入函數Web_find,在腳本中設置文本以及圖像的檢查點,可是在回放過程當中並無對設置的檢查點進行檢查,即Web_find失效。

  錯誤分析:因爲檢查功能會消耗必定的資源,所以LoadRunner默認關閉了對文本以及圖像的檢查,因此在設置檢查點後,須要開啓檢查功能。

解決辦法:打開運行環境設置對話框進行設置,在「Run-time Settings」的「Internet Protocol」選項裏的「Perference」中勾選「Check」下的「Enable Image and text check」選項。

  45.LoadRunner回放Web Services協議腳本錯誤:LoadRunner 8.0版本在錄製Web Services協議的腳本時正常,但在回放時會出現錯誤,提示中止腳本運行。

  錯誤現象:利用LoadRunner 8.0版原本錄製Web Services協議的腳本沒有任何錯誤提示,回放腳本時會出現以下錯誤提示「Error:server returned an incorrectly formatted SOAP response」。

  錯誤分析:出現此錯誤的緣由是LoadRunner8.0在錄製Web Services協議的腳本時存在一個缺陷:若是服務器的操做系統是中文的,VuGen會自動將WSDL文件的頭改成<?xml version="1.0"encoding="zh_cn" ?>,因此纔會有此錯誤提示。

解決辦法:下載兩個補丁,分別爲「LR80WebServicesFPI_setup.exe」和「lrunner_web_ services_patch_1.exe」安裝上便可。

    46.LR啓動controller報錯「transaction monitor not available」

1.可能是OS系統問題,修復試試或升級

2.或修復LR試試

    47.Loadrunnber 報錯誤:Error -- memory violation : Exception ACCESS_VIOLATION received.的一種狀況

Posted on 2011-01-05 12:12蟈蟈俊 閱讀(433) 評論(0) 編輯收藏 

最近寫的一個Loadrunner腳本,最後一步是點擊「退出」按鈕退出登陸狀態,以下:

web_text_link("[退出]",

    "Snapshot=t18.inf",

    DESCRIPTION,

    "Text=[退出]",

    ACTION,

    "UserAction=Click",

    LAST);

return 0;

可是會報錯誤:

Action1.c(94): Error: C interpreter run time error: Action1.c (94): Error -- memory violation : Exception ACCESS_VIOLATION received.

Action1.c(94): Notify: CCI trace: Action1.c(94): web_text_link(0x02080870, 0x0208085f "Snapshot=t18.inf", 0x02080a42 "DESCRIPTION", 0x02080853, 0x02080a3b "ACTION", 0x020809de "UserAction=Click", 0x02080a6a "LAST")

Action1.c(94): Notify: CCI trace: Compiled_code(0): Action1()

通過試驗,發現是由於 退出後有個自動跳轉。

若是退出結束代碼修改成下面就沒有問題了。

    web_text_link("[退出]",

       "Snapshot=t18.inf",

       DESCRIPTION,

       "Text=[退出]",

       ACTION,

       "UserAction=Click",

       LAST);

    web_browser("Sync",

       "Snapshot=t18.inf",

       DESCRIPTION,

       ACTION,

        "Sync",

       LAST);

     return 0;

結論:

web_text_link若是有中間跳轉,不能放在代碼的最後,最後要有一個 Sync 。

    48.Step download timeout(sec)設置

     這個默認是120秒,可是常常咱們要設置的更大一些,具體設置方法:Vugen--》Vuser---》Runtime-settings----》Preferences------》option,將Step download timeout(sec)默認值120s改成本身須要的值,其次要改變HTTP-reguest connnect timeout(sec)和HTTP-reguest receive timeout(sec)也爲相應的值。

    49.修改本機tcp鏈接數

        由於我的pc機的默認的tcp鏈接數只有15個(xp),因此咱們在模擬虛擬多個用戶時,就會遇到tcp的鏈接限制,從而報錯。修改的方法:windows下運行 Patch.exe
輸入C,再輸入你要的TCP/IP鏈接數字(通常爲5002000)回車確認
輸入Y 回車確認。
倒計時15秒後結束。
接着再運行下Patch.exe,看鏈接數是否是由原來的10變成本身改了的數值。
Patch.exe 下載地址:http://www.touchboy.cn/2007/05/% ... %E6%8E%A5%E6%95%B0/

    50.關於Error -27791: Error -27790:Error -27740:錯誤的解決方法:

        錯誤以下:
Action.c(198): Error -27791: Server "www.zcpx.cn" has shut down the connection prematurely
Action.c(198): Error -27790: Failed to read data from server "www.zcpx.cn": [10053] Software caused connection
abort
Action.c(198): Error -27740: Overlapped transmission of request to "www.zcpx.cn" for URL

"http://www.zcpx.cn/userEntry.do" failed: WSA_IO_PENDING

解決辦法:
在腳本的最前面加上web_set_sockets_option("OVERLAPPED","0");

    51. LR中錯誤代號爲27796的一個解決方法

        錯誤以下:

52.

1A:註冊表不能訪問或寫致使的,能夠恢復註冊表或卸載(清除註冊表,可使用工具)從新安裝程序。
要啓支LR自帶的實例的服務時,出錯了,提示:端口已經被另外一個服務佔用,請問一下能不能本身修改這個程序原來設定的端口啊?
2A:中止服務以後,在程序的安裝目錄\WebTours下找到 xitami.cfg文件修改portbase值,注意 默認的端口號是portbase+80,portbase值是1000;要把端口號改爲 8088,就把portbase改成8008,保存以後就是了(8088=8008+80)。而後重啓服務 

 

二:LoadRunner面試(筆試)問題整理

1.      什麼是負載測試?什麼是性能測試?                                                                       

     負載測試是經過逐步增長系統負載,測試系統性能的變化,並最終肯定在知足性能指標的狀況下,系統所能承受的最大負載量的測試,例如,訪問一個頁面的響應時間規定不超過1秒,負載測試就是測試在響應時間爲1秒時,系統所能承受的最大併發訪問用戶的數量。

壓力測試一般是在高負載狀況下來對系統的穩定性進行測試,更有效地發現系統穩定性的隱患和系統在負載峯值的條件下功能隱患等。

性能測試:指在必定的約束條件下(指定的軟件、硬件、網絡環境等),肯定系統所能承受的最大負載壓力。

2.        性能測試包含了哪些測試(至少舉出3種)

 性能測試包含負載測試、壓力測試、大數據量測試、疲勞強度測試等。

3.   簡述性能測試的步驟

 第一,分析產品結構,明確性能測試的需求,包括併發、極限、配置和指標等方面的性能要求,必要時基於LOAD測試的相同測略需同時考慮穩定性測試的需求。
  第二,分析應用場景和用戶數據,細分用戶行爲和相關的數據流,肯定測試點或測試接口,列示系統接口的可能瓶頸,通常是先主幹接口再支線接口,並完成初步的測試用例設計。
  第三,依據性能測試需求和肯定的測試點進行測試組網設計,並明確不一樣組網方案的重要程度或優先級做爲取捨評估的依據,必要時在前期產品設計中提出支持性能測試的可測試性設計方案和對測試工具的需求。
  第四,完成性能測試用例設計、分類選擇和依據用戶行爲分析設計測試規程,並準備好測試用例將用到的測試數據。
    第五,肯定採用的測試工具。
      第六,進行初驗測試,以主幹接口的可用性爲主,根據測試結果分析性能瓶頸,經過迭代保證基本的指標等測試的環境。
      第七,迭代進行全面的性能測試,完成計劃中的性能測試用例的執行。
      第八,完成性能測試評估報告。
  在進行性能測試的時候,咱們須要知道一些有效的性能指標,下面咱們來列出一些主要的性能指標:
  一是,通用指標(指Web應用服務器、數據庫服務器必需測試項):
      *ProcessorTime:指服務器CPU佔用率,通常平均達到70%時,服務就接近飽和;
      *Memory Available Mbyte:可用內存數,若是測試時發現內存有變化狀況也要注意,若是是內存泄露則比較嚴重;
      *Physicsdisk Time :物理磁盤讀寫時間狀況。
      二是,Web服務器指標:
      *Avg Rps:平均每秒鐘響應次數=總請求時間/秒數;
      *Avg time to last byte per terstion(mstes):平均每秒業務角本的迭代次數;*Successful Rounds:成功的請求;
      *Failed Rounds:失敗的請求;
      *Successful Hits:成功的點擊次數;
      *Failed Hits:失敗的點擊次數;
      *Hits Per Second:每秒點擊次數;
      *Successful Hits Per Second:每秒成功的點擊次數;
      *Failed Hits Per Second:每秒失敗的點擊次數;
      *Attempted Connections:嘗試連接數。
      三是,數據庫服務器指標:
      *User 0 Connections :用戶鏈接數,也就是數據庫的鏈接數量;
      *Number of deadlocks:數據庫死鎖;
      *Butter Cache hit:數據庫Cache的命中狀況。

4.         簡述使用Loadrunner的步驟

  A4制定性能測試計劃—>開發測試腳本—>設計測試場景—>執行測試場景—>監控測試場景—>分析測試結果

5.         何時能夠開始執行性能測試?

  功能測試經過;通常須要進行性能測試的系統,都是用戶量比較大、業務使用比較頻繁、比較重要的功能模塊。

6.         LoadRunner由哪些部件組成?

  A6主要有三部分組成:

7.         你使用LoadRunner的哪一個部件來錄製腳本?

     使用Virtual User Generator錄製測試腳本

8.         LoadRunner的哪一個部件能夠模擬多用戶併發下回放腳本?

  LoadRunnerController組件。

9.         什麼是集合點?設置集合點有什麼意義?Loadrunner中設置集合點的函數是哪一個?

     在性能測試過程當中,須要模擬大量用戶在同一時刻,訪問系統並同時操做某一任務,能夠經過配置集合點來實現,多個用戶同時進行某操做;

    集合點能夠在服務器上建立密集的用戶負載,使LoadRunner可以測試服務器在負載狀態下的性能。

     設置集合點函數:lr_rendezvous("Meeting")  // Meeting是集合點名稱

10.     什麼是場景?場景的重要性有哪些?如何設置場景?

   場景用於模擬用戶實際業務操做;

     LoadRunner中場景有手工場景和麪向目標的場景。

設置場景:選擇場景類型、設置運行時設置、模擬用戶數、加減壓方式、持續時間,配置負載生成

1.選擇場景中須要的腳本
     2.選擇爲目標場景,仍是指定的手工場景
     3.設置用戶數、設置產生負載的設備
     4.設置執行策略

11.     請解釋一下如何錄製web腳本?

LR經過轉發請求,來捕獲數據包,來造成腳本

解釋:1.基於瀏覽器的應用程序推薦使用HTML-based Script, 腳本中採用
HTML頁面的形式來表示,這種方式的Script腳本容易維護,容易理解,使用該選項中的advance中的第一個選項,若是單純的HTML方式,是不容許使用關聯的。
2.不是基於瀏覽器的應用程序推薦使用URL-based Script,腳本中的表示採用基於URL 的方式,不是很好閱讀。
解釋:1.是否記錄錄製過程當中的ThinkTime,若是記錄,還能夠設置最大值,通常我不記錄這個值。
2.通知Vugen去從新設置每一個action之間的Http context,缺省是須要的。
3.完整記錄錄製過程的log,
4.保存一個本地的snapshot,能夠加速顯示
5.把html的title放到web_reg_find函數裏面
6.支持的字符集標準
7.Http header的錄製,咱們採用缺省便可,不須要用web_add_header去錄製非標準的header信息。
對錄製的content的內容進行filter,不做爲resource處理的。
 
解釋:這個就是我前面提到的關聯,系統已經預先設置好了一些常見的關聯rules,咱們錄製腳本以前,能夠把系統的

 

12.    爲何要建立參數?如何建立參數?
  參數:在環境變化時必須時腳本具備環境變化的能力,就須要參數化(客戶端發送到服務器端)
  1.肯定要參數話的數據
  2.設定規則形式來取值

13.    什麼是關聯?請解釋一下自動關聯和手動關聯的不一樣。

關聯:不少構架用sessionid等方法標識不一樣任務和數據,應用在每次運行時方式發送數據不徹底相同,須要利用的機制對錄製的腳本進行處理,這種機制叫作關聯(服務端發送到客戶端)

14.    場景設置有哪幾種方法?

目標場景,手工場景

15.    你如何找出哪裏須要關聯?請給一些你所在項目的實例
用戶登錄,
客戶端發送請求後,服務端驗證正確性後,發送給客戶端sessionid,是某種規則產生。

16.    你在哪裏設置自動關聯選項?
兩地方能夠設置
1.設置容許錄製時進行自動關聯,能夠自定義規則


2.錄製完成後,vuser-scan action for correlations

17.    哪一個函數是用來截取虛擬用戶腳本中的動態值?(手工關聯)

web_reg_save_param()函數主要根據須要作關聯的動態數據前面和後面的固定字符串來識別、提取動態數據,因此在作關聯時,須要找出動態數據的左、右邊界字符串。

18.    你在VUGen中什麼時候選擇關閉日誌?什麼時候選擇標準和擴展日誌?
Run-timelog
當調試腳本時,能夠只輸出錯誤日誌,當在場景找你管加載腳本時,日誌自動變爲不可用。
Standard Log Option:選擇標準日誌時,就會在腳本執行過程當中,生成函數的標準日誌而且輸出信息,供調試用。大型負載測試場景不用啓用這個選項。
擴展日誌包括警告和其餘信息。大型負載測試不要啓用該選項。用擴展日誌選項,能夠指定哪些附加信息須要加到擴展日誌中

19.    你如何調試LoadRunner腳本?
VuGen有兩個選項幫助調試Vuser腳本。Run Step by Step命令和斷點(breakpoints)。Option對話框中的調試設置(Debug setting)項,能夠肯定在場景執行過程當中執行軌跡範圍。調試信息寫在output窗口。能夠用 
lr_set_debug_messag函數在腳本中手工設置信息類型。若是咱們只想接收到一小段腳本的調式信息。

20.    你在LR中如何編寫自定義函數?請給出一些你在之前進行的項目中編寫的函數。
在建立用戶自定義函數前咱們須要和建立DLLexternal libary)。把庫放在VuGen bin目錄下。一旦加了庫,把自定義函數分配作一個參數。該函數應該具備一下格式:__declspec (dllexport) char* <function name>(char*, char*)
Milan

21.    什麼是逐步遞增?你如何來設置?
Ramp up這個選項用於逐漸增長服務器的虛擬用戶數或負載量。設置一個初始值並且能夠在兩個迭代之間設置一個值等待。設置Ramp up,請到‘Scenario Scheduling Options’

22.    以線程方式運行的虛擬用戶有哪些優勢?
VuGen提供了用多線程的便利。這使得在每一個生成器上能夠跑更多的虛擬用戶。若是是以進程的方式跑虛擬用戶,爲每一個用戶加載相同的驅動程序到內存中,所以佔用了大量的內存。這就限制了在單個生成器上能跑的虛擬用戶數。若是按線程運行,給定的全部虛擬用戶數(好比100)只是加載一個驅動程序實例到內存裏。每一個線程共用父驅動程序的內存,所以在每一個生成器上能夠跑更多的虛擬用戶。

23.    當你須要在出錯時中止執行腳本,你怎麼作?
lr_abort函數放棄虛擬用戶腳本的執行。說明虛擬用戶中止Action的執行,直接執行vuser_end而後結束執行。在出現錯誤狀況下想手工放棄腳本的執行,這個函數是有用的。用這個函數中止腳本時,Vuser被指定爲「Stopped」狀態。爲了這個函數起做用,開始時候就不能選擇Run-Time Settings中的Continue on error選項

24.    響應時間和吞吐量之間的關係是什麼?
吞吐量圖顯示的是虛擬用戶每秒鐘從服務器接收到的字節數。當和響應時間比較時,能夠發現隨着吞吐量的下降,響應時間也下降,一樣的,吞吐量的峯值和最大響應時間差很少在同時出現。

25.    說明一下如何在LR中配置系統計數器?
經過Web資源監視器,利用這些監控器能夠分析web服務器的吞吐量、點擊率、每秒http響應數以及每秒下載的頁面數。

26.    什麼是think time?think_time有什麼用?
思考時間是真實用戶在action之間等待的時間。例如:當一個用戶從服務器接收到數據時,用戶可能須要在響應以前等待幾分鐘回顧數據,這種推遲被稱爲思考時間。

27.    標準日誌和擴展日誌的區別是什麼?
Standard Log Option:選擇標準日誌時,就會在腳本執行過程當中,生成函數的標準日誌而且輸出信息,供調試用。大型負載測試場景不用啓用這個選項。
擴展日誌包括警告和其餘信息。大型負載測試不要啓用該選項。用擴展日誌選項,能夠指定哪些附加信息須要加到擴展日誌中

28.    解釋如下函數及他們的不一樣之處。
Lr_debug_message
lr_debug_message 函數在指定的消息級別
// 處於活動狀態時發送一條調試消息。若是指定的
// 消息級別未處於活動狀態,則不發出消息。
Lr_output_message
要發送不是特定錯誤消息的特殊通知,
Lr_error_message
函數將錯誤消息發送到
// 輸出窗口和 Vuser日誌文件
Lrd_stmt lrd_exec 函數執行 lrd_stmt設置的 SQL 語句。
Lrd_fetch  函數從結果集中提取後續若干行
result set. 
函數準備用於
// 經過光標輸出字符串(一般爲 SQL語句)
// 的下一結果集。對於 CtLib,它發出 ct_result
// 命令,而且在 ODBC中它運行用於當前數據庫

29.    什麼是吞吐量?
單位時間內系統處理客戶端的請求數。

30.    actioninit、end除了迭代的區別還有其餘嗎?

initend中不能使用集合點、事務等, initend只執行一次。

31.    在什麼地方設置HTTP頁面filter?

       在runtime_settings中download filter裏面進行設置。

32.    pot mapping的原理是什麼?

       就是代理服務器

33.    HTTP的超時有哪三種?

HTTP-request connect timeout、HTTP-request receive timeout、step download timeout

34.    什麼是contentcheck?如何來用?

ContentCheck的設置是爲了讓VuGen檢測何種頁面爲錯誤頁面。若是被測的Web 應用沒有使用自定義的錯誤頁面,那麼這裏不用做更改;若是被測的Web應用使用了自定義的錯誤頁面,那麼這裏須要定義,以便讓VuGen 在運行過程當中檢測,服務器返回的頁面是否包含預約義的字符串,進而判斷該頁面是否爲錯誤頁

面。若是是,VuGen就中止運行,指示運行失敗。

使用方法:點擊在runtime settings中點擊「contentcheck」,而後新創建一個符合要求的應用程序和規則,設定須要查找的文本和前綴後綴便可使用。

35.    network中的speed simulation是模擬的什麼帶寬?

模擬用戶訪問速度的帶寬。

36.    生成WEB性能圖有什麼意義?大概描述便可。

能夠很直觀的看到,在負載下系統的運行狀況以及各類資源的使用狀況,能夠對系統的性能瓶頸定位、性能調優等起到想要的輔助做用。

37.    若是刷新controller裏的腳本?

controller中,點擊detailis-Refresh-script便可。

38.    進程和線程有什麼區別

線程有本身的全局數據。線程存在於進程中,所以一個 進程的全局變量由全部的線程共享。因爲線程共享一樣的系統區域,操做系統分配給一個進程的資源對該進程的全部線程都是可用的,正如全局數據可供全部線程使 用同樣。在Controller中將使用驅動程序(如mdrv.exe、r3vuser.exe)運行vuser。若是按進程運行每一個vuser,則對於 每一個vuser實例,都將反覆啓動同一驅動程序並將其加載到內存中。將同一驅動程序加載到內存中會佔用大量的RAM(隨機存儲器)及其餘系統資源。這就限制了能夠在任一負載生成器上運行的vuser數量。若是按線程運行每一個vuser,Controller爲每50個vuser(默認狀況下)僅啓動驅動程序(如mdrv.exe)的一個實例。該驅動程序將啓動幾個vuser,每一個vuser都按線程運行。這些線程vuser將共享父驅動進程的內存段。這就消除了屢次從新加載驅動程序/進程的須要,節省了大量內存空間,從而能夠在一個負載生成器上運行更多的Vuser.

39.    如何把腳本和結果放到load generator的機器上?

    在controller中,點擊Results-Results settings,在裏面進行相應的設置便可。

40.    如何設置才能讓集合點只對一半的用戶生效?

   對集合點策略進行相應的設置便可。即在controller中,點擊Scenario-Rendezvous-policy進行相應的設置便可,因爲題目中「一半的用戶」沒有說明白具體指什麼樣的用戶,如今很差肯定具體對裏面的哪一個選項進行設置。

41.    LRdAPI分爲幾類

A:通用的API:,就是跟具體的協議無關,在任何協議的腳本里都能用的;

B:針對協議的:像lrs前綴是winsock的;lrd的是針對database;

C:自定義的:這個範圍就比較廣了;好比至少有Java Vuser APIlrapiXML API。還能夠添加WindowsAPI和自定義函數庫。

42.    LR幾種日誌函數的區別?

lr_message】 int lr_message (const char *format, exp1, exp2,…expn.);中文解釋:lr_message函數將信息發送到日誌文件和輸入窗口。在VuGen中運行時,輸入文件爲output.txt

lr_log_message】 int lr_log_message (const char *format, exp1, exp2,…expn.);中文解釋:lr_log_message函數將消息發送到Vuser或代理日誌文件(取決於應用程序),而不是發送到輸出窗口。經過向日志文件發送錯誤消息或其餘信息性消息,能夠將該函數用於調試。                   【lr_error_message】 int lr_error_message (const char *format, exp1, exp2,…expn. );中文解釋:lr_error_message函數將錯誤消息發送到輸出窗口和Vuser日誌文件。要發送不是特定錯誤消息的特殊通知,請使用lr_output_message。

lr_output_message】 int lr_output_message (const char *format, exp1, exp2,…expn.);中文解釋:lr_output_message函數將帶有腳本部分的行號的消息發送到輸出窗口和日誌文件。

lr_debug_message函數組】 int lr_debug_message (unsigned int message_level, const char *format, … );中文解釋:lr_debug_message函數在指定的消息級別處於活動狀態時發送一條調試信息。若是指定的消息級別未出於活動狀態,則不發送消息。您能夠從用戶界面或者使用lr_set_debug_message,將處於活動狀態的消息級別設置爲MSG_CLASS_BRIEF_LOG或MSG_CLASSS_EXTENDED_LOG。要肯定當前級別,

請使用lr_get_debug_message。 unsigned int lr_get_debug_message ( );中文解釋:lr_get_debug_message函數返回當前的日誌運行時設置。該設置肯定發送到輸出端的信息。日誌設置是使用運行時設置對話框或經過使用lr_set_debug_message函數指定的。 int lr_set_debug_message (unsigned int message_level, unsigned int on_off); 中文解釋:lr_set_debug_message函數設置腳本執行的調試消息級別message_lvl。經過設置消息級別,能夠肯定發送哪些信息。啓動設置的方法是將LR_SWITCH_ON做爲on_off傳遞,禁用設置的方法是傳遞LR_SWITCH_OFF。

lrd_stmt】:將SQL語句與光標關聯

lrd_fetch】:提取結果集中得下一條記錄

43.    性能瓶頸分析方法?

 同一場景
1.小用戶量的狀況下測試
2.大用戶量狀況下的測試
分析的方法:
整個系統架構分析,系統響應時間消耗,利用圖表分析
查看事務響應時間,經過事務摘要圖分析事務響應時間,那個消耗最大(經過小用戶量和大用戶量的響應時間分析,查看那個事務響應時間最高),肯定哪部分功能是性能的瓶頸,分析window resource圖表,查看cpu
使用下列計數器標識cpu瓶頸
Processor\ Interrupts/sec
Processor\ % Processor Time
Process(process)\ % Processor Time
System\ Processor Queue Length
經過它來肯定是否硬件自己出現瓶頸,或者進一步肯定應該怎麼去判斷性能產生瓶頸的地方!
下一步去判斷進程,那個進程消耗cpu最高
下邊就有不少種狀況須要你本身去判斷,有多是進程調用了的函數消耗了系統資源造成上邊的問題,也有多是後臺數據庫出現的問題(這個就要看你的系統配置是什麼樣的,好比你的db服務器和應用服務器都配置在一臺機器上)
性能產生瓶頸有不少地方,因此須要進一判斷,是不是後臺數據庫的問題還有待分析,是那條語句致使的問題須要進一步分析判斷。
分析原則:
? 具體問題具體分析(這是因爲不一樣的應用系統,不一樣的測試目的,不一樣的性能關注點)
? 查找瓶頸時按如下順序,由易到難。
服務器硬件瓶頸-〉網絡瓶頸(對局域網,能夠不考慮)-〉服務器操做系統瓶頸(參數配置)-〉中間件瓶頸(參數配置,數據庫,web服務器等)-〉應用瓶頸(SQL語句、數據庫設計、業務邏輯、算法等)
注:以上過程並非每一個分析中都須要的,要根據測試目的和要求來肯定分析的深度。對一些要求低的,咱們分析到應用系統在未來大的負載壓力(併發用戶數、數據量)下,系統的硬件瓶頸在哪兒就夠了。
? 分段排除法頗有效
分析的信息來源:
?1 根據場景運行過程當中的錯誤提示信息
?2 根據測試結果收集到的監控指標數據
一.錯誤提示分析
分析實例:
1 ?Error: Failed to connect to server 「10.10.10.30:8080″: [10060] Connection
?Error: timed out Error: Server 「10.10.10.30″ has shut down the connection prematurely
分析:
?A、應用服務死掉。
(小用戶時:程序上的問題。程序上處理數據庫的問題)
?B、應用服務沒有死
(應用服務參數設置問題)
例:在許多客戶端鏈接Weblogic應用服務器被拒絕,而在服務器端沒有錯誤顯示,則有多是Weblogic中的server元素的 AcceptBacklog屬性值設得太低。若是鏈接時收到connection refused消息,說明應提升該值,每次增長25%
?C、數據庫的鏈接
(1、在應用服務的性能參數可能過小了 二、數據庫啓動的最大鏈接數(跟硬件的內存有關))
2  Error: Page download timeout (120 seconds) has expired
分析:多是如下緣由形成
?A、應用服務參數設置太大致使服務器的瓶頸
?B、頁面中圖片太多
?C、在程序處理表的時候檢查字段太大多
二.監控指標數據分析
1.最大併發用戶數:
應用系統在當前環境(硬件環境、網絡環境、軟件環境(參數配置))下能承受的最大併發用戶數。
在方案運行中,若是出現了大於3個用戶的業務操做失敗,或出現了服務器shutdown的狀況,則說明在當前環境下,系統承受不了當前併發用戶的負載壓力,那麼最大併發用戶數就是前一個沒有出現這種現象的併發用戶數。
若是測得的最大併發用戶數到達了性能要求,且各服務器資源狀況良好,業務操做響應時間也達到了用戶要求,那麼OK。不然,再根據各服務器的資源狀況和業務操做響應時間進一步分析緣由所在。
2.業務操做響應時間:
? 分析方案運行狀況應從平均事務響應時間圖和事務性能摘要圖開始。使用「事務性能摘要」圖,能夠肯定在方案執行期間響應時間過長的事務。
? 細分事務並分析每一個頁面組件的性能。查看過長的事務響應時間是由哪些頁面組件引發的?問題是否與網絡或服務器有關?
? 若是服務器耗時過長,請使用相應的服務器圖肯定有問題的服務器度量並查明服務器性能降低的緣由。若是網絡耗時過長,請使用「網絡監視器」圖肯定致使性能瓶頸的網絡問題
3.服務器資源監控指標:
內存:
1 UNIX資源監控中指標內存頁交換速率(Paging rate),若是該值偶爾走高,代表當時有線程競爭內存。若是持續很高,則內存多是瓶頸。也多是內存訪問命中率低。
2 Windows資源監控中,若是Process\Private Bytes計數器和Process\Working Set計數器的值在長時間內持續升高,同時Memory\Available bytes計數器的值持續下降,則極可能存在內存泄漏。
內存資源成爲系統性能的瓶頸的徵兆:
很高的換頁率(high pageout rate);
進程進入不活動狀態;
交換區全部磁盤的活動次數可高;
可高的全局系統CPU利用率;
內存不夠出錯(out of memory errors)
處理器:
1 UNIX資源監控(Windows操做系統同理)中指標CPU佔用率(CPU utilization),若是該值持續超過95%,代表瓶頸是CPU。能夠考慮增長一個處理器或換一個更快的處理器。若是服務器專用於SQL Server,可接受的最大上限是80-85%
合理使用的範圍在60%至70%。
2 Windows資源監控中,若是System\Processor Queue Length大於2,而處理器利用率(Processor Time)一直很低,則存在着處理器阻塞。
CPU資源成爲系統性能的瓶頸的徵兆:
很慢的響應時間(slow response time)
CPU空閒時間爲零(zero percent idle CPU)
太高的用戶佔用CPU時間(high percent user CPU)
太高的系統佔用CPU時間(high percent system CPU)
長時間的有很長的運行進程隊列(large run queue size sustained over time)
磁盤I/O:
1 UNIX資源監控(Windows操做系統同理)中指標磁盤交換率(Disk rate),若是該參數值一直很高,代表I/O有問題。可考慮更換更快的硬盤系統。
2 Windows資源監控中,若是 Disk Time和Avg.Disk Queue Length的值很高,而Page Reads/sec頁面讀取操做速率很低,則可能存在磁盤瓶徑。
I/O資源成爲系統性能的瓶頸的徵兆 :
太高的磁盤利用率(high disk utilization)
太長的磁盤等待隊列(large disk queue length) 等待磁盤I/O的時間所佔的百分率過高(large percentage of time waiting for disk I/O) 過高的物理I/O速率:large physical I/O rate(not sufficient in itself) 太低的緩存命中率(low buffer cache hit ratio(not sufficient in itself)) 太長的運行進程隊列,但CPU卻空閒(large run queue with idle CPU) 4.數據庫服務器: SQL Server數據庫: 1 SQLServer資源監控中指標緩存點擊率(Cache Hit Ratio),該值越高越好。若是持續低於80%,應考慮增長內存。 2 若是Full Scans/sec(全表掃描/秒)計數器顯示的值比1或2高,則應分析你的查詢以肯定是否確實須要全表掃描,以及SQL查詢是否能夠被優化。 3 Number of Deadlocks/sec(死鎖的數量/秒):死鎖對應用程序的可伸縮性很是有害,而且會致使惡劣的用戶體驗。該計數器的值必須爲0。 4 Lock Requests/sec(鎖請求/秒),經過優化查詢來減小讀取次數,能夠減小該計數器的值。

Oracle數據庫:
1 若是自由內存接近於0並且庫快存或數據字典快存的命中率小於0.90,那麼須要增長SHARED_POOL_SIZE的大小。
快存(共享SQL區)和數據字典快存的命中率:
select(sum(pins-reloads))/sum(pins) from v$librarycache;
select(sum(gets-getmisses))/sum(gets) from v$rowcache;
自由內存 select * from v$sgastat where name=’free memory’;
2 若是數據的緩存命中率小於0.90,那麼須要加大DB_BLOCK_BUFFERS參數的值(單位:塊)。
緩衝區高速緩存命中率:
select name,value from v$sysstat where name in (‘db block gets’,
‘consistent gets’,'physical reads’) ;

Hit Ratio = 1-(physical reads / ( db block gets + consistent gets))
3 若是日誌緩衝區申請的值較大,則應加大LOG_BUFFER參數的值。
日誌緩衝區的申請狀況:
select name,value from v$sysstat where name = ‘redo log space requests’ ;
4 若是內存排序命中率小於0.95,則應加大SORT_AREA_SIZE以免磁盤排序。
內存排序命中率:

相關文章
相關標籤/搜索