W3Cschool
恭喜您成為首批注冊用戶
獲得88經驗值獎勵
如果一臺機器上防止多個redis實例,為了防止上下文切換導致的開銷,可以采用taskset。taskset是LINUX提供的一個命令(ubuntu系統(tǒng)可能需要自行安裝,schedutils package)。他可以讓某個程序運行在某個(或)某些CPU上。
1)顯示進程運行的CPU (6137為redis-server的進程號)
[redis@hadoop1 ~]$ taskset -p 6137
pid 6137's current affinity mask: f
顯示結果的f實際上是二進制4個低位均為1的bitmask,每一個1對應于1個CPU,表示該進程在4個CPU上運行
2)指定進程運行在某個特定的CPU上
[redis@hadoop1 ~]$ taskset -pc 3 6137
pid 6137's current affinity list: 0-3
pid 6137's new affinity list: 3
注:3表示CPU將只會運行在第4個CPU上(從0開始計數(shù))。
3)進程啟動時指定CPU
taskset -c 1 ./redis-server ../redis.conf
參數(shù):OPTIONS -p, --pid operate on an existing PID and not launch a new task
-c, --cpu-list specify a numerical list of processors instead of a bitmask. The list may contain multiple items, separated by comma, and ranges. For example, 0,5,7,9-11.
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: