집 >데이터 베이스 >MySQL 튜토리얼 >MySQL 4G 메모리 서버 구성 최적화에 대한 자세한 설명
회사 웹사이트의 방문 횟수가 증가하고 있으며(일일 100,000PV 이상) MySQL은 자연스럽게 병목 현상이 되었습니다. MySQL 최적화와 관련하여 가장 기본적인 것은 MySQL 시스템 매개변수의 최적화입니다. MySQL은 웹 아키텍처의 성능에 가장 큰 영향을 미치며 핵심적인 부분이기도 합니다. MySQL 자체(my.cnf)의 최적화를 포함하여 MySQL 최적화의 기본 사항 중 일부를 살펴보겠습니다.
MySQL은 웹 아키텍처의 성능에 가장 큰 영향을 미치며 핵심적인 부분이기도 합니다. MySQL 설정이 합리적으로 최적화되었는지 여부는 웹 속도와 로드 용량에 직접적인 영향을 미칩니다! 동시에 MySQL은 최적화하기 가장 어려운 부분이기도 합니다. MySQL 전문 지식을 이해해야 할 뿐만 아니라, 통계를 장기간 관찰하고 경험을 바탕으로 판단한 후 합리적인 매개변수를 설정해야 합니다. MySQL 자체(my.cnf)의 최적화를 포함하여 MySQL 최적화의 기본 사항 중 일부를 살펴보겠습니다.
성능에 더 큰 영향을 미치는 몇 가지 매개변수를 소개합니다. my.cnf 파일의 최적화 설정은 서버 하드웨어 구성과 밀접하게 관련되어 있으므로 일반적인 2U 서버 하드웨어 환경을 지정합니다. CPU: 2 Intel Xeon 2.4GHz 메모리: 4GB DDR 하드 디스크: SCSI.
아래에서는 최적화된 my.cnf와 결합된 위의 하드웨어 구성을 기반으로 설명합니다.
[mysqld] port = 3306 serverid = 1 socket = /tmp/mysql.sock skip-locking #避免MySQL的外部锁定,减少出错几率增强稳定性。 skip-name-resolve #禁止MySQL对外部连接进行DNS解析,使用这一选项可以消除MySQL进行DNS解析的时间。但需要注意,如果开启该选项,则所有远程主机连接授权都要使用IP地址方式,否则MySQL将无法正常处理连接请求! back_log = 384 #back_log参数的值指出在MySQL暂时停止响应新请求之前的短时间内多少个请求可以被存在堆栈中。 如果系统在一个短时间内有很多连接,则需要增大该参数的值,该参数值指定到来的TCP/IP连接的侦听队列的大小。不同的操作系统在这个队列大小上有它自己的限制。 试图设定back_log高于你的操作系统的限制将是无效的。默认值为50。对于Linux系统推荐设置为小于512的整数。 key_buffer_size = 256M #key_buffer_size指定用于索引的缓冲区大小,增加它可得到更好的索引处理性能。对于内存在4GB左右的服务器该参数可设置为256M或384M。注意:该参数值设置的过大反而会是服务器整体效率降低! max_allowed_packet = 4M thread_stack = 256K table_cache = 128K sort_buffer_size = 6M #查询排序时所能使用的缓冲区大小。注意:该参数对应的分配内存是每连接独占,如果有100个连接,那么实际分配的总共排序缓冲区大小为100 × 6 = 600MB。所以,对于内存在4GB左右的服务器推荐设置为6-8M。 read_buffer_size = 4M #读查询操作所能使用的缓冲区大小。和sort_buffer_size一样,该参数对应的分配内存也是每连接独享。 join_buffer_size = 8M #联合查询操作所能使用的缓冲区大小,和sort_buffer_size一样,该参数对应的分配内存也是每连接独享。 myisam_sort_buffer_size = 64M table_cache = 512 thread_cache_size = 64 query_cache_size = 64M #指定MySQL查询缓冲区的大小。可以通过在MySQL控制台观察,如果Qcache_lowmem_prunes的值非常大,则表明经常出现缓冲不够的情况;如果Qcache_hits的值非常大,则表明查询缓冲使用非常频繁,如果该值较小反而会影响效率,那么可以考虑不用查询缓冲;Qcache_free_blocks,如果该值非常大,则表明缓冲区中碎片很多。 tmp_table_size = 256M max_connections = 768 #指定MySQL允许的最大连接进程数。如果在访问论坛时经常出现Too Many Connections的错误提 示,则需要增大该参数值。 max_connect_errors = 10000000 wait_timeout = 10 #指定一个请求的最大连接时间,对于4GB左右内存的服务器可以设置为5-10。 thread_concurrency = 8 #该参数取值为服务器逻辑CPU数量*2,在本例中,服务器有2颗物理CPU,而每颗物理CPU又支持H.T超线程,所以实际取值为4*2=8 skip-networking #开启该选项可以彻底关闭MySQL的TCP/IP连接方式,如果WEB服务器是以远程连接的方式访问MySQL数据库服务器则不要开启该选项!否则将无法正常连接! table_cache=1024 #物理内存越大,设置就越大.默认为2402,调到512-1024最佳 innodb_additional_mem_pool_size=4M #默认为2M innodb_flush_log_at_trx_commit=1 #设置为0就是等到innodb_log_buffer_size列队满后再统一储存,默认为1 innodb_log_buffer_size=2M #默认为1M innodb_thread_concurrency=8 #你的服务器CPU有几个就设置为几,建议用默认一般为8 key_buffer_size=256M #默认为218,调到128最佳 tmp_table_size=64M #默认为16M,调到64-256最挂 read_buffer_size=4M #默认为64K read_rnd_buffer_size=16M #默认为256K sort_buffer_size=32M #默认为256K thread_cache_size=120 #默认为60 query_cache_size=32M
참고:
1 Key_reads가 너무 크면 my.cnf에서 Key_buffer_size를 늘리고 Key_reads/ Key_read_requests를 유지해야 합니다. 최소 1/100이어야 하며, 작을수록 좋습니다.
2. Qcache_lowmem_prunes가 매우 큰 경우 Query_cache_size 값을 늘려야 합니다.
관련 권장 사항:
Linux에서 메모리 통계 및 메모리 누수를 확인하는 방법
위 내용은 MySQL 4G 메모리 서버 구성 최적화에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!