summaryrefslogtreecommitdiffstats
path: root/src/seastar/scripts/seastar-cpu-map.sh
blob: ebc0000987e813bb9fa177048a4b02510a9fbb1d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#!/bin/bash
# !
# ! Usage: ./seastar-cpu-map.sh -p <process_PID> -n <process_Name> -s (optional) <shard>
# !
# ! List CPU affinity for a particular running process
# !  providing a map of threads -> shard, for any seastar apps.
# ! Ex.: ./seastar-cpu-map.sh -n scylla
# !      ./seastar-cpu-map.sh -n scylla -s 0
# !      ./seastar-cpu-map.sh -p 34
# !      ./seastar-cpu-map.sh -p 32 -s 12

usage() {
    cat $0 | grep ^"# !" | cut -d"!" -f2-
}

while getopts 'p:n:s:' option; do
  case "$option" in
    p) PID=$OPTARG
        ;;
    n) PID=`pidof $OPTARG`
        ;;
    s) SHARD=$OPTARG
        ;;
    :) printf "missing argument for -%s\n" "$OPTARG" >&2
       usage >&2
       exit 1
       ;;
    \?) printf "illegal option: -%s\n" "$OPTARG" >&2
       usage >&2
       exit 1
       ;;
  esac
done

if [ $# -eq 0 ]; then usage >&2; exit 1; fi

if [ -e "/proc/$PID/task" ]; then
  # get list of threads for given PID
  THREADS=`ls /proc/$PID/task`
  for i in $THREADS; do
    # get shards from threads
    # there were three options here to get the shard number:
    # reactor-xx, syscall-xx and timer-xx
    # syscall was preferred because reactor as a special case (reactor-0 is called scylla)
    SYSCALL=`grep syscall /proc/$i/comm | cut -d"-" -f2`
    if [ -n "$SYSCALL" ] && [ "$SYSCALL" = "$SHARD" ]; then
      echo -e "shard: $SYSCALL, cpu:$(taskset -c -p $i | cut -d":" -f2)"
    elif [ -n "$SYSCALL" ] && [ -z "$SHARD" ]; then
      echo -e "shard: $SYSCALL, cpu:$(taskset -c -p $i | cut -d":" -f2)"
    fi
  done
else
  echo "Process does not exist"
fi