Provided by: numactl_2.0.18-1build1_amd64 bug

NAME

       numactl - Control NUMA policy for processes or shared memory

SYNOPSIS

       numactl  [ --all ] [ --balancing ] [ --interleave nodes ] [ --preferred node ] [ --preferred-many nodes ]
       [ --membind nodes ] [ --cpunodebind nodes ]  [  --physcpubind  cpus  ]  [  --localalloc  ]  [--]  command
       {arguments ...}
       numactl --show
       numactl --hardware [--cpu-compress]
       numactl --version
       numactl [ --huge ] [ --offset offset ] [ --shmmode shmmode ] [ --length length ] [ --strict ]
       [ --shmid id ] --shm shmkeyfile | --file tmpfsfile
       [ --touch ] [ --dump ] [ --dump-nodes ] memory policy

DESCRIPTION

       numactl runs processes with a specific NUMA scheduling or memory placement policy.  The policy is set for
       command and inherited by all of its children.  In addition it can set persistent policy for shared memory
       segments or files.

       Use -- before command if using command options that could be confused with numactl options.

       nodes  may  be  specified  as  N,N,N  or   N-N  or N,N-N or  N-N,N-N and so forth.  Relative nodes may be
       specified as +N,N,N or  +N-N or +N,N-N and so forth. The + indicates that the node numbers  are  relative
       to  the process' set of allowed nodes in its current cpuset.  A !N-N notation indicates the inverse of N-
       N, in other words all nodes except N-N.  If used with + notation, specify !+N-N. When same  is  specified
       the previous nodemask specified on the command line is used.  all means all nodes in the current cpuset.

       Instead of a number a node can also be:

       netdev:DEV                 The node connected to network device DEV.
       file:PATH                  The node the block device of PATH.
       ip:HOST                    The node of the network device of HOST
       block:PATH                 The node of block device PATH
       pci:[seg:]bus:dev[:func]   The node of a PCI device.

       Note that block resolves the kernel block device names only for udev names in /dev use file:

       Policy settings are:

       --all, -a
              Unset  default  cpuset  awareness,  so  user  can use all possible CPUs/nodes for following policy
              settings.

       --interleave=nodes, -i nodes
              Set a memory interleave policy. Memory will be allocated using round robin on nodes.  When  memory
              cannot be allocated on the current interleave target fall back to other nodes.  Multiple nodes may
              be specified on --interleave, --membind and --cpunodebind.

       --membind=nodes, -m nodes
              Only allocate memory from nodes.  Allocation will fail when there is not enough  memory  available
              on these nodes.  nodes may be specified as noted above.

       --cpunodebind=nodes, -N nodes
              Only  execute  command on the CPUs of nodes.  Note that nodes may consist of multiple CPUs.  nodes
              may be specified as noted above.

       --physcpubind=cpus, -C cpus
              Only execute process on cpus.  This accepts cpu numbers  as  shown  in  the  processor  fields  of
              /proc/cpuinfo,  or  relative  cpus  as  in relative to the current cpuset.  You may specify "all",
              which means all cpus in the current cpuset.  Physical cpus may be specified as N,N,N  or   N-N  or
              N,N-N  or   N-N,N-N and so forth.  Relative cpus may be specified as +N,N,N or  +N-N or +N,N-N and
              so forth. The + indicates that the cpu numbers are relative to the process' set of allowed cpus in
              its  current cpuset.  A !N-N notation indicates the inverse of N-N, in other words all cpus except
              N-N.  If used with + notation, specify !+N-N.

       --localalloc, -l
              Try to allocate on the current node of the process, but if memory cannot be allocated  there  fall
              back to other nodes.

       --preferred=node, -p node
              Preferably  allocate  memory  on  node, but if memory cannot be allocated there fall back to other
              nodes.  This option takes only a single node number.  Relative notation may be used.

       --balancing, -b
              Enable Linux kernel NUMA balancing for the process if it is supported by kernel.  This should only
              be used with --membind, -m only, otherwise ignored.

       --preferred-many=nodes, -P nodes
              Preferably  allocate  memory  on nodes, but if memory cannot be allocated there fall back to other
              nodes.  This option takes a mask of preferred nodes where the closest node to local is  considered
              most preferred.  Relative notation may be used.

       --show, -s
              Show NUMA policy settings of the current process.

       --hardware, -H
              Show  inventory  of  available nodes on the system. When the --cpu-compress option is set show cpu
              ranges. This is not default not break any existing scripts.

       Numactl can set up policy for a SYSV shared memory segment or a file in shmfs/hugetlbfs.

       --version
       print the version of the numactl package and exit.

       The following policy settings are persistent and will be used by
       all mappings from that shared memory. The order of options matters here.  The specification must at least
       include either of --shm, --shmid, --file to specify the shared memory segment or file and a memory policy
       like described above ( --interleave, --localalloc, --preferred, --preferred-many, --membind ).

       --huge
       When creating a SYSV shared memory segment use huge pages.  Only valid before --shmid or --shm

       --offset
       Specify offset into the shared memory segment. Default 0.  Valid units are m (for MB), g (for GB), k (for
       KB), otherwise it specifies bytes.

       --strict
       Give an error when a page in the policied area in the shared memory segment already was faulted in with a
       conflicting policy. Default is to silently ignore this.

       --shmmode shmmode
       Only valid before --shmid or --shm When creating a shared memory segment set it to numeric mode shmmode.

       --length length
       Apply policy to length range in the shared memory segment or make the segment length long Default  is  to
       use the remaining length Required when a shared memory segment is created and specifies the length of the
       new segment then. Valid units are m (for MB), g (for GB), k (for KB), otherwise it specifies bytes.

       --shmid id
       Create or use a shared memory segment with numeric ID id

       --shm shmkeyfile
       Create or use a shared memory segment, with the ID generated using ftok(3) from shmkeyfile

       --file tmpfsfile
       Set policy for a file in tmpfs or hugetlbfs

       --touch
       Touch pages to enforce policy early. Default is to  not  touch  them,  the  policy  is  applied  when  an
       applications maps and accesses a page.

       --dump
       Dump policy in the specified range.

       --dump-nodes
       Dump all nodes of the specific range (very verbose!)

       Valid node specifiers

       all                 All nodes
       number              Node number
       number1{,number2}   Node number1 and Node number2
       number1-number2     Nodes from number1 to number2
       ! nodes             Invert selection of the following specification.

