亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

javascript - Node并發訪問時與猜想的結果不致

瀏覽:87日期:2023-08-30 11:06:25

問題描述

試驗的邏輯比較簡單, 就是Node訪問數據庫查詢數據, SQL語句的執行時間在2秒左右, 我用JMeter進行多線程測試(5線程),按照預想的結果(根據Node非堵塞特性), 應該是5線程同時在2秒返回結果, 但是結果是這樣的:

javascript - Node并發訪問時與猜想的結果不致

javascript - Node并發訪問時與猜想的結果不致

按照結果來看, Node成串行執行了, 這和預想的結果完成不一致啊, 哪位能解釋一下

代碼:

app.get(’/’, function (req, res) { var now = +(new Date()) connection.query(’select count(*) from ACTIVITY group by name’, function (err, result, fields) {var curr = +(new Date())var tmp = ’耗時:’ + (curr - now)console.log(tmp)res.send(tmp) })})

注: 不是數據庫處理的問題, 因為我用兩臺不同的機器, 執行相同的SQL語句, 時間都2秒

以下為補充

按照@邊城的原因是多條SQL語句用的同一個connection, 現在代碼已修改, 使用的是數據庫連接池, 執行結果如下圖:

javascript - Node并發訪問時與猜想的結果不致

代碼如下:

app.get(’/’, function (req, res) { var now = +(new Date()) pool.getConnection(function (err, conn) {console.log(’--連接池連接成功!’ + +(new Date()))conn.query(’select count(*) from ACTIVITY group by name’, function (err, result, fields) { var curr = +(new Date()) var tmp = ’耗時:’ + (curr - now) console.log(tmp) res.send(tmp)}) })})

這樣的結果和預想就比較一致了, 5線程同時查詢, 都是在4s+時間返回, 壓力上去了, 查詢時間自然會長, 經測試, 當線程改成2時, 返回的時間在2s+, 和預期也一致!

問題解答

回答1:

時間起始是 query 之前,結束是 query 完成,所以每個時間是 query 運行的時間,

Node 是異步了,但是你用的是同一個 connection,connection 本身是不是需要排隊呢?據我所知,多數數據庫在同一個 connection 中執行的 SQL 都是排隊挨個進行的……多個 connection 之間可能會并行。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 成 人 黄 色 视频播放1 | 精品一区二区三区视频在线观看 | 大尺度福利视频在线观看网址 | 国内精品久久久久久影院老狼 | 高清性色生活片免费视频软件 | 曰本黄色录像 | 日本高清在线一区二区三区 | 欧美在线网址 | 日韩日日日 | 精品一区二区三区在线观看 | 欧美黄色一级毛片 | 视频一本大道香蕉久在线播放 | 刺激花蒂抽搐视频在线看 | 中文毛片 | 亚洲精品主播一区二区三区 | 亚洲狠狠狠一区二区三区 | 薰衣草视频高清在线观看免费 | 中文字幕一区二区三区在线不卡 | 国产精品久久久久久久人人看 | 久久一区精品 | 国产欧美亚洲精品a | 久久日本精品一区二区免费 | 欧美日韩视频在线一区二区 | 久久精品色| 天天射夜夜骑 | 亚洲第一网站 | 99精品国内不卡在线观看 | 一级片免费在线 | 国产亚洲精品aa在线观看 | 最新91在线| 亚洲 欧美 日韩在线综合福利 | 色婷婷综合和线在线 | 国产一区二区三区四区20p | 正在播放国产酒店露脸 | 国模一区二区三区私啪啪 | 日本69色视频在线观看 | 亚洲免费人成在线视频观看 | 国产在线观看xxxx免费 | 欧美一区二区三区婷婷月色 | 欧美一区二区在线观看 | 免费精品在线视频 |