The CMake program provides a great deal of control over how you configure a MySQL source distribution. Typically, you do this using options on the CMake command line. For information about options supported by CMake, run either of these commands in the top-level source directory:
$> cmake . -LH
$> ccmake .You can also affect CMake using certain environment variables. See Environment Variables.
      For boolean options, the value may be specified as
      1 or ON to enable the
      option, or as 0 or OFF to
      disable the option.
    
      Many options configure compile-time defaults that can be
      overridden at server startup. For example, the
      CMAKE_INSTALL_PREFIX,
      MYSQL_TCP_PORT, and
      MYSQL_UNIX_ADDR options that
      configure the default installation base directory location, TCP/IP
      port number, and Unix socket file can be changed at server startup
      with the --basedir,
      --port, and
      --socket options for
      mysqld. Where applicable, configuration option
      descriptions indicate the corresponding mysqld
      startup option.
    
The following sections provide more information about CMake options.
        The following table shows the available CMake
        options. In the Default column,
        PREFIX stands for the value of the
        CMAKE_INSTALL_PREFIX option, which
        specifies the installation base directory. This value is used as
        the parent location for several of the installation
        subdirectories.
Table 4.1 MySQL Source-Configuration Option Reference (CMake)
| Formats | Description | Default | Introduced | Removed | 
|---|---|---|---|---|
| ADD_GDB_INDEX | Whether to enable generation of .gdb_index section in binaries | 8.0.18 | ||
| BUILD_CONFIG | Use same build options as official releases | |||
| BUNDLE_RUNTIME_LIBRARIES | Bundle runtime libraries with server MSI and Zip packages for Windows | OFF | ||
| CMAKE_BUILD_TYPE | Type of build to produce | RelWithDebInfo | ||
| CMAKE_CXX_FLAGS | Flags for C++ Compiler | |||
| CMAKE_C_FLAGS | Flags for C Compiler | |||
| CMAKE_INSTALL_PREFIX | Installation base directory | /usr/local/mysql | ||
| COMPILATION_COMMENT | Comment about compilation environment | |||
| COMPILATION_COMMENT_SERVER | Comment about compilation environment for use by mysqld | 8.0.14 | ||
| COMPRESS_DEBUG_SECTIONS | Compress debug sections of binary executables | OFF | 8.0.22 | |
| CPACK_MONOLITHIC_INSTALL | Whether package build produces single file | OFF | ||
| DEFAULT_CHARSET | The default server character set | utf8mb4 | ||
| DEFAULT_COLLATION | The default server collation | utf8mb4_0900_ai_ci | ||
| DISABLE_PSI_COND | Exclude Performance Schema condition instrumentation | OFF | ||
| DISABLE_PSI_DATA_LOCK | Exclude the performance schema data lock instrumentation | OFF | ||
| DISABLE_PSI_ERROR | Exclude the performance schema server error instrumentation | OFF | ||
| DISABLE_PSI_FILE | Exclude Performance Schema file instrumentation | OFF | ||
| DISABLE_PSI_IDLE | Exclude Performance Schema idle instrumentation | OFF | ||
| DISABLE_PSI_MEMORY | Exclude Performance Schema memory instrumentation | OFF | ||
| DISABLE_PSI_METADATA | Exclude Performance Schema metadata instrumentation | OFF | ||
| DISABLE_PSI_MUTEX | Exclude Performance Schema mutex instrumentation | OFF | ||
| DISABLE_PSI_PS | Exclude the performance schema prepared statements | OFF | ||
| DISABLE_PSI_RWLOCK | Exclude Performance Schema rwlock instrumentation | OFF | ||
| DISABLE_PSI_SOCKET | Exclude Performance Schema socket instrumentation | OFF | ||
| DISABLE_PSI_SP | Exclude Performance Schema stored program instrumentation | OFF | ||
| DISABLE_PSI_STAGE | Exclude Performance Schema stage instrumentation | OFF | ||
| DISABLE_PSI_STATEMENT | Exclude Performance Schema statement instrumentation | OFF | ||
| DISABLE_PSI_STATEMENT_DIGEST | Exclude Performance Schema statements_digest instrumentation | OFF | ||
| DISABLE_PSI_TABLE | Exclude Performance Schema table instrumentation | OFF | ||
| DISABLE_PSI_THREAD | Exclude the performance schema thread instrumentation | OFF | ||
| DISABLE_PSI_TRANSACTION | Exclude the performance schema transaction instrumentation | OFF | ||
| DISABLE_SHARED | Do not build shared libraries, compile position-dependent code | OFF | 8.0.18 | |
| DOWNLOAD_BOOST | Whether to download the Boost library | OFF | ||
| DOWNLOAD_BOOST_TIMEOUT | Timeout in seconds for downloading the Boost library | 600 | ||
| ENABLED_LOCAL_INFILE | Whether to enable LOCAL for LOAD DATA | OFF | ||
| ENABLED_PROFILING | Whether to enable query profiling code | ON | ||
| ENABLE_DOWNLOADS | Whether to download optional files | OFF | 8.0.26 | |
| ENABLE_EXPERIMENTAL_SYSVARS | Whether to enabled experimental InnoDB system variables | OFF | ||
| ENABLE_GCOV | Whether to include gcov support | |||
| ENABLE_GPROF | Enable gprof (optimized Linux builds only) | OFF | ||
| FORCE_COLORED_OUTPUT | Whether to colorize compiler output | OFF | 8.0.33 | |
| FORCE_INSOURCE_BUILD | Whether to force an in-source build | OFF | 8.0.14 | |
| FORCE_UNSUPPORTED_COMPILER | Whether to permit unsupported compilers | OFF | ||
| FPROFILE_GENERATE | Whether to generate profile guided optimization data | OFF | 8.0.19 | |
| FPROFILE_USE | Whether to use profile guided optimization data | OFF | 8.0.19 | |
| HAVE_PSI_MEMORY_INTERFACE | Enable performance schema memory tracing module for memory allocation functions used in dynamic storage of over-aligned types | OFF | 8.0.26 | |
| IGNORE_AIO_CHECK | With -DBUILD_CONFIG=mysql_release, ignore libaio check | OFF | ||
| INSTALL_BINDIR | User executables directory | PREFIX/bin | ||
| INSTALL_DOCDIR | Documentation directory | PREFIX/docs | ||
| INSTALL_DOCREADMEDIR | README file directory | PREFIX | ||
| INSTALL_INCLUDEDIR | Header file directory | PREFIX/include | ||
| INSTALL_INFODIR | Info file directory | PREFIX/docs | ||
| INSTALL_LAYOUT | Select predefined installation layout | STANDALONE | ||
| INSTALL_LIBDIR | Library file directory | PREFIX/lib | ||
| INSTALL_MANDIR | Manual page directory | PREFIX/man | ||
| INSTALL_MYSQLKEYRINGDIR | Directory for keyring_file plugin data file | platform specific | ||
| INSTALL_MYSQLSHAREDIR | Shared data directory | PREFIX/share | ||
| INSTALL_MYSQLTESTDIR | mysql-test directory | PREFIX/mysql-test | ||
| INSTALL_PKGCONFIGDIR | Directory for mysqlclient.pc pkg-config file | INSTALL_LIBDIR/pkgconfig | ||
| INSTALL_PLUGINDIR | Plugin directory | PREFIX/lib/plugin | ||
| INSTALL_PRIV_LIBDIR | Installation private library directory | 8.0.18 | ||
| INSTALL_SBINDIR | Server executable directory | PREFIX/bin | ||
| INSTALL_SECURE_FILE_PRIVDIR | secure_file_priv default value | platform specific | ||
| INSTALL_SHAREDIR | aclocal/mysql.m4 installation directory | PREFIX/share | ||
| INSTALL_STATIC_LIBRARIES | Whether to install static libraries | ON | ||
| INSTALL_SUPPORTFILESDIR | Extra support files directory | PREFIX/support-files | ||
| LINK_RANDOMIZE | Whether to randomize order of symbols in mysqld binary | OFF | ||
| LINK_RANDOMIZE_SEED | Seed value for LINK_RANDOMIZE option | mysql | ||
| MAX_INDEXES | Maximum indexes per table | 64 | ||
| MEMCACHED_HOME | Path to memcached; obsolete | [none] | 8.0.23 | |
| MSVC_CPPCHECK | Enable MSVC code analysis. | OFF | 8.0.33 | |
| MUTEX_TYPE | InnoDB mutex type | event | ||
| MYSQLX_TCP_PORT | TCP/IP port number used by X Plugin | 33060 | ||
| MYSQLX_UNIX_ADDR | Unix socket file used by X Plugin | /tmp/mysqlx.sock | ||
| MYSQL_DATADIR | Data directory | |||
| MYSQL_MAINTAINER_MODE | Whether to enable MySQL maintainer-specific development environment | OFF | ||
| MYSQL_PROJECT_NAME | Windows/macOS project name | MySQL | ||
| MYSQL_TCP_PORT | TCP/IP port number | 3306 | ||
| MYSQL_UNIX_ADDR | Unix socket file | /tmp/mysql.sock | ||
| NDB_UTILS_LINK_DYNAMIC | Cause NDB tools to be dynamically linked to ndbclient | 8.0.22 | ||
| ODBC_INCLUDES | ODBC includes directory | |||
| ODBC_LIB_DIR | ODBC library directory | |||
| OPTIMIZER_TRACE | Whether to support optimizer tracing | |||
| OPTIMIZE_SANITIZER_BUILDS | Whether to optimize sanitizer builds | ON | 8.0.34 | |
| REPRODUCIBLE_BUILD | Take extra care to create a build result independent of build location and time | |||
| SHOW_SUPPRESSED_COMPILER_WARNING | Whether to show suppressed compiler warnings and not fail with -Werror. | OFF | 8.0.30 | |
| SYSCONFDIR | Option file directory | |||
| SYSTEMD_PID_DIR | Directory for PID file under systemd | /var/run/mysqld | ||
| SYSTEMD_SERVICE_NAME | Name of MySQL service under systemd | mysqld | ||
| TMPDIR | tmpdir default value | |||
| USE_LD_GOLD | Whether to use GNU gold linker | ON | 8.0.31 | |
| USE_LD_LLD | Whether to use LLVM lld linker | ON | 8.0.16 | |
| WIN_DEBUG_NO_INLINE | Whether to disable function inlining | OFF | ||
| WITHOUT_SERVER | Do not build the server; internal use only | OFF | ||
| WITHOUT_xxx_STORAGE_ENGINE | Exclude storage engine xxx from build | |||
| WITH_ANT | Path to Ant for building GCS Java wrapper | |||
| WITH_ASAN | Enable AddressSanitizer | OFF | ||
| WITH_ASAN_SCOPE | Enable AddressSanitizer -fsanitize-address-use-after-scope Clang flag | OFF | ||
| WITH_AUTHENTICATION_CLIENT_PLUGINS | Enabled automatically if any corresponding server authentication plugins are built | 8.0.26 | ||
| WITH_AUTHENTICATION_LDAP | Whether to report error if LDAP authentication plugins cannot be built | OFF | ||
| WITH_AUTHENTICATION_PAM | Build PAM authentication plugin | OFF | ||
| WITH_AWS_SDK | Location of Amazon Web Services software development kit | |||
| WITH_BOOST | The location of the Boost library sources | |||
| WITH_BUILD_ID | On Linux systems, generate a unique build ID | ON | 8.0.31 | |
| WITH_BUNDLED_LIBEVENT | Use bundled libevent when building ndbmemcache; obsolete | ON | 8.0.23 | |
| WITH_BUNDLED_MEMCACHED | Use bundled memcached when building ndbmemcache; obsolete | ON | 8.0.23 | |
| WITH_CLASSPATH | Classpath to use when building MySQL Cluster Connector for Java. Default is an empty string. |  | ||
| WITH_CLIENT_PROTOCOL_TRACING | Build client-side protocol tracing framework | ON | ||
| WITH_CURL | Location of curl library | |||
| WITH_DEBUG | Whether to include debugging support | OFF | ||
| WITH_DEFAULT_COMPILER_OPTIONS | Whether to use default compiler options | ON | ||
| WITH_DEFAULT_FEATURE_SET | Whether to use default feature set | ON | 8.0.22 | |
| WITH_DEVELOPER_ENTITLEMENTS | Whether to add the 'get-task-allow' entitlement to all executables on macOS to generate a core dump in the event of an unexpected server halt | OFF | 8.0.30 | |
| WITH_EDITLINE | Which libedit/editline library to use | bundled | ||
| WITH_ERROR_INSERT | Enable error injection in the NDB storage engine. Should not be used for building binaries intended for production. | OFF | ||
| WITH_FIDO | Type of FIDO library support | bundled | 8.0.27 | |
| WITH_GMOCK | Path to googlemock distribution | 8.0.26 | ||
| WITH_ICU | Type of ICU support | bundled | ||
| WITH_INNODB_EXTRA_DEBUG | Whether to include extra debugging support for InnoDB. | OFF | ||
| WITH_INNODB_MEMCACHED | Whether to generate memcached shared libraries. | OFF | ||
| WITH_JEMALLOC | Whether to link with -ljemalloc | OFF | 8.0.16 | |
| WITH_KEYRING_TEST | Build the keyring test program | OFF | ||
| WITH_LIBEVENT | Which libevent library to use | bundled | ||
| WITH_LIBWRAP | Whether to include libwrap (TCP wrappers) support | OFF | ||
| WITH_LOCK_ORDER | Whether to enable LOCK_ORDER tooling | OFF | 8.0.17 | |
| WITH_LSAN | Whether to run LeakSanitizer, without AddressSanitizer | OFF | 8.0.16 | |
| WITH_LTO | Enable link-time optimizer | OFF | 8.0.13 | |
| WITH_LZ4 | Type of LZ4 library support | bundled | ||
| WITH_LZMA | Type of LZMA library support | bundled | 8.0.16 | |
| WITH_MECAB | Compiles MeCab | |||
| WITH_MSAN | Enable MemorySanitizer | OFF | ||
| WITH_MSCRT_DEBUG | Enable Visual Studio CRT memory leak tracing | OFF | ||
| WITH_MYSQLX | Whether to disable X Protocol | ON | ||
| WITH_NDB | Build MySQL NDB Cluster, including NDB storage engine and all NDB programs | OFF | 8.0.31 | |
| WITH_NDBAPI_EXAMPLES | Build API example programs. | OFF | ||
| WITH_NDBCLUSTER | NDB 8.0.30 and earlier: Build NDB storage engine. NDB 8.0.31 and later: Deprecated; use WITH_NDB instead | OFF | ||
| WITH_NDBCLUSTER_STORAGE_ENGINE | Prior to NDB 8.0.31, this was for internal use only. NDB 8.0.31 and later: toggles (only) inclusion of NDBCLUSTER storage engine | ON | ||
| WITH_NDBMTD | Build multithreaded data node binary | ON | ||
| WITH_NDB_DEBUG | Produce a debug build for testing or troubleshooting. | OFF | ||
| WITH_NDB_JAVA | Enable building of Java and ClusterJ support. Enabled by default. Supported in MySQL Cluster only. | ON | ||
| WITH_NDB_PORT | Default port used by a management server built with this option. If this option was not used to build it, the management server's default port is 1186. | [none] | ||
| WITH_NDB_TEST | Include NDB API test programs. | OFF | ||
| WITH_NUMA | Set NUMA memory allocation policy | |||
| WITH_PACKAGE_FLAGS | For flags typically used for RPM/DEB packages, whether to add them to standalone builds on those platforms | 8.0.26 | ||
| WITH_PLUGIN_NDBCLUSTER | For internal use; may not work as expected in all circumstances. Instead, users should employ WITH_NDBCLUSTER | 8.0.13 | 8.0.31 | |
| WITH_PROTOBUF | Which Protocol Buffers package to use | bundled | ||
| WITH_RAPID | Whether to build rapid development cycle plugins | ON | ||
| WITH_RAPIDJSON | Type of RapidJSON support | bundled | 8.0.13 | |
| WITH_RE2 | Type of RE2 library support | bundled | 8.0.18 | |
| WITH_ROUTER | Whether to build MySQL Router | ON | 8.0.16 | |
| WITH_SASL | Internal use only | |||
| WITH_SSL | Type of SSL support | system | ||
| WITH_SYSTEMD | Enable installation of systemd support files | OFF | ||
| WITH_SYSTEMD_DEBUG | Enable additional systemd debug information | OFF | 8.0.22 | |
| WITH_SYSTEM_LIBS | Set system value of library options not set explicitly | OFF | ||
| WITH_TCMALLOC | Whether to link with -ltcmalloc. BUNDLED is supported on Linux only | OFF | 8.0.22 | |
| WITH_TEST_TRACE_PLUGIN | Build test protocol trace plugin | OFF | ||
| WITH_TSAN | Enable ThreadSanitizer | OFF | ||
| WITH_UBSAN | Enable Undefined Behavior Sanitizer | OFF | ||
| WITH_UNIT_TESTS | Compile MySQL with unit tests | ON | ||
| WITH_UNIXODBC | Enable unixODBC support | OFF | ||
| WITH_VALGRIND | Whether to compile in Valgrind header files | OFF | ||
| WITH_WIN_JEMALLOC | Path to directory containing jemalloc.dll | 8.0.29 | ||
| WITH_ZLIB | Type of zlib support | bundled | ||
| WITH_ZSTD | Type of zstd support | bundled | 8.0.18 | |
| WITH_xxx_STORAGE_ENGINE | Compile storage engine xxx statically into server | 
- This option configures a source distribution with the same build options used by Oracle to produce binary distributions for official MySQL releases. 
- On Linux systems, generates a unique build ID which is used as the value of the - build_idsystem variable and written to the MySQL server log on startup. Set this option to- OFFto disable this feature.- Added in MySQL 8.0.31, this option has no effect on platforms other than Linux. 
- -DBUNDLE_RUNTIME_LIBRARIES=- bool- Whether to bundle runtime libraries with server MSI and Zip packages for Windows. 
- The type of build to produce: - RelWithDebInfo: Enable optimizations and generate debugging information. This is the default MySQL build type.
- Release: Enable optimizations but omit debugging information to reduce the build size. This build type was added in MySQL 8.0.13.
- Debug: Disable optimizations and generate debugging information. This build type is also used if the- WITH_DEBUGoption is enabled. That is,- -DWITH_DEBUG=1has the same effect as- -DCMAKE_BUILD_TYPE=Debug.
 - The option values - Noneand- MinSizeRelare not supported.
- -DCPACK_MONOLITHIC_INSTALL=- bool- This option affects whether the make package operation produces multiple installation package files or a single file. If disabled, the operation produces multiple installation package files, which may be useful if you want to install only a subset of a full MySQL installation. If enabled, it produces a single file for installing everything. 
- Defines whether to force an in-source build. Out-of-source builds are recommended, as they permit multiple builds from the same source, and cleanup can be performed quickly by removing the build directory. To force an in-source build, invoke CMake with - -DFORCE_INSOURCE_BUILD=ON.
- Defines whether to enable colorized compiler output for gcc and clang when compiling on the command line. Defaults to - OFF.
        The CMAKE_INSTALL_PREFIX option
        indicates the base installation directory. Other options with
        names of the form
        INSTALL_ that
        indicate component locations are interpreted relative to the
        prefix and their values are relative pathnames. Their values
        should not include the prefix.
xxx
- -DCMAKE_INSTALL_PREFIX=- dir_name- The installation base directory. - This value can be set at server startup using the - --basediroption.
- Where to install user programs. 
- Where to install documentation. 
- -DINSTALL_DOCREADMEDIR=- dir_name- Where to install - READMEfiles.
- Where to install header files. 
- Where to install Info files. 
- Select a predefined installation layout: - STANDALONE: Same layout as used for- .tar.gzand- .zippackages. This is the default.
- RPM: Layout similar to RPM packages.
- SVR4: Solaris package layout.
- DEB: DEB package layout (experimental).
 - You can select a predefined layout but modify individual component installation locations by specifying other options. For example: - cmake . -DINSTALL_LAYOUT=SVR4 -DMYSQL_DATADIR=/var/mysql/data- The - INSTALL_LAYOUTvalue determines the default value of the- secure_file_priv,- keyring_encrypted_file_data, and- keyring_file_datasystem variables. See the descriptions of those variables in Server System Variables, and Keyring System Variables.
