mirror of
https://github.com/postgres/postgres.git
synced 2025-07-31 22:04:40 +03:00
Add support for basic NUMA awareness
Add basic NUMA awareness routines, using a minimal src/port/pg_numa.c portability wrapper and an optional build dependency, enabled by --with-libnuma configure option. For now this is Linux-only, other platforms may be supported later. A built-in SQL function pg_numa_available() allows checking NUMA support, i.e. that the server was built/linked with the NUMA library. The main function introduced is pg_numa_query_pages(), which allows determining the NUMA node for individual memory pages. Internally the function uses move_pages(2) syscall, as it allows batching, and is more efficient than get_mempolicy(2). Author: Jakub Wartak <jakub.wartak@enterprisedb.com> Co-authored-by: Bertrand Drouvot <bertranddrouvot.pg@gmail.com> Reviewed-by: Andres Freund <andres@anarazel.de> Reviewed-by: Álvaro Herrera <alvherre@alvh.no-ip.org> Reviewed-by: Tomas Vondra <tomas@vondra.me> Discussion: https://postgr.es/m/CAKZiRmxh6KWo0aqRqvmcoaX2jUxZYb4kGp3N%3Dq1w%2BDiH-696Xw%40mail.gmail.com
This commit is contained in:
14
configure.ac
14
configure.ac
@ -1053,6 +1053,20 @@ if test "$with_libcurl" = yes ; then
|
||||
fi
|
||||
|
||||
|
||||
#
|
||||
# libnuma
|
||||
#
|
||||
AC_MSG_CHECKING([whether to build with libnuma support])
|
||||
PGAC_ARG_BOOL(with, libnuma, no, [build with libnuma support],
|
||||
[AC_DEFINE([USE_LIBNUMA], 1, [Define to build with NUMA support. (--with-libnuma)])])
|
||||
AC_MSG_RESULT([$with_libnuma])
|
||||
AC_SUBST(with_libnuma)
|
||||
|
||||
if test "$with_libnuma" = yes ; then
|
||||
AC_CHECK_LIB(numa, numa_available, [], [AC_MSG_ERROR([library 'libnuma' is required for NUMA support])])
|
||||
PKG_CHECK_MODULES(LIBNUMA, numa)
|
||||
fi
|
||||
|
||||
#
|
||||
# XML
|
||||
#
|
||||
|
Reference in New Issue
Block a user