k6是新興的性能測試框架,比肩jmeter,另外測試腳本使用js,更加適合自動化的架構(gòu)。
成都創(chuàng)新互聯(lián)是一家專注于成都網(wǎng)站設計、成都網(wǎng)站建設與策劃設計,海豐網(wǎng)站建設哪家好?成都創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設10年,網(wǎng)設計領域的專業(yè)建站公司;建站業(yè)務涵蓋:海豐等地區(qū)。海豐做網(wǎng)站價格咨詢:13518219792
k6啟動的框架是使用golang的cli標準框架cobra,入口函數(shù)
進入cobra框架后,我們直接查看getRunCmd,這個是命令run的入口,主要工作都是從這里開始。
重點關注初始化Runner,這個是通過js腳本,使用goja庫解析后,生成的實際執(zhí)行單元。
進入js目錄,查看Runner的結(jié)構(gòu),runner.go
Runner有一些配置屬性,另外還有方法,方法用lib.Runner的接口進行規(guī)范。
Runner有一個NewVU方法,里面定義了連接參數(shù),實現(xiàn)api測試
返回主函數(shù),在初始化完成Runner后,啟動調(diào)度器,以及做結(jié)果收集
最終封裝成一個engine
啟動測試
包 utf-8 實現(xiàn)的功能和常量用于文章utf8編碼,包含runes和utf8字節(jié)序列的轉(zhuǎn)換功能.在unicode中,一個中文占兩個字節(jié),utf-8中一個中文占三個字節(jié),golang默認的編碼是utf-8編碼,因此默認一個中文占三個字節(jié),但是golang中的字符串底層實際上是一個byte數(shù)組.
Output:
RuneSelf該值的字節(jié)碼值為128,在判斷是否是常規(guī)的ascii碼是使用。hicb字節(jié)碼值為191. FF 的對應的字節(jié)碼為255。
計算字符串中的rune數(shù)量,原理:首先取出字符串的碼值,然后判斷是不是個小于128的,如果是小于則直接continue.rune個數(shù)++.
如果是個十六進制f1.的則是無效字符,直接continue.rune個數(shù)++,也就是說一個無效的字符也當成一個字長為1的rune.如果字符的碼值在first列表中的值和7按位的結(jié)果為其字長,比如上面示例中的 鋼 。其字長為三位,第一位的值為 233 .二進制形式為 11101001 ;與7按位與后的值為0.從acceptRanges中取出的結(jié)果為{locb, hicb}。也就是標識 ox80 到 0xbf 之間的值。而結(jié)果n也就是直接size+3跳過3個字節(jié)后,rune個數(shù)++。其他函數(shù)的處理流程差不多,不再過多敘述。
示例:
ValidString返回值表明參數(shù)字符串是否是一個合法的可utf8編碼的字符串。
RuneCount返回參數(shù)中包含的rune數(shù)量,第一個例子中將 utf8.RuneCountInString ,改成該方法調(diào)用,返回的結(jié)果相同。錯誤的和短的被當成一個長一字節(jié)的rune.單個字符 H 就表示一個長度為1字節(jié)的rune.
該函數(shù)標識參數(shù)是否以一個可編碼的rune開頭,上面的例子中,因為字符串是以一個ascii碼值在0-127內(nèi)的字符開頭,所以在執(zhí)行
first[p[0]] 時,取到的是 p[0] 是72,在first列表中,127之前的值都相同都為 0xF0 ,十進制標識為240,與7按位與后值為0,所以,直接返回 true .
和FullRune類似,只是參數(shù)為字符串形式
Gorm是Go語言開發(fā)用的比較多的一個ORM。它的功能比較全:
但是這篇文章中并不會直接看Gorm的源碼,我們會先從database/sql分析。原因是Gorm也是基于這個包來封裝的一些功能。所以只有先了解了database/sql包才能更加好的理解Gorm源碼。
database/sql 其實也是一個對于mysql驅(qū)動的上層封裝。”github.com/go-sql-driver/mysql”就是一個對于mysql的驅(qū)動,database/sql 就是在這個基礎上做的基本封裝包含連接池的使用
下面這個是最基本的增刪改查操作
操作分下面幾個步驟:
因為Gorm的連接池就是使用database/sql包中的連接池,所以這里我們需要學習一下包里的連接池的源碼實現(xiàn)。其實所有連接池最重要的就是連接池對象、獲取函數(shù)、釋放函數(shù)下面來看一下database/sql中的連接池。
DB對象
獲取方法
釋放連接方法
連接池的實現(xiàn)有很多方法,在database/sql包中使用的是chan阻塞 使用map記錄等待列表,等到有連接釋放的時候再把連接傳入等待列表中的chan 不在阻塞返回連接。
之前我們看到的Redigo是使用一個chan 來阻塞,然后釋放的時候放入空閑列表,在往這一個chan中傳入struct{}{},讓程序繼續(xù) 獲取的時候再從空閑列表中獲取。并且使用的是鏈表的結(jié)構(gòu)來存儲空閑列表。
database/sql 是對于mysql驅(qū)動的封裝,然而Gorm則是對于database/sql的再次封裝。讓我們可以更加簡單的實現(xiàn)對于mysql數(shù)據(jù)庫的操作。
1.最簡單的方法:
public static String reverse1(String str)
{ return new StringBuffer(str).reverse().toString();
}
2.最常用的方法:
public static String reverse3(String s)
{ char[] array = s.toCharArray();
String reverse = ""; //注意這是空串,不是null
for (int i = array.length - 1; i = 0; i--)
reverse += array[i];
return reverse;
}
3.常用方法的變形:
public static String reverse2(String s)
{ int length = s.length();
String reverse = ""; //注意這是空串,不是null
for (int i = 0; i length; i++)
reverse = s.charAt(i) + reverse;//在字符串前面連接, 而非常見的后面
return reverse;
}