- Where to install library files. 
- Where to install manual pages. 
- -DINSTALL_MYSQLKEYRINGDIR=- dir_path- The default directory to use as the location of the - keyring_fileplugin data file. The default value is platform specific and depends on the value of the- INSTALL_LAYOUTCMake option; see the description of the- keyring_file_datasystem variable in Server System Variables.
- -DINSTALL_MYSQLSHAREDIR=- dir_name- Where to install shared data files. 
- -DINSTALL_MYSQLTESTDIR=- dir_name- Where to install the - mysql-testdirectory. To suppress installation of this directory, explicitly set the option to the empty value (- -DINSTALL_MYSQLTESTDIR=).
- -DINSTALL_PKGCONFIGDIR=- dir_name- The directory in which to install the - mysqlclient.pcfile for use by pkg-config. The default value is- INSTALL_LIBDIR/pkgconfig, unless- INSTALL_LIBDIRends with- /mysql, in which case that is removed first.
- The location of the plugin directory. - This value can be set at server startup with the - --plugin_diroption.
- -DINSTALL_PRIV_LIBDIR=- dir_name- The location of the dynamic library directory. - Default location. For RPM builds, this is - /usr/lib64/mysql/private/, for DEB it is- /usr/lib/mysql/private/, and for TAR it is- lib/private/.- Protobuf. Because this is a private location, the loader (such as - ld-linux.soon Linux) may not find the- libprotobuf.sofiles without help. To guide the loader,- RPATH=$ORIGIN/../$INSTALL_PRIV_LIBDIRis added to mysqld and mysqlxtest. This works for most cases but when using the Resource Group feature, mysqld is- setsuid, and the loader ignores any- RPATHwhich contains- $ORIGIN. To overcome this, an explicit full path to the directory is set in the DEB and RPM versions of mysqld, since the target destination is known. For tarball installs, patching of mysqld with a tool like patchelf is required.- This option was added in MySQL 8.0.18. 
- Where to install the mysqld server. 
- -DINSTALL_SECURE_FILE_PRIVDIR=- dir_name- The default value for the - secure_file_privsystem variable. The default value is platform specific and depends on the value of the- INSTALL_LAYOUTCMake option; see the description of the- secure_file_privsystem variable in Server System Variables.
- Where to install - aclocal/mysql.m4.
- -DINSTALL_STATIC_LIBRARIES=- bool- Whether to install static libraries. The default is - ON. If set to- OFF, these library files are not installed:- libmysqlclient.a,- libmysqlservices.a.
- -DINSTALL_SUPPORTFILESDIR=- dir_name- Where to install extra support files. 
- Whether to randomize the order of symbols in the mysqld binary. The default is - OFF. This option should be enabled only for debugging purposes.
- Seed value for the - LINK_RANDOMIZEoption. The value is a string. The default is- mysql, an arbitrary choice.
- The location of the MySQL data directory. - This value can be set at server startup with the - --datadiroption.
- The location of the ODBC includes directory, which may be used while configuring Connector/ODBC. 
- The location of the ODBC library directory, which may be used while configuring Connector/ODBC. 
- The default - my.cnfoption file directory.- This location cannot be set at server startup, but you can start the server with a given option file using the - --defaults-file=option, where- file_name- file_nameis the full path name to the file.
- The name of the directory in which to create the PID file when MySQL is managed by systemd. The default is - /var/run/mysqld; this might be changed implicitly according to the- INSTALL_LAYOUTvalue.- This option is ignored unless - WITH_SYSTEMDis enabled.
- The name of the MySQL service to use when MySQL is managed by systemd. The default is - mysqld; this might be changed implicitly according to the- INSTALL_LAYOUTvalue.- This option is ignored unless - WITH_SYSTEMDis enabled.
- The default location to use for the - tmpdirsystem variable. If unspecified, the value defaults to- P_tmpdirin- <stdio.h>.
        Storage engines are built as plugins. You can build a plugin as
        a static module (compiled into the server) or a dynamic module
        (built as a dynamic library that must be installed into the
        server using the INSTALL PLUGIN
        statement or the --plugin-load
        option before it can be used). Some plugins might not support
        static or dynamic building.
      
        The InnoDB,
        MyISAM,
        MERGE,
        MEMORY, and
        CSV engines are mandatory (always
        compiled into the server) and need not be installed explicitly.
      
        To compile a storage engine statically into the server, use
        -DWITH_.
        Some permissible engine_STORAGE_ENGINE=1engine values are
        ARCHIVE, BLACKHOLE,
        EXAMPLE, and FEDERATED.
        Examples:
      
