`
tw5566
  • 浏览: 460541 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

Linux中对MySQL优化

 
阅读更多

要求: MySQL数据库管理与维护

1、熟悉Linux上安装、配置和优化MySQL数据库,

2、熟悉 Mysql的AB复制以及读写分离的实现,能完成添加从库,从库变主库等操作;

3精通mysql数据库的查询、子查询、插入、更新等操作,以及建数据库、表和索引;

4、掌握表的连接、视图,以为存储过程和函数的使用;

5能实现mysql数据库的备份和还原,对各种引擎进行优化

==================================================================================

1.优化MySQL数据库:

 

#vim /etc/my.cnf以下只列出my.cnf文件中[mysqld]段落中的内容,其他段落内容对MySQL运行性能影响甚微,因而姑且忽略。

[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 ManyConnections的错误提示,则需要增大该参数值
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 


值得注意的是:

很多情况需要具体情况具体分析

一、如果Key_reads太大,则应该把my.cnf中Key_buffer_size变大,保持Key_reads/Key_read_requests至少1/100以上,越小越好。
二、如果Qcache_lowmem_prunes很大,就要增加Query_cache_size的值。

From:http://blog.sina.com.cn/s/blog_701fdd650100oina.html

分享到:
评论

相关推荐

    Linux中对MySQL优化实例详解

    Linux中对MySQL优化实例详解 vim /etc/my.cnf以下只列出my.cnf文件中[mysqld]段落中的内容,其他段落内容对MySQL运行性能影响甚微,因而姑且忽略。 [mysqld] port = 3306 serverid = 1 socket = /tmp/mysql.sock ...

    linux一键安装mysql

    在Linux系统中,MySQL是一种广泛使用的开源关系型数据库管理系统,对于开发者和系统管理员来说,能够快速、方便地在Linux上安装MySQL是至关重要的。本文将详细介绍如何通过一个名为`install_mysql.sh`的脚本来实现...

    mysql-connector-java Linux下MySQL的JDBC驱动Jar包

    总结,"mysql-connector-java"是Java与MySQL数据库之间的重要桥梁,它为开发者提供了方便的接口,以便在Linux环境中进行数据库操作。了解并熟练掌握其安装、配置和使用,是开发Java数据库应用的基础。随着技术的发展...

    linux中安装mysql8.0安装包

    在Linux环境中安装MySQL 8.0是一个常见的任务,尤其对于那些需要搭建数据库服务器或进行开发工作的用户来说。MySQL 8.0是当前的稳定版本,提供了许多改进和新特性,如增强的安全性、性能优化以及更强大的数据管理...

    Linux中mysql的搭建和应用

    在Linux环境中,MySQL是一种广泛应用的关系型数据库管理系统,用于存储和管理各种类型的数据。本文将详细介绍在Linux上搭建MySQL服务器的过程,以及如何进行基本的操作,包括创建数据库、表、数据的增删改查、备份和...

    Linux下安装mysql

    在 Linux 系统中安装 MySQL 数据库是一项常见的任务,尤其是在搭建 Web 服务器或开发环境中。本文将详细介绍如何在 Linux 系统上安装 MySQL,并提供相关的配置和管理指南。 #### 准备工作 在安装 MySQL 之前,我们...

    linux_mysql.rar_c mysql linux_linux mysql_linux mysql_linux m

    总之,Linux下的数据库编程涉及了对MySQL服务器的管理和C语言接口的运用,这对于任何需要在Linux环境中处理数据的开发者来说都是不可或缺的技能。通过深入学习和实践,你将能够熟练地在Linux系统中使用MySQL数据库,...

    Linux下的MySQL调优

    此外,对MySQL进行编译优化,如采用静态编译,以及选择更高效的操作系统内核也有助于提高性能。 ##### 2. 系统设置 - **External-locking**:禁用文件系统外部锁,以避免与其他应用程序发生冲突。 - **Table_cache...

    MySQL 5.7 For Linux的部署及启动与排错

    部署MySQL 5.7 For Linux涉及文件系统的选择、安全配置以及性能优化等关键步骤。 首先,文件系统的兼容性对于MySQL的部署至关重要。在CentOS 6.5这样的Linux发行版中,常用的文件系统有XFS和ext4。在部署前,需要...

    mysql for linux

    以下是对MySQL在Linux环境下安装和使用的一些关键知识点的详细说明: 1. **Linux发行版兼容性**: MySQL可在众多Linux发行版上运行,如Ubuntu、CentOS、Red Hat Enterprise Linux (RHEL)、Debian等。不同发行版...

    Linux下的MySQL依赖包(所有perl).rar

    在Linux环境中,MySQL数据库系统是广泛使用的开源关系型数据库管理系统,尤其在服务器端应用中扮演着重要角色。为了确保MySQL在Linux上能够顺利运行,它依赖于一系列的库和工具,其中Perl语言的某些模块是MySQL安装...

    mysql 5.5.tar.gz linux版mysql5.55下载

    在日常使用中,对MySQL进行定期备份、监控性能、调整参数以及安全审计都是非常重要的维护工作。对于开发者来说,理解SQL语句的执行计划、掌握索引优化技巧、了解锁机制是提高数据库性能的关键。 总之,MySQL 5.5在...

    黑马程序员mysql在linux下的安装

    MySQL的性能优化包括配置文件调整、索引优化、查询优化等多个方面。例如,修改`my.cnf`配置文件,调整内存分配、缓存大小、查询缓存等参数。 总结,安装MySQL在Linux下是一个相对简单的过程,但需要理解每个步骤...

    Linux下Mysql的配置

    在Linux系统中安装MySQL可以通过RPM包进行。这里提供了一个示例命令: ```bash rpm -ivh MySQL-server-4.1.22-0.glibc23.i386.rpm --nodeps rpm -ivh MySQL-client-4.1.22-0.glibc23.i386.rpm --nodeps ``` 这两个...

Global site tag (gtag.js) - Google Analytics