zoukankan      html  css  js  c++  java
  • Notes on <High Performance MySQL> Ch7: Operating System and Hardware Optimization

     

    What Limits MySQL’s Performance?

    CPU saturation happens when MySQL works with data that either fits in memory or can be read from disk as fast as needed.

    I/O saturation, on the other hand, generally happens when you need to work with much more data than you can fit in memory.


    How to Select CPUs for MySQL

    You can identify a CPU-bound workload by checking the CPU utilization, but instead of looking only at how heavily your CPUs are loaded overall, try to look at the balance of CPU usage and I/O for your most important queries, and notice whether the CPUs are loaded evenly.

    You can use tools such as mpstat, iostat, and vmstat.

    Which Is Better: Fast CPUs or Many CPUs?

    When you have a CPU-bound workload, MySQL generally benefits most from faster CPUs.

    MySQL’s current architecture has scaling issues with multiple CPUs, and MySQL cannot run a single query in parallel across many CPUs.

    Broadly speaking, there are two types of performance you might desire:

    -          Low latency (fast response time)

    -          High throughput

    MySQL replication also works best with fast CPUs, not many CPUs.  The I/O subsystem, not the CPU, is usually the bottleneck on a slave.

    CPU Architecture

    It’s a good idea to choose a 64-bit architecture for all new hardware you purchase.

    Scaling to Many CPUs and Cores

    One place where multiple CPUs can be quite helpful is an OLTP system.

    There are actually two types of concurrency problems in database, and you need different approaches to solve them:

    -          Logical concurrency issues

    Contention for resources that are visible to the application, such as table or row locks.

    -          Internal concurrency issues

    Contention for resources such as semaphores, access to pages in the InnoDB buffer pool, and so on. You can try to work around these problems by changing server settings, changing your OS, or using different hardware.

    The CPU architecture (RISC, CISC, depth of pipeline, etc.), CPU model, and OS all affect MySQL’s scaling pattern.

    Some systems can even give lower total performance with more processors.

    Balancing Memory and Disk Resources

    Random Versus Sequential I/O

    Database servers use both sequential and random I/O, and random I/O benefits the most from caching.

    Another reason sequential reads don’t benefit much from caching is because they are faster than random reads.

    -          Sequential I/O is faster than random I/O

    Random accesses are some 2,500 times faster in memory than on disk, while sequential accesses are only 10 times faster in memory.

    -          Storage engines can perform sequential reads faster than random reads.

    Adding memory is the best solution for random-read I/O problems if you can afford it.

    Caching, Reads, and Writes

    Writes benefit greatly from buffering, because it converts random I/O into more sequential I/O. Asynchronous (buffered) writes are typically handled by the OS and are batched so they can be flushed to disk more optimally. Synchronous (unbuffered) writes have to be written to disk before they finish. That’s why they benefit from buffering in a RAID controller’s battery-backed write-back cache.

    What’s Your Working Set?

    The working set and the cache unit

    The working set contains both data and indexes, and you should count it in cache units. A cache unit is the smallest unit of data that the storage engine works with.

    The size of the cache unit varies between storage engines, and therefore so does the size of the working set. For example, InnoDB always works in pages of 16 KB.

    Finding an Effective Memory-to-Disk Ratio

    Choosing Hard Disks

    Choosing Hardware for a Slave

    If you’re planning to use a replication slave for failover, it usually needs to be at least as powerful as the master.

    RAID Performance Optimization

    RAID Failure, Recovery, and Monitoring

    Balancing Hardware RAID and Software RAID

    RAID Configuration and Caching

    The RAID stripe chunk size

    The RAID cache

    -          Caching reads

    -          Caching read-ahead data

    -          Caching writes

    -          Internal operations

    In general, the RAID controller’s memory is a scarce resource that you should try to use wisely. Using it for reads is usually a waste, but using it for writes is an important way to speed up your I/O performance.

    Storage Area Networks and Network-Attached Storage

    Storage area network (SANs) and network-attached storage (NAS) are two related, but very different, ways to attach external file storage devices to a server. A SAN exposes a block-level interface that a server sees as being directly attached, while a NAS device exposes a file-based protocol such as NFS or SMB. A SAN is usually connected to the server via the Fibre Channel Protocol (FCP) or iSCSI, while a NAS device is connected via a standard network connection.

    Storage Area Networks

    The benefits of using a SAN include more flexible storage management and the ability to scale storage.

    They permit a server to access a very large number of hard drives – often 50 or more—and typically have large, intelligent caches to buffer writes.

    The block-level interface they export appears to the server as logical unit numbers (LUNs), or virtual volumes. Many SANs also allow multiple nodes to be “clustered” to get better performance.

    SANs work well when you have a lot of concurrent requests and need high throughput.

    A SAN is still ultimately a collection of hard drives that can do only a limited number of I/O operations per second, and because a SAN is external to the server and does its own processing, it adds latency to each I/O requests. The extra latency makes SANs less efficient when you need very high performance for synchronous I/O, so keeping your transaction logs on a SAN is usually not as good as using a directly attached RAID controller.

    In general, directly attached storage is faster than the LUNs on a SAN with the same number of similar hard drives.

    SANs have one big disadvantage: their cost is typically much higher than the cost of comparable directly attached storage (especially internal storage).

    Most web application don’t use SANs, but they’re very populate for so-called enterprise applications. There are some reasons for this:

    -          Enterprise applications are usually less constrained by budget.

    -          Enterprises often run many applications, or many instances of a single application, and have unpredictable growth requirements. A SAN gives you the ability to buy a lot of storage, share it, and grow it on demand.

    -          A SAN’s large buffers can help absorb write spikes and provide fast access to “hot” data, and SANs typically balance load across a very large number of hard drives. All this is usually required for clustered applications that are vertically scaled, but it doesn’t help web applications much. Web applications usually don’t have periods of low activity followed by huge write spikes; most of them are writing a lot of data almost constantly, so buffering writes isn’t helpful. Read buffering isn’t needed either, because databases tend to have their own (large, smart) caches. And the most common and successful strategy for building a very large web application is to use application partitioning (sharding), so web applications are already balancing the load across a large number of hard drives.

    Network-Attached Storage

    A NAS device is essentially a stripped-down file server appliance, typically with a web interface instead of a physical mouse, monitor, and keyboard.

    NAS devices are not very fast, because they’re mounted over the network. They also have a long history of problems with synchronous I/O support and locking, so we don’t recommend then for general database storage.

    Using Multiple Disk Volumes

    -          Data and indexes files

    -          Transaction log files

    -          Binary log files

    -          General log files (e.g., for the error log, query log, and slow query log)

    -          Temporary files and tables

    A typical disk layout is to have the operating system, swap partition, and binary logs on a RAID 1 volume, and a separate RAID 5 or RAID 10 volume that holds everything else.

    Network Configuration

    It’s a good idea to monitor network performance and errors on all network ports. Monitor every port on servers, on routers, and on switches. The Multi Router Traffic Grapher (MRTG) is the tried-and-true solution for device monitoring. Other common tools for monitoring network performance are Smokeping and Cacti.

    Choosing an Operating System

    -          GNU/Linux

    -          Solaris

    -          FreeBSD

    -          Windows: typically used for development and when MySQL is used with desktop applications.

    Choosing a Filesystem

    When possible, it’s best to use a journaling filesystem, such as ext3, ReiserFS, XFS, ZFS, or JFS. If you don’t, a filesystem check after a crash can take a long time.

    Threading

    As of version 5.0, MySQL uses one thread per connection, plus housekeeping threads, special-purpose threads, and any threads the storage engine creates.

    GNU/Linux offers two thread libraries: LinuxThreads and the newer Native POSIX Threads Library (NPTL). NPTL is usually lighter and more efficient, and it doesn’t suffer from a lot problems LinuxThreads had.

    Swapping

    Swapping occurs when the OS writes some virtual memory to disk because it doesn’t have enough physical memory to hold it.

    Swapping is very bad for MySQL’s performance. It defeats the purpose of caching in memory, and it results in lower efficiency than using too little memory for the caches.

    On GNU/Linux, you can monitor swapping with vmstat.

    Operating System Status

    How to Read vmstat Output

    How to Read iostat Output

    A CPU-Bound Machine

    An  I/O-Bound Machine

    A Swapping Machine

    An Idle Machine

  • 相关阅读:
    通过 VB5 创建 ActiveX DLL 文件并用 ASP 调用一例
    Autocad VBA初级教程
    自学资料第一集
    Linux虚拟化:10个不得不爱的理由
    EXCEL VBA编程的一些小结
    FAQ 工作薄及工作表
    很重要的EXCEL使用技巧
    Excel VBA编程的常用代码
    VBA生成一个CorelDraw工具栏
    支付宝,网银在线,快钱 3大支付接口的集成与对比,统合实现
  • 原文地址:https://www.cnblogs.com/fangwenyu/p/2581419.html
Copyright © 2011-2022 走看看