-DWITH_ARCHIVE_STORAGE_ENGINE=1
-DWITH_BLACKHOLE_STORAGE_ENGINE=1
        To build MySQL with support for NDB Cluster, use the
        WITH_NDB option. (NDB
        8.0.30 and earlier: Use
        WITH_NDBCLUSTER.)
It is not possible to compile without Performance Schema support. If it is desired to compile without particular types of instrumentation, that can be done with the following CMake options:
DISABLE_PSI_COND
DISABLE_PSI_DATA_LOCK
DISABLE_PSI_ERROR
DISABLE_PSI_FILE
DISABLE_PSI_IDLE
DISABLE_PSI_MEMORY
DISABLE_PSI_METADATA
DISABLE_PSI_MUTEX
DISABLE_PSI_PS
DISABLE_PSI_RWLOCK
DISABLE_PSI_SOCKET
DISABLE_PSI_SP
DISABLE_PSI_STAGE
DISABLE_PSI_STATEMENT
DISABLE_PSI_STATEMENT_DIGEST
DISABLE_PSI_TABLE
DISABLE_PSI_THREAD
DISABLE_PSI_TRANSACTION
          For example, to compile without mutex instrumentation,
          configure MySQL using
          -DDISABLE_PSI_MUTEX=1.
        To exclude a storage engine from the build, use
        -DWITH_.
        Examples:
      engine_STORAGE_ENGINE=0
-DWITH_ARCHIVE_STORAGE_ENGINE=0
-DWITH_EXAMPLE_STORAGE_ENGINE=0
-DWITH_FEDERATED_STORAGE_ENGINE=0
        It is also possible to exclude a storage engine from the build
        using
        -DWITHOUT_
        (but
        engine_STORAGE_ENGINE=1-DWITH_
        is preferred). Examples:
      engine_STORAGE_ENGINE=0
-DWITHOUT_ARCHIVE_STORAGE_ENGINE=1
-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1
-DWITHOUT_FEDERATED_STORAGE_ENGINE=1
        If neither
        -DWITH_
        nor
        engine_STORAGE_ENGINE-DWITHOUT_
        are specified for a given storage engine, the engine is built as
        a shared module, or excluded if it cannot be built as a shared
        module.
