MySQL* Optimization with Intel® C++ Compiler
How LeCloud Leverages MySQL* to Deliver Peak Service
LeCloud is a leading video cloud service provider that deploys its content delivery network (CDN) nodes in more than 60 countries and regions, with 20 terabytes per second (Tbps) of available bandwidth to support its cloud services―including cloud-on-demand, content sharing, distribution and live broadcasting of commercial events, virtual reality, and more. LeCloud platforms support more than a million live events per year, hundreds of millions of device accesses a day, and millions of concurrent users per second. With the heavy demand for its high-performance public database services, LeCloud uses MySQL*, a popular open-source database, as the basis for its cloud service.
One key challenge for LeCloud is optimizing MySQL database performance―also an important topic for many database administrators (DBA) and operation and maintenance IT developers. Key performance concerns include:
- Queries per second (QPS)
- Transactions per second (TPS)
- Query response time
This article shows how we optimized MySQL using Intel® C++ Compiler and its Interprocedural Optimization (IPO) capability. Without having to modify any code, we compiled the MySQL source code and tested the performance indicators. The result? By using Intel C++ Compiler optimizations on MySQL in a set of test scenarios, performance improved between 5% and 35%―bringing developers another avenue to better MySQL performance.
Intel® C++ Compiler
Intel® C++ Compiler, a component of Intel® Parallel Studio XE, is a C and C++ optimizing compiler that takes advantage of the latest instruction sets and architectural features to maximize performance. Because the Intel compiler development team knows the Intel architecture so well, they can do specialized―and more effective―optimization for CPU features like new SIMD instructions and cache structure for Intel® CPUs compared to other compilers like GNU GCC* or Microsoft Visual C++*. Some of the optimization technologies used in the present case study include:
- Automatic vectorization
- Guided auto parallelism
- Interprocedural optimization
- Profile-guided optimization
The Intel compilers help users get the most benefit out of their Intel-based platforms.
Automatic Vectorization
The automatic vectorizer (also called the auto-vectorizer) is a component of the Intel® compiler that automatically uses SIMD instructions in the Intel® Streaming SIMD Extensions (Intel® SSE, Intel® SSE2, Intel® SSE3, and Intel® SSE4), Supplemental Streaming SIMD Extensions (SSSE3) instruction sets, and the Intel® Advanced Vector Extensions (Intel® AVX, Intel® AVX2, Intel® AVX512) instruction sets. The vectorizer detects operations in the program that can be done in parallel and converts the sequential operations to parallel. For example, the vectorizer converts the sequential SIMD instruction that processes up to 16 elements into a parallel operation, depending on the data type. The compiler also supports a variety of auto-vectorizing hints that can help the compiler generate effective vector instructions on the latest processors, including the Intel® Xeon® E5-2699 v4 used in this case study.
Guided Auto Parallelism
The Guided Auto Parallelism (GAP) feature of the Intel C++ Compiler offers advice to improve the performance of sequential applications by suggesting changes that will take advantage of the compiler’s ability to automatically vectorize and parallelize code as well as improve the efficiency of data operations.
Interprocedural Optimization (IPO)
This automatic, multistep process allows the compiler to analyze code to find interprocedural optimizations (i.e., optimizations that go beyond individual program subunits) within source files and across multiple source files. IPO is covered in more detail below, as it is a key component of this case study.
Profile-Guided Optimization (PGO)
In PGO, the compiler analyzes the code while it runs and takes advantage of this profile information during subsequent recompilation. This improves application performance by shrinking code size, reducing branch mispredictions, and reorganizing code layout to minimize instruction-cache problems.
MySQL Optimization
Compiling with IPO
IPO is a key optimization technique in the Intel C++ Compiler. It does code profiling and static topological analysis based on both single-source and multi-source files, and then implements specific optimizations like inlining, constant propagation, and dead function elimination for programs that contain many commonly used small and medium-sized functions. Figure 1 shows the IPO process.
When you compile your source code with the IPO option, for single-file compilation, the compiler performs inline function expansion for calls to procedures defined within the current source file. For multi-file IPO, the compiler may perform some inlining according the multi-source code, such as inlining functions marked with inlining pragmas or attributes (GNU C and C++) and C++ class member functions with bodies included in the class declaration. After each source file is compiled with IPO, the compiler stores an intermediate representation of the source code in mock object files.
When you link with the IPO option, the compiler is invoked a final time to perform IPO across all mock object files. During the analysis process, the compiler reads all intermediate representations in the mock file, object files, and library files to determine if all references are resolved and whether or not a given symbol is defined in a mock object file. Symbols included in the intermediate representation in a mock object file for both data and functions are candidates for manipulation based on the results of whole program analysis.
Building MySQL with the Intel Compiler
The latest official version of MySQL (v5.6.27) was used in this case study. This section describes how to use Intel C++ Compiler to compile MySQL on Linux*.
Download the MySQL installation package:
wget http://downloads.mysql.com/archives/get/file/mysql-5.6.27.tar.gz tar –zxvf mysql-5.6.27.tar.gz
Compile MySQL with Intel C++ Compiler (Figure 2):
1. Install Cmake:
yum -y install wget make cmake gcc gcc-c++ autoconf automake zlib* libxml2* ncurses-devel libmcrypt* libtool-ltdl-devel*
2. Compile MySQL with Intel C++ Compiler: Set CC to icc, CXX to icpc, and enable IPO with the –ipo option.
Create MySQL Grant System Tables
cd /usr/local/mysql-5.6.27-icc groupadd mysql useradd -M -g mysql mysql -s /sbin/nologin ; chown -R mysql . chgrp -R mysql . ./scripts/mysql_install_db --user=mysql --collation-server=utf8_general_ci
Performance Testing
The purpose of this analysis is to do comparative performance testing between MySQL built with the GNU and Intel compilers. The performance metrics for online transaction processing (OLTP) include queries per second (QPS), and response time (RT). The test tool was Sysbench* (v0.4.12), a modular, cross-platform, multi-threaded benchmarking tool that is commonly used to evaluate database performance. Tables 1 and 2 show the test environment.
Server | Dell PowerEdge* R730xd | |
---|---|---|
Hardware Environment |
CPU | Intel® Xeon® processor E5-2699 v4 @ 2.20 GHz 2 |
Memory | 128 GB | |
Disk | SATA* SSD S3510, 1.5T 1 |
Software Environment |
OS version | CentOS* 6.6 |
---|---|---|
Kernel | 2.6.32-926 | |
Intel® C++ Compiler | ICC-17.0.1 | |
GNU GCC* | 4.4.7 20120313 (RedHat* 4.4.7-11) | |
MySQL* | MySQL 5.6.27 | |
Sysbench* | Sysbench-0.4.12 |
Test Steps
We installed two MySQL instances, 3308 and 3318, on the same Intel® SATA SSD disk, and used Sysbench for OLTP testing (Table 3). Before testing, we cleaned the operating system cache and disabled the MySQL query_cache. We created 10 MySQL database tables for testing, with one million records per table. 4, 8, 16, 32, 64, 128, and 512 test threads were used for random read OLTP. MySQL buffer_pool size was set as 2GB, 8GB, and 16GB. Each test was run three times and the average time was used as the final result.
Instance | MySQL* Version | Compiler | Engine | QueryCache |
---|---|---|---|---|
MySQL 3308 | 5.6.27 | GCC* | Innodb | Disable |
MySQL 3318 | 5.6.27 | Intel® C++ Compiler | Innodb | Disable |
Performance Testing Results
QPS
The results of the Sysbench TPS test on MySQL compiled with the Intel and GNU compilers are shown in Table 4 and Figure 3. The number of threads and the MySQL buffer_pool size were varied. Across the board, MySQL compiled with the Intel compiler gives significantly higher QPS, especially as the number of threads increases. We see a 5% to 35% improvement in QPS for MySQL compiled with the Intel C++ Compiler (Figure 3).
Threads | GCC_2GB | ICC_2GB | GCC_8GB | ICC_8GB | GCC_16GB | ICC_16GB |
---|---|---|---|---|---|---|
4 | 1036.64 | 1184.88 | 1406.89 | 1598.23 | 1402.00 | 1592.23 |
8 | 1863.62 | 2154.04 | 2556.77 | 2882.07 | 2541.71 | 2856.27 |
16 | 3394.35 | 4013.79 | 4949.17 | 5444.82 | 4915.52 | 5468.59 |
32 | 5639.77 | 6625.03 | 9036.91 | 9599.00 | 9034.98 | 9570.54 |
64 | 6975.84 | 9510.31 | 12796.34 | 14680.04 | 12839.79 | 14662.85 |
128 | 6975.05 | 9465.03 | 12410.70 | 14804.35 | 12391.96 | 14744.11 |
256 | 6859.37 | 9367.19 | 11586.47 | 14083.09 | 11574.40 | 13887.13 |
512 | 6769.54 | 9260.24 | 10904.25 | 12290.89 | 10893.18 | 12310.28 |
Average Response Time
The results of the Sysbench average response time (RT) test on MySQL compiled with the Intel and GNU compilers are shown in Table 5 and Figure 4. RT is in milliseconds. The number of threads and the MySQL buffer_pool size were varied as in the QPS test. Once again, MySQL compiled with the Intel compiler gives superior performance, especially at higher numbers of threads.
Threads | GCC_2GB | ICC_2GB | GCC_8GB | ICC_8GB | GCC_16GB | ICC_16GB |
---|---|---|---|---|---|---|
4 | 3.86 | 3.38 | 2.84 | 2.50 | 2.85 | 2.51 |
8 | 4.29 | 3.71 | 3.13 | 2.77 | 3.15 | 2.80 |
16 | 4.71 | 3.98 | 3.23 | 2.94 | 3.25 | 2.93 |
32 | 5.67 | 4.83 | 3.54 | 3.33 | 3.54 | 3.34 |
64 | 9.17 | 6.73 | 5.00 | 4.36 | 4.98 | 4.36 |
128 | 18.35 | 13.52 | 10.31 | 8.64 | 10.33 | 8.68 |
256 | 37.32 | 27.33 | 22.09 | 18.18 | 22.12 | 18.45 |
512 | 75.63 | 55.29 | 46.95 | 41.65 | 47.00 | 41.59 |
Conclusions
Maximizing MySQL performance is essential for DBAs, operators, and developers trying to reach a performance goal. This study demonstrates that compiling MySQL with the Intel C++ Compiler can significantly improve database performance. We found that the Intel C++ Compiler improved performance by 5% to 35%, with an average improvement of about 15%.
There are many factors that affect MySQL performance, including the MySQL configuration, the CPU, and the SSD. For example, we used the Intel® Xeon processor E5-2620 V3, but upgrading to V4 should improve performance even further. Using a faster SSD, such as the Intel® DC P3700 instead of the Intel® DC S3510 used in this article should also further improve performance.
References
- Intel® Media Server Studio Support
- MySQL* NDB Cluster 7.3–7.4 Reference Guide
- CMake Reference Documentation
Software and workloads used in performance tests may have been optimized for performance only on Intel microprocessors. Performance tests, such as SYSmark and MobileMark, are measured using specific computer systems, components, software, operations and functions. Any change to any of those factors may cause the results to vary. You should consult other information and performance tests to assist you in fully evaluating your contemplated purchases, including the performance of that product when combined with other products. For more complete information visit http://www.intel.com/performance.
Intel’s compilers may or may not optimize to the same degree for non-Intel microprocessors for optimizations that are not unique to Intel microprocessors. These optimizations include SSE2, SSE3, and SSSE3 instruction sets and other optimizations. Intel does not guarantee the availability, functionality, or effectiveness of any optimization on microprocessors not manufactured by Intel. Microprocessor-dependent optimizations in this product are intended for use with Intel microprocessors. Certain optimizations not specific to Intel microarchitecture are reserved for Intel microprocessors. Please refer to the applicable product User and Reference Guides for more information regarding the specific instruction sets covered by this notice.