numactl(8)


NAME

   numactl - Control NUMA policy for processes or shared memory

SYNOPSIS

   numactl  [  --all  ]  [  --interleave  nodes  ]  [ --preferred node ] [
   --membind nodes ] [ --cpunodebind nodes ]  [  --physcpubind  cpus  ]  [
   --localalloc ] [--] command {arguments ...}
   numactl --show
   numactl --hardware
   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 specifed 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 specifed 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
          Always allocate on the current node.

   --preferred=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.

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

   --hardware, -H
          Show inventory of available nodes on the system.

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

   This  policy  is  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, --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 an shared memory segment with numeric ID id

   --shm shmkeyfile
   Create or use an 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=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 --interleave=all --shm /tmp/shmkey Interleave all of  the  sysv
   shared memory region 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 an 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)





Opportunity


Personal Opportunity - Free software gives you access to billions of dollars of software at no cost. Use this software for your business, personal use or to develop a profitable skill. Access to source code provides access to a level of capabilities/information that companies protect though copyrights. Open source is a core component of the Internet and it is available to you. Leverage the billions of dollars in resources and capabilities to build a career, establish a business or change the world. The potential is endless for those who understand the opportunity.

Business Opportunity - Goldman Sachs, IBM and countless large corporations are leveraging open source to reduce costs, develop products and increase their bottom lines. Learn what these companies know about open source and how open source can give you the advantage.





Free Software


Free Software provides computer programs and capabilities at no cost but more importantly, it provides the freedom to run, edit, contribute to, and share the software. The importance of free software is a matter of access, not price. Software at no cost is a benefit but ownership rights to the software and source code is far more significant.


Free Office Software - The Libre Office suite provides top desktop productivity tools for free. This includes, a word processor, spreadsheet, presentation engine, drawing and flowcharting, database and math applications. Libre Office is available for Linux or Windows.





Free Books


The Free Books Library is a collection of thousands of the most popular public domain books in an online readable format. The collection includes great classical literature and more recent works where the U.S. copyright has expired. These books are yours to read and use without restrictions.


Source Code - Want to change a program or know how it works? Open Source provides the source code for its programs so that anyone can use, modify or learn how to write those programs themselves. Visit the GNU source code repositories to download the source.





Education


Study at Harvard, Stanford or MIT - Open edX provides free online courses from Harvard, MIT, Columbia, UC Berkeley and other top Universities. Hundreds of courses for almost all major subjects and course levels. Open edx also offers some paid courses and selected certifications.


Linux Manual Pages - A man or manual page is a form of software documentation found on Linux/Unix operating systems. Topics covered include computer programs (including library and system calls), formal standards and conventions, and even abstract concepts.