engine_STORAGE_ENGINE
- This option determines whether to enable generation of a - .gdb_indexsection in binaries, which makes loading them in a debugger faster. The option is disabled by default. lld linker is used, and is disabled by It has no effect if a linker other than lld or GNU gold is used.- This option was added in MySQL 8.0.18. 
- A descriptive comment about the compilation environment. As of MySQL 8.0.14, mysqld uses - COMPILATION_COMMENT_SERVER. Other programs continue to use- COMPILATION_COMMENT.
- -DCOMPRESS_DEBUG_SECTIONS=- bool- Whether to compress the debug sections of binary executables (Linux only). Compressing executable debug sections saves space at the cost of extra CPU time during the build process. - The default is - OFF. If this option is not set explicitly but the- COMPRESS_DEBUG_SECTIONSenvironment variable is set, the option takes its value from that variable.- This option was added in MySQL 8.0.22. 
- -DCOMPILATION_COMMENT_SERVER=- string- A descriptive comment about the compilation environment for use by mysqld (for example, to set the - version_commentsystem variable). This option was added in MySQL 8.0.14. Prior to 8.0.14, the server uses- COMPILATION_COMMENT.
- -DDEFAULT_CHARSET=- charset_name- The server character set. By default, MySQL uses the - utf8mb4character set.- charset_namemay be one of- binary,- armscii8,- ascii,- big5,- cp1250,- cp1251,- cp1256,- cp1257,- cp850,- cp852,- cp866,- cp932,- dec8,- eucjpms,- euckr,- gb2312,- gbk,- geostd8,- greek,- hebrew,- hp8,- keybcs2,- koi8r,- koi8u,- latin1,- latin2,- latin5,- latin7,- macce,- macroman,- sjis,- swe7,- tis620,- ucs2,- ujis,- utf8mb3,- utf8mb4,- utf16,- utf16le,- utf32.- This value can be set at server startup with the - --character-set-serveroption.
- -DDEFAULT_COLLATION=- collation_name- The server collation. By default, MySQL uses - utf8mb4_0900_ai_ci. Use the- SHOW COLLATIONstatement to determine which collations are available for each character set.- This value can be set at server startup with the - --collation_serveroption.
- Whether to exclude the Performance Schema condition instrumentation. The default is - OFF(include).
- Whether to exclude the Performance Schema file instrumentation. The default is - OFF(include).
- Whether to exclude the Performance Schema idle instrumentation. The default is - OFF(include).
- Whether to exclude the Performance Schema memory instrumentation. The default is - OFF(include).
- Whether to exclude the Performance Schema metadata instrumentation. The default is - OFF(include).
- Whether to exclude the Performance Schema mutex instrumentation. The default is - OFF(include).
- Whether to exclude the Performance Schema rwlock instrumentation. The default is - OFF(include).
- Whether to exclude the Performance Schema socket instrumentation. The default is - OFF(include).
- Whether to exclude the Performance Schema stored program instrumentation. The default is - OFF(include).
- Whether to exclude the Performance Schema stage instrumentation. The default is - OFF(include).
- Whether to exclude the Performance Schema statement instrumentation. The default is - OFF(include).
- -DDISABLE_PSI_STATEMENT_DIGEST=- bool- Whether to exclude the Performance Schema statement digest instrumentation. The default is - OFF(include).
- Whether to exclude the Performance Schema table instrumentation. The default is - OFF(include).
- Whether to disable building build shared libraries and compile position-dependent code. The default is - OFF(compile position-independent code).- This option is unused, and was removed in MySQL 8.0.18. 
- Exclude the Performance Schema prepared statements instances instrumentation. The default is - OFF(include).
- Exclude the Performance Schema thread instrumentation. The default is - OFF(include).- Only disable threads when building without any instrumentation, because other instrumentations have a dependency on threads. 
- -DDISABLE_PSI_TRANSACTION=- bool- Exclude the Performance Schema transaction instrumentation. The default is - OFF(include).
- Exclude the performance schema data lock instrumentation. The default is - OFF(include).
- Exclude the performance schema server error instrumentation. The default is - OFF(include).
- Whether to download the Boost library. The default is - OFF.- See the - WITH_BOOSToption for additional discussion about using Boost.
- -DDOWNLOAD_BOOST_TIMEOUT=- seconds- The timeout in seconds for downloading the Boost library. The default is 600 seconds. - See the - WITH_BOOSToption for additional discussion about using Boost.
- Whether to download optional files. For example, with this option enabled, CMake downloads the Google Test distribution that is used by the test suite to run unit tests, or Ant and JUnit, required for building the GCS Java wrapper. - As of MySQL 8.0.26, MySQL source distributions bundle the Google Test source code used to run unit tests. Consequently, as of that version the - WITH_GMOCKand- ENABLE_DOWNLOADSCMake options are removed and are ignored if specified.
- -DENABLE_EXPERIMENTAL_SYSVARS=- bool- Whether to enable experimental - InnoDBsystem variables. Experimental system variables are intended for those engaged in MySQL development, should only be used in a development or test environment, and may be removed without notice in a future MySQL release. For information about experimental system variables, refer to- /storage/innobase/handler/ha_innodb.ccin the MySQL source tree. Experimental system variables can be identified by searching for “PLUGIN_VAR_EXPERIMENTAL”.
- Whether to include gcov support (Linux only). 
- Whether to enable gprof (optimized Linux builds only). 
- This option controls the compiled-in default - LOCALcapability for the MySQL client library. Clients that make no explicit arrangements therefore have- LOCALcapability disabled or enabled according to the- ENABLED_LOCAL_INFILEsetting specified at MySQL build time.- By default, the client library in MySQL binary distributions is compiled with - ENABLED_LOCAL_INFILEdisabled. If you compile MySQL from source, configure it with- ENABLED_LOCAL_INFILEdisabled or enabled based on whether clients that make no explicit arrangements should have- LOCALcapability disabled or enabled, respectively.- ENABLED_LOCAL_INFILEcontrols the default for client-side- LOCALcapability. For the server, the- local_infilesystem variable controls server-side- LOCALcapability. To explicitly cause the server to refuse or permit- LOAD DATA LOCALstatements (regardless of how client programs and libraries are configured at build time or runtime), start mysqld with- --local-infiledisabled or enabled, respectively.- local_infilecan also be set at runtime. See Security Considerations for LOAD DATA LOCAL.
- Whether to enable query profiling code (for the - SHOW PROFILEand- SHOW PROFILESstatements).
- -DFORCE_UNSUPPORTED_COMPILER=- bool- By default, CMake checks for minimum versions of supported compilers; to disable this check, use - -DFORCE_UNSUPPORTED_COMPILER=ON.
- Whether to generate profile guided optimization (PGO) data. This option is available for experimenting with PGO with GCC. See - cmake/fprofile.cmakein the MySQL source distribution for information about using- FPROFILE_GENERATEand- FPROFILE_USE. These options have been tested with GCC 8 and 9.- This option was added in MySQL 8.0.19. 
- Whether to use profile guided optimization (PGO) data. This option is available for experimenting with PGO with GCC. See the - cmake/fprofile.cmakefile in a MySQL source distribution for information about using- FPROFILE_GENERATEand- FPROFILE_USE. These options have been tested with GCC 8 and 9.- Enabling - FPROFILE_USEalso enables- WITH_LTO.- This option was added in MySQL 8.0.19. 
- -DHAVE_PSI_MEMORY_INTERFACE=- bool- Whether to enable the performance schema memory tracing module for memory allocation functions ( - ut::aligned_library functions) used in dynamic storage of over-aligned types.- name
- If the - -DBUILD_CONFIG=mysql_releaseoption is given on Linux, the- libaiolibrary must be linked in by default. If you do not have- libaioor do not want to install it, you can suppress the check for it by specifying- -DIGNORE_AIO_CHECK=1.
- The maximum number of indexes per table. The default is 64. The maximum is 255. Values smaller than 64 are ignored and the default of 64 is used. 
- Whether to enable a MySQL maintainer-specific development environment. If enabled, this option causes compiler warnings to become errors. 
- -DWITH_DEVELOPER_ENTITLEMENTS=- bool- Whether to add the - get-task-allowentitlement to all executables to generate a core dump in the event of an unexpected server halt.- On macOS 11+, core dumps are limited to processes with the - com.apple.security.get-task-allowentitlement, which this CMake option enables. The entitlement allows other processes to attach and read/modify the processes memory, and allows- --core-fileto function as expected.- This option was added in MySQL 8.0.30. 
- The mutex type used by - InnoDB. Options include:- event: Use event mutexes. This is the default value and the original- InnoDBmutex implementation.
- sys: Use POSIX mutexes on UNIX systems. Use- CRITICAL_SECTIONobjects on Windows, if available.
- futex: Use Linux futexes instead of condition variables to schedule waiting threads.
 
- The port number on which X Plugin listens for TCP/IP connections. The default is 33060. - This value can be set at server startup with the - mysqlx_portsystem variable.
- The Unix socket file path on which the server listens for X Plugin socket connections. This must be an absolute path name. The default is - /tmp/mysqlx.sock.- This value can be set at server startup with the - mysqlx_portsystem variable.
- For Windows or macOS, the project name to incorporate into the project file name. 
- The port number on which the server listens for TCP/IP connections. The default is 3306. - This value can be set at server startup with the - --portoption.
- The Unix socket file path on which the server listens for socket connections. This must be an absolute path name. The default is - /tmp/mysql.sock.- This value can be set at server startup with the - --socketoption.
- Whether to support optimizer tracing. See Tracing the Optimizer. 
- For builds on Linux systems, this option controls whether to take extra care to create a build result independent of build location and time. - This option was added in MySQL 8.0.11. As of MySQL 8.0.12, it defaults to - ONfor- RelWithDebInfobuilds.
- -DSHOW_SUPPRESSED_COMPILER_WARNINGS=- bool- Show suppressed compiler warnings, and do so without failing with - -Werror. Defaults to- OFF.- This option was added in MySQL 8.0.30. 
- GNU gold linker support was removed in MySQL 8.0.31; this CMake option was also removed. - CMake causes the build process to link with the GNU gold linker if it is available and not explicitly disabled. To disable use of this linker, specify the - -DUSE_LD_GOLD=OFFoption.
- CMake causes the build process to link using the LLVM lld linker for Clang if it is available and not explicitly disabled. To disable use of this linker, specify the - -DUSE_LD_LLD=OFFoption.- This option was added in MySQL 8.0.16. 
- Whether to disable function inlining on Windows. The default is - OFF(inlining enabled).
- Set the path to Ant, required when building GCS Java wrapper. Set - WITH_ANTto the path of a directory where the Ant tarball or unpacked archive is saved. When- WITH_ANTis not set, or is set with the special value- system, the build process assumes a binary- antexists in- $PATH.
- Whether to enable the AddressSanitizer, for compilers that support it. The default is - OFF.
- Whether to enable the AddressSanitizer - -fsanitize-address-use-after-scopeClang flag for use-after-scope detection. The default is off. To use this option,- -DWITH_ASANmust also be enabled.
- -DWITH_AUTHENTICATION_CLIENT_PLUGINS=- bool- This option is enabled automatically if any corresponding server authentication plugins are built. Its value thus depends on other CMake options and it should not be set explicitly. - This option was added in MySQL 8.0.26. 
- -DWITH_AUTHENTICATION_LDAP=- bool- Whether to report an error if the LDAP authentication plugins cannot be built: - If this option is disabled (the default), the LDAP plugins are built if the required header files and libraries are found. If they are not, CMake displays a note about it. 
- If this option is enabled, a failure to find the required header file and libraries causes CMake to produce an error, preventing the server from being built. 
 - For information about LDAP authentication, see LDAP Pluggable Authentication. 