EXAMPLES

       numactl  --physcpubind=+0-4,8-12  myapplic  arguments  Run  myapplic  on cpus 0-4 and 8-12 of the current
       cpuset.

       numactl --interleave=all bigdatabase arguments Run big database with its memory interleaved on all CPUs.

       numactl --cpunodebind=0 --membind=0,1 process Run process on node 0 with memory allocated on node  0  and
       1.

       numactl  --cpunodebind=0  --membind=0,1  -- process -l Run process as above, but with an option (-l) that
       would be confused with a numactl option.

       numactl --cpunodebind=0 --balancing --membind=0,1 process Run process on node 0 with memory allocated  on
       node 0 and 1.  Optimize the page placement with Linux kernel NUMA balancing mechanism if possible.

       numactl  --cpunodebind=netdev:eth0 --membind=netdev:eth0 network-server Run network-server on the node of
       network device eth0 with its memory also in the same node.

       numactl --preferred=1 numactl --show Set preferred node 1 and show the resulting state.

       numactl --preferred-many=0x3 numactl --show Set preferred nodes 1 and 2, and show the resulting state.

       numactl --length 1g --shm /tmp/shmkey --interleave=all Interleave all of the sysv shared memory region of
       size 1g specified by /tmp/shmkey over all nodes.

       Place a tmpfs file on 2 nodes:
         numactl --membind=2 dd if=/dev/zero of=/dev/shm/A bs=1M count=1024
         numactl --membind=3 dd if=/dev/zero of=/dev/shm/A seek=1024 bs=1M count=1024

       numactl  --localalloc  /dev/shm/file  Reset  the  policy  for  the shared memory file file to the default
       localalloc policy.

NOTES

       Requires a NUMA policy aware kernel.

       Command is not executed using a shell. If you want to use shell metacharacters in the child use sh -c  as
       wrapper.

       Setting policy for a hugetlbfs file does currently not work because it cannot be extended by truncate.

       Shared memory segments larger than numactl's address space cannot be completely policied. This could be a
       problem on 32bit architectures.  Changing it piece by piece may work.

       The old --cpubind which accepts node numbers, not cpu numbers, is deprecated and replaced  with  the  new
       --cpunodebind and --physcpubind options.

FILES

       /proc/cpuinfo for the listing of active CPUs. See proc(5) for details.

       /sys/devices/system/node/node*/numastat for NUMA memory hit statistics.

COPYRIGHT

       Copyright  2002,2004  Andi  Kleen,  SuSE  Labs.   numactl and the demo programs are under the GNU General
       Public License, v.2

SEE ALSO

       set_mempolicy(2) , get_mempolicy(2) , mbind(2) , sched_setaffinity(2) , sched_getaffinity(2) , proc(5)  ,
       ftok(3) , shmat(2) , migratepages(8)