說明:這里筆者使用 gobot框架
成都創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設(shè),金堂縣企業(yè)網(wǎng)站建設(shè),金堂縣品牌網(wǎng)站建設(shè),網(wǎng)站定制,金堂縣網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,金堂縣網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。
官網(wǎng):
執(zhí)行下面命令:
命令執(zhí)行完成后,會生成一個main的二進制文件,那個就是我們的程序
備注:如果你想編譯其他版本的樹莓程序?修改 GOARM 即可
GOARM=6 (Raspberry Pi A, A+, B, B+, Zero) GOARM=7 (Raspberry Pi 2, 3)
備注:總結(jié)后面有上傳腳本 ^?_?^
1.請確保你已經(jīng)連接到樹莓派了
2.如果無法上傳,或者報錯,請查權(quán)限是否正確
執(zhí)行上傳命令:
scp main pi@192.168.1.xxx :/home/pi/
1.請確保你已經(jīng)連接到樹莓派了
進入 /home/pi (就是你剛上傳的文件路徑)
運行它: ./main
祝你好運!
1.上傳文件的時候,請注意命令
2.不知道如何ssh登陸樹莓派?(請看我上一篇文章)
3.當然需要一點linux的知識
本教程介紹了使用 Godatabase/sql及其標準庫中的包訪問關(guān)系數(shù)據(jù)庫的基礎(chǔ)知識。
您將使用的database/sql包包括用于連接數(shù)據(jù)庫、執(zhí)行事務(wù)、取消正在進行的操作等的類型和函數(shù)。
在本教程中,您將創(chuàng)建一個數(shù)據(jù)庫,然后編寫代碼來訪問該數(shù)據(jù)庫。您的示例項目將是有關(guān)老式爵士樂唱片的數(shù)據(jù)存儲庫。
首先,為您要編寫的代碼創(chuàng)建一個文件夾。
1、打開命令提示符并切換到您的主目錄。
在 Linux 或 Mac 上:
在 Windows 上:
2、在命令提示符下,為您的代碼創(chuàng)建一個名為 data-access 的目錄。
3、創(chuàng)建一個模塊,您可以在其中管理將在本教程中添加的依賴項。
運行g(shù)o mod init命令,為其提供新代碼的模塊路徑。
此命令創(chuàng)建一個 go.mod 文件,您添加的依賴項將在其中列出以供跟蹤。
注意: 在實際開發(fā)中,您會指定一個更符合您自己需求的模塊路徑。有關(guān)更多信息,請參閱一下文章。
GO語言(二十五):管理依賴項(上)
GO語言(二十六):管理依賴項(中)
GO語言(二十七):管理依賴項(下)
接下來,您將創(chuàng)建一個數(shù)據(jù)庫。
在此步驟中,您將創(chuàng)建要使用的數(shù)據(jù)庫。您將使用 DBMS 本身的 CLI 創(chuàng)建數(shù)據(jù)庫和表,以及添加數(shù)據(jù)。
您將創(chuàng)建一個數(shù)據(jù)庫,其中包含有關(guān)黑膠唱片上的老式爵士樂錄音的數(shù)據(jù)。
這里的代碼使用MySQL CLI,但大多數(shù) DBMS 都有自己的 CLI,具有類似的功能。
1、打開一個新的命令提示符。
在命令行,登錄到您的 DBMS,如下面的 MySQL 示例所示。
2、在mysql命令提示符下,創(chuàng)建一個數(shù)據(jù)庫。
3、切到您剛剛創(chuàng)建的數(shù)據(jù)庫,以便您可以添加表。
4、在文本編輯器的 data-access 文件夾中,創(chuàng)建一個名為 create-tables.sql 的文件來保存用于添加表的 SQL 腳本。
將以下 SQL 代碼粘貼到文件中,然后保存文件。
在此 SQL 代碼中:
(1)刪除名為album表。 首先執(zhí)行此命令可以讓您更輕松地稍后重新運行腳本。
(2)創(chuàng)建一個album包含四列的表:title、artist和price。每行的id值由 DBMS 自動創(chuàng)建。
(3)添加帶有值的四行。
5、在mysql命令提示符下,運行您剛剛創(chuàng)建的腳本。
您將使用以下形式的source命令:
6、在 DBMS 命令提示符處,使用SELECT語句來驗證您是否已成功創(chuàng)建包含數(shù)據(jù)的表。
接下來,您將編寫一些 Go 代碼進行連接,以便進行查詢。
現(xiàn)在你已經(jīng)有了一個包含一些數(shù)據(jù)的數(shù)據(jù)庫,開始你的 Go 代碼。
找到并導入一個數(shù)據(jù)庫驅(qū)動程序,該驅(qū)動程序會將您通過database/sql包中的函數(shù)發(fā)出的請求轉(zhuǎn)換為數(shù)據(jù)庫可以理解的請求。
1、在您的瀏覽器中,訪問SQLDrivers wiki 頁面以識別您可以使用的驅(qū)動程序。
2、使用頁面上的列表來識別您將使用的驅(qū)動程序。為了在本教程中訪問 MySQL,您將使用 Go-MySQL-Driver。
3、請注意驅(qū)動程序的包名稱 - 此處為github.com/go-sql-driver/mysql.
4、使用您的文本編輯器,創(chuàng)建一個用于編寫 Go 代碼的文件,并將該文件作為 main.go 保存在您之前創(chuàng)建的數(shù)據(jù)訪問目錄中。
5、進入main.go,粘貼以下代碼導入驅(qū)動包。
在此代碼中:
(1)將您的代碼添加到main包中,以便您可以獨立執(zhí)行它。
(2)導入 MySQL 驅(qū)動程序github.com/go-sql-driver/mysql。
導入驅(qū)動程序后,您將開始編寫代碼以訪問數(shù)據(jù)庫。
現(xiàn)在編寫一些 Go 代碼,讓您使用數(shù)據(jù)庫句柄訪問數(shù)據(jù)庫。
您將使用指向結(jié)構(gòu)的指針sql.DB,它表示對特定數(shù)據(jù)庫的訪問。
編寫代碼
1、進入 main.go,在import您剛剛添加的代碼下方,粘貼以下 Go 代碼以創(chuàng)建數(shù)據(jù)庫句柄。
在此代碼中:
(3)使用 MySQL 驅(qū)動程序Config和FormatDSN類型以收集連接屬性并將它們格式化為連接字符串的 DSN。
該Config結(jié)構(gòu)使代碼比連接字符串更容易閱讀。
(4)調(diào)用sql.Open 初始化db變量,傳遞 FormatDSN。
(5)檢查來自 的錯誤sql.Open。例如,如果您的數(shù)據(jù)庫連接細節(jié)格式不正確,它可能會失敗。
為了簡化代碼,您調(diào)用log.Fatal結(jié)束執(zhí)行并將錯誤打印到控制臺。在生產(chǎn)代碼中,您會希望以更優(yōu)雅的方式處理錯誤。
(6)調(diào)用DB.Ping以確認連接到數(shù)據(jù)庫有效。在運行時, sql.Open可能不會立即連接,具體取決于驅(qū)動程序。您在Ping此處使用以確認 database/sql包可以在需要時連接。
(7)檢查來自Ping的錯誤,以防連接失敗。
(8)Ping如果連接成功,則打印一條消息。
文件的頂部現(xiàn)在應(yīng)該如下所示:
3、保存 main.go。
1、開始跟蹤 MySQL 驅(qū)動程序模塊作為依賴項。
使用go get 添加 github.com/go-sql-driver/mysql 模塊作為您自己模塊的依賴項。使用點參數(shù)表示“獲取當前目錄中代碼的依賴項”。
2、在命令提示符下,設(shè)置Go 程序使用的DBUSER和DBPASS環(huán)境變量。
在 Linux 或 Mac 上:
在 Windows 上:
3、在包含 main.go 的目錄中的命令行中,通過鍵入go run來運行代碼。
連接成功了!
接下來,您將查詢一些數(shù)據(jù)。
很多朋友可能知道Go語言的優(yōu)勢在哪,卻不知道Go語言適合用于哪些地方。
1、 Go語言作為服務(wù)器編程語言,很適合處理日志、數(shù)據(jù)打包、虛擬機處理、文件系統(tǒng)、分布式系統(tǒng)、數(shù)據(jù)庫代理等;網(wǎng)絡(luò)編程方面。Go語言廣泛應(yīng)用于Web應(yīng)用、API應(yīng)用、下載應(yīng)用等;除此之外,Go語言還可用于內(nèi)存數(shù)據(jù)庫和云平臺領(lǐng)域,目前國外很多云平臺都是采用Go開發(fā)。
2、 其實Go語言主要用作服務(wù)器端開發(fā)。其定位是用來開發(fā)"大型軟件"的,適合于很多程序員一起開發(fā)大型軟件,并且開發(fā)周期長,支持云計算的網(wǎng)絡(luò)服務(wù)。Go語言能夠讓程序員快速開發(fā),并且在軟件不斷的增長過程中,它能讓程序員更容易地進行維護和修改。它融合了傳統(tǒng)編譯型語言的高效性和腳本語言的易用性和富于表達性。
3、 Go語言成功案例。Nsq:Nsq是由Go語言開發(fā)的高性能、高可用消息隊列系統(tǒng),性能非常高,每天能處理數(shù)十億條的消息;
4、 Docker:基于lxc的一個虛擬打包工具,能夠?qū)崿F(xiàn)PAAS平臺的組建。
5、 Packer:用來生成不同平臺的鏡像文件,例如VM、vbox、AWS等,作者是vagrant的作者
6、 Skynet:分布式調(diào)度框架。
7、 Doozer:分布式同步工具,類似ZooKeeper。
8、 Heka:mazila開源的日志處理系統(tǒng)。
9、 Cbfs:couchbase開源的分布式文件系統(tǒng)。
10、 Tsuru:開源的PAAS平臺,和SAE實現(xiàn)的功能一模一樣。
11、 Groupcache:memcahe作者寫的用于Google下載系統(tǒng)的緩存系統(tǒng)。
12、 God:類似redis的緩存系統(tǒng),但是支持分布式和擴展性。
13、 Gor:網(wǎng)絡(luò)流量抓包和重放工具。
以上的就是關(guān)于go語言能做什么的內(nèi)容介紹了。
本教程介紹了 Go 中模糊測試的基礎(chǔ)知識。通過模糊測試,隨機數(shù)據(jù)會針對您的測試運行,以嘗試找出漏洞或?qū)е卤罎⒌妮斎搿?梢酝ㄟ^模糊測試發(fā)現(xiàn)的一些漏洞示例包括 SQL 注入、緩沖區(qū)溢出、拒絕服務(wù)和跨站點腳本攻擊。
在本教程中,您將為一個簡單的函數(shù)編寫一個模糊測試,運行 go 命令,并調(diào)試和修復(fù)代碼中的問題。
首先,為您要編寫的代碼創(chuàng)建一個文件夾。
1、打開命令提示符并切換到您的主目錄。
在 Linux 或 Mac 上:
在 Windows 上:
2、在命令提示符下,為您的代碼創(chuàng)建一個名為 fuzz 的目錄。
3、創(chuàng)建一個模塊來保存您的代碼。
運行g(shù)o mod init命令,為其提供新代碼的模塊路徑。
接下來,您將添加一些簡單的代碼來反轉(zhuǎn)字符串,稍后我們將對其進行模糊測試。
在此步驟中,您將添加一個函數(shù)來反轉(zhuǎn)字符串。
a.使用您的文本編輯器,在 fuzz 目錄中創(chuàng)建一個名為 main.go 的文件。
獨立程序(與庫相反)始終位于 package 中main。
此函數(shù)將接受string,使用byte進行循環(huán) ,并在最后返回反轉(zhuǎn)的字符串。
此函數(shù)將運行一些Reverse操作,然后將輸出打印到命令行。這有助于查看運行中的代碼,并可能有助于調(diào)試。
e.該main函數(shù)使用 fmt 包,因此您需要導入它。
第一行代碼應(yīng)如下所示:
從包含 main.go 的目錄中的命令行,運行代碼。
可以看到原來的字符串,反轉(zhuǎn)它的結(jié)果,然后再反轉(zhuǎn)它的結(jié)果,就相當于原來的了。
現(xiàn)在代碼正在運行,是時候測試它了。
在這一步中,您將為Reverse函數(shù)編寫一個基本的單元測試。
a.使用您的文本編輯器,在 fuzz 目錄中創(chuàng)建一個名為 reverse_test.go 的文件。
b.將以下代碼粘貼到 reverse_test.go 中。
這個簡單的測試將斷言列出的輸入字符串將被正確反轉(zhuǎn)。
使用運行單元測試go test
接下來,您將單元測試更改為模糊測試。
單元測試有局限性,即每個輸入都必須由開發(fā)人員添加到測試中。模糊測試的一個好處是它可以為您的代碼提供輸入,并且可以識別您提出的測試用例沒有達到的邊緣用例。
在本節(jié)中,您將單元測試轉(zhuǎn)換為模糊測試,這樣您就可以用更少的工作生成更多的輸入!
請注意,您可以將單元測試、基準測試和模糊測試保存在同一個 *_test.go 文件中,但對于本示例,您將單元測試轉(zhuǎn)換為模糊測試。
在您的文本編輯器中,將 reverse_test.go 中的單元測試替換為以下模糊測試。
Fuzzing 也有一些限制。在您的單元測試中,您可以預(yù)測Reverse函數(shù)的預(yù)期輸出,并驗證實際輸出是否滿足這些預(yù)期。
例如,在測試用例Reverse("Hello, world")中,單元測試將返回指定為"dlrow ,olleH".
模糊測試時,您無法預(yù)測預(yù)期輸出,因為您無法控制輸入。
但是,Reverse您可以在模糊測試中驗證函數(shù)的一些屬性。在這個模糊測試中檢查的兩個屬性是:
(1)將字符串反轉(zhuǎn)兩次保留原始值
(2)反轉(zhuǎn)的字符串將其狀態(tài)保留為有效的 UTF-8。
注意單元測試和模糊測試之間的語法差異:
(3)確保新包unicode/utf8已導入。
隨著單元測試轉(zhuǎn)換為模糊測試,是時候再次運行測試了。
a.在不進行模糊測試的情況下運行模糊測試,以確保種子輸入通過。
如果您在該文件中有其他測試,您也可以運行g(shù)o test -run=FuzzReverse,并且您只想運行模糊測試。
b.運行FuzzReverse模糊測試,查看是否有任何隨機生成的字符串輸入會導致失敗。這是使用go test新標志-fuzz執(zhí)行的。
模糊測試時發(fā)生故障,導致問題的輸入被寫入將在下次運行的種子語料庫文件中g(shù)o test,即使沒有-fuzz標志也是如此。要查看導致失敗的輸入,請在文本編輯器中打開寫入 testdata/fuzz/FuzzReverse 目錄的語料庫文件。您的種子語料庫文件可能包含不同的字符串,但格式相同。
語料庫文件的第一行表示編碼版本。以下每一行代表構(gòu)成語料庫條目的每種類型的值。由于 fuzz target 只需要 1 個輸入,因此版本之后只有 1 個值。
c.運行沒有-fuzz標志的go test; 新的失敗種子語料庫條目將被使用:
由于我們的測試失敗,是時候調(diào)試了。
go可以在安卓運行的,github.com/golang/mobile,這是用golang做移動端開發(fā)的庫,
go是靜態(tài)編譯語言,不是腳本語言
一. 什么是LoadRunner LoadRunner是一種預(yù)測系統(tǒng)行為和性能的工業(yè)標準級負載測試工具。通過以模擬多個用戶實施并發(fā)負載測試及實時性能檢測的方式來確認和查找問題,能對整個企業(yè)架構(gòu)進行測試。 二. LoadRunner的優(yōu)點 1. 輕松創(chuàng)建虛擬用戶:通過記錄下業(yè)務(wù)流程轉(zhuǎn)為測試腳本,在機器上產(chǎn)生多個用戶訪問,減少負載測試需要的硬件和人力資源。 2. 創(chuàng)建真實的負載:可以通過Controller設(shè)定負載方案,如定義用戶在什么時候訪問系統(tǒng)以產(chǎn)生負載,所有用戶同時執(zhí)行一個動作來模擬峰值負載情況等。 3. 實時監(jiān)測器:可以實時顯示交易性能數(shù)據(jù)(如響應(yīng)時間)和其他系統(tǒng)組件如數(shù)據(jù)庫,網(wǎng)絡(luò)等的實時性能。 4. 分析結(jié)果以精確定位問題所在:LoadRunner能收集匯總所有測試數(shù)據(jù),提供高級的分析和報告工具。 三. LoadRunner的安裝與使用 1.安裝過程詳見上傳的LoadRunner使用手冊,在此不再詳細介紹。 2.具體使用: 點擊File新建錄制文件,也可以點擊下面的NEW快捷鍵進行新建。使用File新建,會彈出協(xié)議選擇窗口,選擇新的單協(xié)議腳本(New SingleProtocol Script)的Web(HTTP/HTML)項,確定即可(選擇Web項是因為我們測試的是Web應(yīng)用)。接著會彈出開始錄制的設(shè)置項,需要寫入錄入系統(tǒng)的地址,點擊確定后就會根據(jù)錄入地址展現(xiàn)系統(tǒng)頁面,開始錄制腳本,出現(xiàn)小工具條: 第一個按鈕為錄制鍵 第二個為回放腳本鍵 第三個為停止錄制鍵 第四個為暫停錄制鍵 第五個為編譯腳本鍵 第六個為創(chuàng)建新的Action鍵。LR的錄制腳本分為三個部分,vuser_init、vuser_end和 Action。腳本循環(huán)執(zhí)行時,只執(zhí)行一次vuser_init和vuser_end,而多次循環(huán)Action部分。比如錄制投保業(yè)務(wù)時,登陸系統(tǒng)部分放入vuser_init,退出登陸放到vuser_end,中間的投保操作放到Action中,則循環(huán)執(zhí)行時就會登陸一次投保系統(tǒng)開始反復(fù)執(zhí)行投保操作直到結(jié)束退出系統(tǒng)。 第七個為用來改變錄制的options設(shè)置按鈕 第八個和第九個為插入事務(wù)的起始點和結(jié)束點鍵,結(jié)合起來構(gòu)成一個完整事物,用來衡量服務(wù)器的性能。比如錄制腳本過程中,投保系統(tǒng)的查詢投保單號操作,可以在輸入完查詢信息后點擊查詢按鈕前插入事務(wù)的起始點,查詢出數(shù)據(jù)后插入事務(wù)的結(jié)束點,這樣在運行測試腳本時,Loadrunner在運行到該事務(wù)時,便會計算出這個查詢操作所花時間,便于衡量服務(wù)器執(zhí)行查詢操作的性能。 第十個為插入集合點鍵,可用于衡量在加重負載的情況下服務(wù)器的性能。比如要驗證系統(tǒng)是否能承受100人同時進行報案操作,便可在腳本錄入過程中,點擊報案確認鍵操作前插入集合點,這樣當腳本運行到集合點時,Loadrunner會讓100個虛擬用戶同時點擊報案確認按鈕(如果有的用戶還沒運行到集合點,先到用戶要等未到用戶一起操作)進行報案,從而達到測試目的。 最后一個為設(shè)置驗證點鍵,在創(chuàng)建事物后,設(shè)置一個驗證點可以用來確認事物執(zhí)行是否成功。比如進行查詢事務(wù)操作時,LR只要檢測到網(wǎng)頁的響應(yīng),就認為事務(wù)pass,而不管顯示頁面內(nèi)容是否正確。因此為了檢查Web服務(wù)器返回的網(wǎng)頁是否正確,可以插入Text/Image檢查點,驗證網(wǎng)頁上是否存在指定的Text或Image。 設(shè)置驗證點時,如果我們驗證的文本內(nèi)容是中文,有時會返回無法找到驗證內(nèi)容的報錯信息,而頁面顯示又是正確的,出現(xiàn)問題的原因可能是因為LR對中文的支持部好,盡量選擇驗證信息為數(shù)字或字母;也可能是設(shè)置問題,可以嘗試將Tools-Recording Options-HTTP Properties下的Advanced選項里設(shè)置支持UTF-8,再檢查開發(fā)人員有沒有設(shè)置支持中文。 錄制結(jié)束后,先點擊保存腳本,同時為腳本命名。然后編譯腳本,看是否存在語法錯誤,編譯成功后,即可回放,看錄制腳本是否成功。 LoadRunner錄制得到的腳本基本沒有錯誤,不像robot會有錄入數(shù)據(jù)的缺失,只是會錄入一些非錄入系統(tǒng)的網(wǎng)頁信息,根據(jù)地址可以識別并刪除掉。 四. LoadRunner腳本錄制學習小結(jié) 1. LoadRunner錄制腳本,主要是為了進行壓力測試,所以跑流程時,跑了主要流程即可,也就是系統(tǒng)必須的信息錄入就可以了。 2. LoadRunner的腳本運行過程中,只能用于一次業(yè)務(wù)辦理的數(shù)據(jù)需要做參數(shù)化,如車輛車架號,車牌,報案號等,以免出現(xiàn)重復(fù)投?;驁蟀笩o法立案現(xiàn)象,不能繼續(xù)進行下去。參數(shù)化步驟: 1) 將需要做參數(shù)化的數(shù)據(jù)右鍵點擊,選擇Replace with a parameter,進行設(shè)置。 2) 在彈出編輯框里,設(shè)置易懂的參數(shù)名稱,再點擊Properties進行屬性設(shè)置。 3) 點擊Create Table 按鈕,生成參數(shù)表格,再點擊Edit with Notepad按鈕,即可在記事本里添加新的參數(shù),添加完后再次回車(不回車可能最后條數(shù)據(jù)讀取不到)關(guān)閉,參數(shù)化操作完成。 4) 使用Ctrl +H鍵可以找到替換同樣的需要參數(shù)化的數(shù)據(jù)。 3. 腳本跑流程過程中,因為業(yè)務(wù)運轉(zhuǎn),前面生成的投保單要接著進行提交核保業(yè)務(wù),而每次生成的投保單號不一樣,用于進行提交核保的單號也要與之前的保持一致,因此需要做關(guān)聯(lián)處理,讀取到生成的新投保單號給提交核保流程。關(guān)聯(lián)步驟: 1) .查找關(guān)聯(lián)數(shù)據(jù)第一次出現(xiàn)的位置,判斷該數(shù)據(jù)是由什么函數(shù)返回的。 2) .在樹形結(jié)構(gòu)里點擊返回該數(shù)據(jù)值的函數(shù),看它的Server Response信息,用復(fù)制的關(guān)聯(lián)數(shù)據(jù)進行查找它的返回語句,找到區(qū)分度明顯的語句(不一定要是第一個返回語句),然后使用web_reg_save_param函數(shù)進行關(guān)聯(lián)。 注:關(guān)聯(lián)函數(shù)一定要寫在第一個返回該數(shù)據(jù)值的函數(shù)前。 3) .web_reg_save_param (const char *ParamName, List ofAttributes, LAST); 函數(shù)的第一個參數(shù)是用來對關(guān)聯(lián)數(shù)據(jù)進行定義的,取名最好可讀性強;第二個參數(shù)是用來標識關(guān)聯(lián)數(shù)據(jù)在返回語句里的具體位置的,寫出該數(shù)據(jù)的左右邊界,程序才能識別;LAST表示屬性列的結(jié)束。比如辦理理賠業(yè)務(wù)的流程號,在服務(wù)器的返回語句里是: input name=flowID type="hidden" value=L05012009110000035215 做關(guān)聯(lián)為: web_reg_save_param("LogFlowID", "LB=name=flowIDtype=\"hidden\" value=", "RB=", LAST); 定義的參數(shù)名就叫LogFlowID,表示流程號,易于明白;左邊界從name取就可以標識了,也可取長點或短點,只要能區(qū)分;右邊界只有,寫上就好;最后寫上LAST。 在定義的左右邊界中,如果有雙引號,在腳本中是需要轉(zhuǎn)義的,因為雙引號在C中是有意義的,這里只要表示語句信息,加上右斜杠。尖括號直寫。 左右邊界也需要用雙引號括起來。定義好的參數(shù)寫在程序中,需要在加上單尖括號:swfLogFlowID={LogFlowID} 五. 腳本執(zhí)行過程中的報錯處理 1. vuser_init.c(3051):Error -26377: No match found for the requested parameter"proposalNo". Check whether the requested boundaries exist in theresponse data. Also, if the data you want to save exceeds 256 bytes, useweb_set_max_html_param_len to increase the parameter size [MsgId: MERR-26377] 2. vuser_init.c(3051):web_submit_data("UIPrPoEnInputNext.jsp") highest severity level was"ERROR", 4312 body bytes, 258 header bytes [MsgId: MMSG-26388] 兩個錯誤一起出現(xiàn),出錯語句都是在關(guān)聯(lián)函數(shù)下的提交數(shù)據(jù)函數(shù)位置,但是具體出錯有可能是: 1). 關(guān)聯(lián)函數(shù)左右邊界沒寫對,所有信息都要用字符輸入,不能是中文或其他。 2). 在關(guān)聯(lián)函數(shù)確認寫對的情況下,看提交數(shù)據(jù)函數(shù)中的業(yè)務(wù)設(shè)置,比如有可能是因為保單查詢語句,設(shè)置的查詢時間是過去的時間,新生成的投保單當然查不到,這樣程序也會報這樣的錯。 3. loadrunner 執(zhí)行理賠的立案處理,錄制好腳本后,回放,報錯: 腳本日志信息提示: 1.Action.c(400):Error -26366: "Text=立案信息提交成功" not found for web_reg_find [MsgId: MERR-26366] 2.Action.c(400):web_submit_data("claimSave.do") highest severity level was"ERROR", 4424 body bytes, 258 header bytes [MsgId: MMSG-26388] 腳本執(zhí)行過程停止在立案信息提交頁面,錯誤原因:數(shù)據(jù)問題,可能是有的應(yīng)該變化的信息沒有變。 在該流程中,一個報案號只能做一次立案,而初始腳本沒有設(shè)置參數(shù)、關(guān)聯(lián),使用保單號進行查詢,錯誤被掩蓋。在立案系統(tǒng)中,一個保單號可以重復(fù)報案,但是一個報案號只能一次立案,要跑通流程,需要先將這一保單再重復(fù)報案,得到新的報案號。 六. 性能測試的場景設(shè)置 腳本錄制完畢后,接著準備測試場景。 1.首先準備測試數(shù)據(jù)。比如車險投保,需要投保人和車架號信息來唯一標識一輛被保車,因此就需要將投保人和車架號做參數(shù)化處理,編輯文本框錄入大量數(shù)據(jù)讓腳本唯一讀?。?1). 錄入投保人參數(shù),車架號參數(shù),過程同腳本錄制的參數(shù)化處理 2). 因為投保人和車架號一起生成一條投保數(shù)據(jù),可設(shè)置車架號隨投保人參數(shù)一起讀取,設(shè)置步驟為: 投保人文件存放路徑--File path 投保人參數(shù)數(shù)據(jù)讀取方式 腳本按列名讀取參數(shù),每行數(shù)據(jù)讀取一次,每次循環(huán)取一次新值。 接著設(shè)置車架號參數(shù)信息: 車架號參數(shù)讀取文件路徑設(shè)為和投保人文件路徑一樣 腳本按列名讀取參數(shù),行號選擇和讀取的投保人數(shù)據(jù)同一行 這樣得到所需的投保單生成參數(shù)數(shù)據(jù) 2.設(shè)置測試場景 點擊Tools-Create Controller Scenarios,彈出場景類型選擇框: 錄入需要的虛擬用戶數(shù),選擇生成結(jié)果存放路徑和組名。確定后進入具體設(shè)置頁面: Quantity表示虛擬用戶個數(shù),group name為組名。 1). 設(shè)置運行時間選項Run – time Settings 選擇循環(huán)次數(shù)Run Logic-Iteration Count,設(shè)置循環(huán)10次,虛擬用戶數(shù)為之前設(shè)置的5人,則預(yù)計一共可生成50張投保單。 設(shè)置思考時間,思考時間通常是錄制腳本過程中,填寫頁面信息花費的時間,選擇忽略項,節(jié)省跑腳本的時間。 設(shè)置網(wǎng)絡(luò)連接時間,點擊網(wǎng)絡(luò)協(xié)議項Internet Protocol 的Options鍵,將彈出頁面里的HTTP-request connect timeout和 HTTP-request receive timeout的數(shù)值改為1000。使得能在網(wǎng)絡(luò)狀況不太好的情況下向服務(wù)器發(fā)送接收數(shù)據(jù)。 2). 設(shè)置EditSchedule 選擇虛擬用戶加載方式: 可以一次加載所有用戶,也可以按需要設(shè)置,一秒加載一個用戶或其他。 選擇結(jié)束方式: 當選擇一秒加載一個用戶時,結(jié)束設(shè)置為直到跑完所有腳本停止執(zhí)行。如果選擇選擇一次加載所有用戶可以選擇運行多少時間后停止和不停止選項。 這些設(shè)置完成后,一次測試場景布置完成??梢赃M行基線檢查或單點并發(fā)測試。 七. 性能測試步驟 一). 除測試工具外性能測試必備的系統(tǒng)及業(yè)務(wù)知識 1、熟悉保險行業(yè)業(yè)務(wù)特點,有助于與開發(fā)和客戶討論需求,制定測試用例; 2、熟悉系統(tǒng)的實現(xiàn)特點,開發(fā)實現(xiàn)方式,有助于選擇程序處理復(fù)雜、消耗系統(tǒng)資源的用例點; 3、熟悉數(shù)據(jù)結(jié)構(gòu),了解數(shù)據(jù)存儲規(guī)則,對腳本調(diào)試、數(shù)據(jù)準備、測試執(zhí)行和監(jiān)視都有幫助; 4、熟悉系統(tǒng)所使用的數(shù)據(jù)庫、操作系統(tǒng)、中間件的監(jiān)視和性能問題查看,有助于測試監(jiān)視和發(fā)現(xiàn)問題; 5、熟悉系統(tǒng)架構(gòu)及系統(tǒng)集成方式,有助于分析及明確定位性能問題。 二) 性能測試執(zhí)行過程 1. 基線檢查 1).目的:驗證環(huán)境是否可用; 驗證腳本是否能在場景正常執(zhí)行。 2).方法:1個人單獨循環(huán)5次--沒有其他人干擾,干凈的環(huán)境 3).結(jié)果:一般一個事物的響應(yīng)時間超過3秒就可能存在問題,要提報開發(fā)人 2. 單點并發(fā) 1).目的:為了快速的發(fā)現(xiàn)問題,如多進程的鎖機制,看是否相互間有影響。 2).方法:一般是10人或20人執(zhí)行10到15分鐘,執(zhí)行過程忽略思考時間。 忽略思考時間可以減少客戶端時間,加快向服務(wù)器傳送數(shù)據(jù)速度,很大程度上增大了服務(wù)器的壓力,20個人單點并發(fā)的壓力就相當于200人正常執(zhí)行帶給服務(wù)器的壓力。 3).單點測試的數(shù)據(jù)可以用來進行混發(fā)測試,但是有可能單點測試的數(shù)據(jù)不足以進行混發(fā),需要自己再準備足夠的數(shù)據(jù)。 3.方案測試--混發(fā)測試 1).目的:模擬生產(chǎn)環(huán)境 2).方法:執(zhí)行1小時左右,加上思考時間 八.資源監(jiān)控及調(diào)優(yōu) 性能測試執(zhí)行過程中,需要監(jiān)控系統(tǒng)各項資源,看是否能滿足用戶實際需要,如內(nèi)存使用,SQL SERVER等,結(jié)合LR生成的分析報告,分析系統(tǒng)哪里可能存在問題,需要改進,進行調(diào)優(yōu),這也是我之后要接著進行學習的地方。 1. 學習使用weblogic,了解weblogic常配參數(shù)的意義。通過weblogic自身的監(jiān)控臺,可以了解到目前的JVM的大小、數(shù)據(jù)庫連接池的使用情況以及目前連接的客戶端數(shù)量以及請求狀況等等。 2. 學習oracle使用,熟悉它的體系結(jié)構(gòu),尤其是oracle10里 的awr,awr能采集與統(tǒng)計數(shù)據(jù),并從那些統(tǒng)計數(shù)據(jù)中導出性能量度,以跟蹤潛在的問題。 3. 需要繼續(xù)學習LR的理論知識和實際操作,參考書籍《Web性能測試實戰(zhàn)》、《軟件性能測試過程詳解與案例剖析》