- -DWITH_AUTHENTICATION_PAM=- bool- Whether to build the PAM authentication plugin, for source trees that include this plugin. (See PAM Pluggable Authentication.) If this option is specified and the plugin cannot be compiled, the build fails. 
- The location of the Amazon Web Services software development kit. 
- The Boost library is required to build MySQL. These CMake options enable control over the library source location, and whether to download it automatically: - -DWITH_BOOST=specifies the Boost library directory location. It is also possible to specify the Boost location by setting the- path_name- BOOST_ROOTor- WITH_BOOSTenvironment variable.- -DWITH_BOOST=systemis also permitted and indicates that the correct version of Boost is installed on the compilation host in the standard location. In this case, the installed version of Boost is used rather than any version included with a MySQL source distribution.
- -DDOWNLOAD_BOOST=specifies whether to download the Boost source if it is not present in the specified location. The default is- bool- OFF.
- -DDOWNLOAD_BOOST_TIMEOUT=the timeout in seconds for downloading the Boost library. The default is 600 seconds.- seconds
 - For example, if you normally build MySQL placing the object output in the - bldsubdirectory of your MySQL source tree, you can build with Boost like this:- mkdir bld cd bld cmake .. -DDOWNLOAD_BOOST=ON -DWITH_BOOST=$HOME/my_boost- This causes Boost to be downloaded into the - my_boostdirectory under your home directory. If the required Boost version is already there, no download is done. If the required Boost version changes, the newer version is downloaded.- If Boost is already installed locally and your compiler finds the Boost header files on its own, it may not be necessary to specify the preceding CMake options. However, if the version of Boost required by MySQL changes and the locally installed version has not been upgraded, you may have build problems. Using the CMake options should give you a successful build. - With the above settings that allow Boost download into a specified location, when the required Boost version changes, you need to remove the - bldfolder, recreate it, and perform the cmake step again. Otherwise, the new Boost version might not get downloaded, and compilation might fail.
- -DWITH_CLIENT_PROTOCOL_TRACING=- bool- Whether to build the client-side protocol tracing framework into the client library. By default, this option is enabled. - For information about writing protocol trace client plugins, see Writing Protocol Trace Plugins. - See also the - WITH_TEST_TRACE_PLUGINoption.
- The location of the - curllibrary.- curl_typecan be- system(use the system- curllibrary) or a path name to the- curllibrary.
- Whether to include debugging support. - Configuring MySQL with debugging support enables you to use the - --debug="d,parser_debug"option when you start the server. This causes the Bison parser that is used to process SQL statements to dump a parser trace to the server's standard error output. Typically, this output is written to the error log.- Sync debug checking for the - InnoDBstorage engine is defined under- UNIV_DEBUGand is available when debugging support is compiled in using the- WITH_DEBUGoption. When debugging support is compiled in, the- innodb_sync_debugconfiguration option can be used to enable or disable- InnoDBsync debug checking.- Enabling - WITH_DEBUGalso enables Debug Sync. This facility is used for testing and debugging. When compiled in, Debug Sync is disabled by default at runtime. To enable it, start mysqld with the- --debug-sync-timeout=option, where- N- Nis a timeout value greater than 0. (The default value is 0, which disables Debug Sync.)- Nbecomes the default timeout for individual synchronization points.- Sync debug checking for the - InnoDBstorage engine is available when debugging support is compiled in using the- WITH_DEBUGoption.- For a description of the Debug Sync facility and how to use synchronization points, see MySQL Internals: Test Synchronization. 
- -DWITH_DEFAULT_FEATURE_SET=- bool- Whether to use the flags from - cmake/build_configurations/feature_set.cmake. This option was removed in MySQL 8.0.22.
- Which - libedit/- editlinelibrary to use. The permitted values are- bundled(the default) and- system.
- The - authentication_fidoauthentication plugin is implemented using a FIDO library (see FIDO Pluggable Authentication). The- WITH_FIDOoption indicates the source of FIDO support:- bundled: Use the FIDO library bundled with the distribution. This is the default.- As of MySQL 8.0.30, MySQL includes - fido2version 1.8.0. (Prior releases used- fido21.5.0).
- system: Use the system FIDO library.
 - WITH_FIDOis disabled (set to- none) if all authentication plugins are disabled.- This option was added in MySQL 8.0.27. 
- The path to the googlemock distribution, for use with Google Test-based unit tests. The option value is the path to the distribution zip file. Alternatively, set the - WITH_GMOCKenvironment variable to the path name. It is also possible to use- -DENABLE_DOWNLOADS=1, so that CMake downloads the distribution from GitHub.- If you build MySQL without the Google Test unit tests (by configuring without - WITH_GMOCK), CMake displays a message indicating how to download it.- As of MySQL 8.0.26, MySQL source distributions bundle the Google Test source code. Consequently, as of that version, the - WITH_GMOCKand- ENABLE_DOWNLOADSCMake options are removed and are ignored if specified.
- -DWITH_ICU={- icu_type|- path_name}- MySQL uses International Components for Unicode (ICU) to support regular expression operations. The - WITH_ICUoption indicates the type of ICU support to include or the path name to the ICU installation to use.- icu_typecan be one of the following values:- bundled: Use the ICU library bundled with the distribution. This is the default, and is the only supported option for Windows.
- system: Use the system ICU library.
 
- path_nameis the path name to the ICU installation to use. This can be preferable to using the- icu_typevalue of- systembecause it can prevent CMake from detecting and using an older or incorrect ICU version installed on the system. (Another permitted way to do the same thing is to set- WITH_ICUto- systemand set the- CMAKE_PREFIX_PATHoption to- path_name.)
 
- -DWITH_INNODB_EXTRA_DEBUG=- bool- Whether to include extra InnoDB debugging support. - Enabling - WITH_INNODB_EXTRA_DEBUGturns on extra InnoDB debug checks. This option can only be enabled when- WITH_DEBUGis enabled.
- Whether to generate memcached shared libraries ( - libmemcached.soand- innodb_engine.so).
- Whether to link with - -ljemalloc. If enabled, built-in- malloc(),- calloc(),- realloc(), and- free()routines are disabled. The default is- OFF.- WITH_JEMALLOCand- WITH_TCMALLOCare mutually exclusive.- This option was added in MySQL 8.0.16. 
- Whether to build the test program that accompanies the - keyring_fileplugin. The default is- OFF. Test file source code is located in the- plugin/keyring/keyring-testdirectory.
- Which - libeventlibrary to use. Permitted values are- bundled(default) and- system. Prior to MySQL 8.0.21, if you specify- system, the system- libeventlibrary is used if present, and an error occurs otherwise. In MySQL 8.0.21 and later, if- systemis specified and no system- libeventlibrary can be found, an error occurs regardless, and the bundled- libeventis not used.- The - libeventlibrary is required by- InnoDBmemcached, X Plugin, and MySQL Router.
- Whether to include - libwrap(TCP wrappers) support.
- Whether to enable LOCK_ORDER tooling. By default, this option is disabled and server builds contain no tooling. If tooling is enabled, the LOCK_ORDER tool is available and can be used as described in The LOCK_ORDER Tool. Note- With the - WITH_LOCK_ORDERoption enabled, MySQL builds require the flex program.- This option was added in MySQL 8.0.17. 
- Whether to run LeakSanitizer, without AddressSanitizer. The default is - OFF.- This option was added in MySQL 8.0.16. 
- Whether to enable the link-time optimizer, if the compiler supports it. The default is - OFFunless- FPROFILE_USEis enabled.- This option was added in MySQL 8.0.13. 
- The - WITH_LZ4option indicates the source of- zlibsupport:- bundled: Use the- lz4library bundled with the distribution. This is the default.
- system: Use the system- lz4library. If- WITH_LZ4is set to this value, the lz4_decompress utility is not built. In this case, the system lz4 command can be used instead.
 
- The type of LZMA library support to include. - lzma_typecan be one of the following values:- bundled: Use the LZMA library bundled with the distribution. This is the default.
- system: Use the system LZMA library.
 - This option was removed in MySQL 8.0.16. 
- -DWITH_MECAB={disabled|system|- path_name}- Use this option to compile the MeCab parser. If you have installed MeCab to its default installation directory, set - -DWITH_MECAB=system. The- systemoption applies to MeCab installations performed from source or from binaries using a native package management utility. If you installed MeCab to a custom installation directory, specify the path to the MeCab installation, for example,- -DWITH_MECAB=/opt/mecab. If the- systemoption does not work, specifying the MeCab installation path should work in all cases.- For related information, see MeCab Full-Text Parser Plugin. 
- Whether to enable MemorySanitizer, for compilers that support it. The default is off. - For this option to have an effect if enabled, all libraries linked to MySQL must also have been compiled with the option enabled. 
- Whether to enable Visual Studio CRT memory leak tracing. The default is - OFF.
- Whether to enable MSVC code analysis. The default is - OFF.
- Whether to build with support for X Plugin. The default is - ON. See Using MySQL as a Document Store.
- Explicitly set the NUMA memory allocation policy. CMake sets the default - WITH_NUMAvalue based on whether the current platform has- NUMAsupport. For platforms without NUMA support, CMake behaves as follows:- With no NUMA option (the normal case), CMake continues normally, producing only this warning: NUMA library missing or required version not available. 
- With - -DWITH_NUMA=ON, CMake aborts with this error: NUMA library missing or required version not available.
 
- For flags typically used for RPM and Debian packages, whether to add them to standalone builds on those platforms. The default is - ONfor nondebug builds.- This option was added in MySQL 8.0.26. 
- Which Protocol Buffers package to use. - protobuf_typecan be one of the following values:- bundled: Use the package bundled with the distribution. This is the default. Optionally use- INSTALL_PRIV_LIBDIRto modify the dynamic Protobuf library directory.
- system: Use the package installed on the system.
 - Other values are ignored, with a fallback to - bundled.
- Whether to build the rapid development cycle plugins. When enabled, a - rapiddirectory is created in the build tree containing these plugins. When disabled, no- rapiddirectory is created in the build tree. The default is- ON, unless the- rapiddirectory is removed from the source tree, in which case the default becomes- OFF.
- -DWITH_RAPIDJSON=- rapidjson_type- The type of RapidJSON library support to include. - rapidjson_typecan be one of the following values:- bundled: Use the RapidJSON library bundled with the distribution. This is the default.
- system: Use the system RapidJSON library. Version 1.1.0 or later is required.
 - This option was added in MySQL 8.0.13. 
- The type of RE2 library support to include. - re2_typecan be one of the following values:- bundled: Use the RE2 library bundled with the distribution. This is the default.
- system: Use the system RE2 library.
 - As of MySQL 8.0.18, MySQL no longer uses the RE2 library, and this option has been removed. 
- Whether to build MySQL Router. The default is - ON.- This option was added in MySQL 8.0.16. 
- Internal use only. This option was added in 8.0.20. Not supported on Windows. 
- -DWITH_SSL={|- ssl_type- path_name}- For support of encrypted connections, entropy for random number generation, and other encryption-related operations, MySQL must be built using an SSL library. This option specifies which SSL library to use. - ssl_typecan be one of the following values:- system: Use the system OpenSSL library. This is the default.- On macOS and Windows, using - systemconfigures MySQL to build as if CMake was invoked with- path_namepoints to a manually installed OpenSSL library. This is because they do not have system SSL libraries. On macOS, brew install openssl installs to- /usr/local/opt/opensslso that- systemcan find it. On Windows, it checks- %ProgramFiles%/OpenSSL,- %ProgramFiles%/OpenSSL-Win32,- %ProgramFiles%/OpenSSL-Win64,- C:/OpenSSL,- C:/OpenSSL-Win32, and- C:/OpenSSL-Win64.
- yes: This is a synonym for- system.
- openssl: (MySQL 8.0.30 and later:) Use an alternate OpenSSL system package such as- version- openssl11on EL7, or- openssl3on EL8.- Authentication plugins, such as LDAP and Kerberos, are disabled as they do not support these alternative versions of OpenSSL. 
 
- path_nameis the path name to the OpenSSL installation to use. This can be preferable to using the- ssl_typevalue of- systembecause it can prevent CMake from detecting and using an older or incorrect OpenSSL version installed on the system. (Another permitted way to do the same thing is to set- WITH_SSLto- systemand set the- CMAKE_PREFIX_PATHoption to- path_name.)
 - For additional information about configuring the SSL library, see Configuring SSL Library Support. 
- Whether to enable installation of systemd support files. By default, this option is disabled. When enabled, systemd support files are installed, and scripts such as mysqld_safe and the System V initialization script are not installed. On platforms where systemd is not available, enabling - WITH_SYSTEMDresults in an error from CMake.- For more information about using systemd, see Managing MySQL Server with systemd. That section also includes information about specifying options otherwise specified in - [mysqld_safe]option groups. Because mysqld_safe is not installed when systemd is used, such options must be specified another way.
- This option serves as an “umbrella” option to set the - systemvalue of any of the following CMake options that are not set explicitly:- WITH_CURL,- WITH_EDITLINE,- WITH_FIDO,- WITH_ICU,- WITH_LIBEVENT,- WITH_LZ4,- WITH_LZMA,- WITH_PROTOBUF,- WITH_RE2,- WITH_SSL,- WITH_ZSTD.- WITH_ZLIBwas included here priot MySQL 8.0.30.
- Whether to produce additional systemd debugging information, for platforms on which systemd is used to run MySQL. The default is - OFF.- This option was added in MySQL 8.0.22. 
- Whether to link with - -ltcmalloc. If enabled, built-in- malloc(),- calloc(),- realloc(), and- free()routines are disabled. The default is- OFF.- Beginning with MySQL 8.0.38, a - tcmalloclibrary is included in the source; you can cause the build to use the bundled version by setting this option to- BUNDLED.- BUNDLEDis supported on Linux systems only.- WITH_TCMALLOCand- WITH_JEMALLOCare mutually exclusive.- This option was added in MySQL 8.0.22. 
- Whether to build the test protocol trace client plugin (see Using the Test Protocol Trace Plugin). By default, this option is disabled. Enabling this option has no effect unless the - WITH_CLIENT_PROTOCOL_TRACINGoption is enabled. If MySQL is configured with both options enabled, the- libmysqlclientclient library is built with the test protocol trace plugin built in, and all the standard MySQL clients load the plugin. However, even when the test plugin is enabled, it has no effect by default. Control over the plugin is afforded using environment variables; see Using the Test Protocol Trace Plugin.Note- Do not enable the - WITH_TEST_TRACE_PLUGINoption if you want to use your own protocol trace plugins because only one such plugin can be loaded at a time and an error occurs for attempts to load a second one. If you have already built MySQL with the test protocol trace plugin enabled to see how it works, you must rebuild MySQL without it before you can use your own plugins.- For information about writing trace plugins, see Writing Protocol Trace Plugins. 
- Whether to enable the ThreadSanitizer, for compilers that support it. The default is off. 
- Whether to enable the Undefined Behavior Sanitizer, for compilers that support it. The default is off. 
- If enabled, compile MySQL with unit tests. The default is - ONunless the server is not being compiled.
- Enables unixODBC support, for Connector/ODBC. 
- Whether to compile in the Valgrind header files, which exposes the Valgrind API to MySQL code. The default is - OFF.- To generate a Valgrind-aware debug build, - -DWITH_VALGRIND=1normally is combined with- -DWITH_DEBUG=1. See Building Debug Configurations.
- On Windows, pass in a path to a directory containing - jemalloc.dllto enable jemalloc functionality. The build system copies- jemalloc.dllto the same directory as- mysqld.exeand/or- mysqld-debug.exeand utilizes it for memory management operations. Standard memory functions are used if- jemalloc.dllis not found or does not export the required functions. An INFORMATION level log message records whether or not jemalloc is found and used.- This option is enabled for official MySQL binaries for Windows. - This option was added in MySQL 8.0.29. 
- Some features require that the server be built with compression library support, such as the - COMPRESS()and- UNCOMPRESS()functions, and compression of the client/server protocol. The- WITH_ZLIBoption indicates the source of- zlibsupport:- In MYSQL 8.0.32 and later, the minimum supported version of - zlibis 1.2.13.- bundled: Use the- zliblibrary bundled with the distribution. This is the default.
- system: Use the system- zliblibrary. If- WITH_ZLIBis set to this value, the zlib_decompress utility is not built. In this case, the system openssl zlib command can be used instead.
 
- Connection compression using the - zstdalgorithm (see Connection Compression Control) requires that the server be built with- zstdlibrary support. The- WITH_ZSTDoption indicates the source of- zstdsupport:- bundled: Use the- zstdlibrary bundled with the distribution. This is the default.
- system: Use the system- zstdlibrary.
 - This option was added in MySQL 8.0.18. 
- Whether to build without MySQL Server. The default is OFF, which does build the server. - This is considered an experimental option; it is preferred to build with the server. - This option also prevents building of the - NDBstorage engine or any- NDBbinaries including management and data node programs.
- Flags for the C compiler. 
- Flags for the C++ compiler. 
- -DWITH_DEFAULT_COMPILER_OPTIONS=- bool- Whether to use the flags from - cmake/build_configurations/compiler_options.cmake.Note- All optimization flags are carefully chosen and tested by the MySQL build team. Overriding them can lead to unexpected results and is done at your own risk. 
- -DOPTIMIZE_SANITIZER_BUILDS=- bool- Whether to add - -O1 -fno-inlineto sanitizer builds. The default is- ON.
        To specify your own C and C++ compiler flags, for flags that do
        not affect optimization, use the
        CMAKE_C_FLAGS and
        CMAKE_CXX_FLAGS CMake options.
      
        When providing your own compiler flags, you might want to
        specify CMAKE_BUILD_TYPE as well.
      
For example, to create a 32-bit release build on a 64-bit Linux machine, do this:
$> mkdir build
$> cd build
$> cmake .. -DCMAKE_C_FLAGS=-m32 \
  -DCMAKE_CXX_FLAGS=-m32 \
  -DCMAKE_BUILD_TYPE=RelWithDebInfo
        If you set flags that affect optimization
        (-O), you must
        set the
        numberCMAKE_C_FLAGS_
        and/or
        build_typeCMAKE_CXX_FLAGS_
        options, where build_typebuild_type corresponds
        to the CMAKE_BUILD_TYPE value. To
        specify a different optimization for the default build type
        (RelWithDebInfo) set the
        CMAKE_C_FLAGS_RELWITHDEBINFO and
        CMAKE_CXX_FLAGS_RELWITHDEBINFO options. For
        example, to compile on Linux with -O3 and with
        debug symbols, do this:
      
$> cmake .. -DCMAKE_C_FLAGS_RELWITHDEBINFO="-O3 -g" \
  -DCMAKE_CXX_FLAGS_RELWITHDEBINFO="-O3 -g"
        To compile with support for NDB Cluster, you can use
        -DWITH_NDB, which causes the build
        to include the NDB storage engine and all NDB programs. This
        option is enabled by default. To prevent building of the NDB
        storage engine plugin, use
        -DWITH_NDBCLUSTER_STORAGE_ENGINE=OFF.
        Other aspects of the build can be controlled using the other
        options listed in this section.
      
The following options apply when building the MySQL sources with NDB Cluster support.
- NDBsupport for memcached was removed in NDB 8.0.23; thus, this option is no longer supported for building- NDBin this or later versions.
- -DNDB_UTILS_LINK_DYNAMIC={ON|OFF}- Controls whether NDB utilities such as ndb_drop_table are linked with - ndbclientstatically (- OFF) or dynamically (- ON);- OFF(static linking) is the default. Normally static linking is used when building these to avoid problems with- LD_LIBRARY_PATH, or when multiple versions of- ndbclientare installed. This option is intended for creating Docker images and possibly other cases in which the target environment is subject to precise control and it is desirable to reduce image size.- Added in NDB 8.0.22. 
- -DWITH_BUNDLED_LIBEVENT={ON|OFF}- NDBsupport for memcached was removed in NDB 8.0.23; thus, this option is no longer supported for building- NDBin this or later versions.
- -DWITH_BUNDLED_MEMCACHED={ON|OFF}- NDBsupport for memcached was removed in NDB 8.0.23; thus, this option is no longer supported for building- NDBin this or later versions.
- Sets the classpath for building MySQL NDB Cluster Connector for Java. The default is empty. This option is ignored if - -DWITH_NDB_JAVA=OFFis used.
- Enables error injection in the - NDBkernel. For testing only; not intended for use in building production binaries. The default is- OFF.
- Build MySQL NDB Cluster; build the NDB plugin and all NDB Cluster programs. - Added in NDB 8.0.31. 
- -DWITH_NDBAPI_EXAMPLES={ON|OFF}- Build NDB API example programs in - storage/ndb/ndbapi-examples/. See NDB API Examples, for information about these.
- -DWITH_NDBCLUSTER_STORAGE_ENGINE={ON|OFF}- NDB 8.0.30 and earlier: For internal use only; may not always work as expected. To build with - NDBsupport, use- WITH_NDBCLUSTERinstead.- NDB 8.0.31 and later: Controls (only) whether the - NDBCLUSTERstorage engine is included in the build;- WITH_NDBenables this option automatically, so it is recommended that you use- WITH_NDBinstead.
- -DWITH_NDBCLUSTER={ON|OFF}(DEPRECATED)- Build and link in support for the - NDBstorage engine in mysqld.- This option is deprecated as of NDB 8.0.31, and subject to eventual removal; use - WITH_NDBinstead.
- Build the multithreaded data node executable ndbmtd. The default is - ON.
- Enable building the debug versions of the NDB Cluster binaries. This is - OFFby default.
- Enable building NDB Cluster with Java support, including support for ClusterJ (see MySQL NDB Cluster Connector for Java). - This option is - ONby default. If you do not wish to compile NDB Cluster with Java support, you must disable it explicitly by specifying- -DWITH_NDB_JAVA=OFFwhen running CMake. Otherwise, if Java cannot be found, configuration of the build fails.
- Causes the NDB Cluster management server (ndb_mgmd) that is built to use this - portby default. If this option is unset, the resulting management server tries to use port 1186 by default.
- If enabled, include a set of NDB API test programs. The default is - OFF.
- -DWITH_PLUGIN_NDBCLUSTER={ON|OFF}- For internal use only; may not always work as expected. This option was removed in NDB 8.0.31; use - WITH_NDBinstead to build MySQL NDB Cluster. (NDB 8.0.30 and earlier: Use- WITH_NDBCLUSTER.)