mysql读写分离(四)---补充常用配置



[client]
default-character-set = utf8mb4    //支持表情特殊符号


[mysql]
default-character-set = utf8mb4     //支持表情特殊符号


[mysqld]
character-set-client-handshake = FALSE
character-set-server = utf8mb4                      //支持表情特殊符号
max_connections =3000           //最大支持16000,一般设置成3000
datadir=/home/mysql/data     //数据存储的目录
read-only = ON                 //这项功能只对非管理员组以为的用户有效
auto_increment_offset = 1 
auto_increment_increment = 2 
//这样A的auto_increment字段产生的数值是:1, 3, 5, 7, …等奇数ID了
port=3306
/*
Mysql有两种连接方式:
(1),TCP/IP
(2),socket
对mysql.sock来说,其作用是程序与mysqlserver处于同一台机器,发起本地连接时可用。
例如你无须定义连接host的具体IP得,只要为空或localhost就可以。
在此种情况下,即使你改变mysql的外部port也是一样可能正常连接。
因为你在my.ini中或my.cnf中改变端口后,mysql.sock是随每一次 mysql server启动生成的。已经根据你在更改完my.cnf后重启mysql时重新生成了一次,信息已跟着变更。

那么对于外部连接,必须是要变更port才能连接的

*/
socket=/home/mysql/mysql.sock         
/*
mysqld程序在启动后将在给定UNIX/Linux账户下执行; mysqld必须从root账户启动才能在启动后切换到另一个账户下执行; mysqld_safe脚本将默认使用--user=mysql选项来启动mysqld程序。
*/
user=mysql

pid-file=/home/mysql/mysql.pid    #mysql的进程id
server-id=2  #服务器 ID,注意服务器 ID 不能重复,一般用机器得ip
replicate-do-db=shantoo   #需要做复制的数据库名,如果复制多个数据库,重复设置这个选项即可
replicate-do-db=boluofan
replicate-do-db=blf_bops


slave-skip-errors=1032,1062,126,1114,1146,1048,1396  #自动跳过的错误code
read-only # slave can only read.
symbolic-links=0    //禁止 数据库或表可以存储在my.cnf中指定datadir之外的分区或目录
slow-query-log-file = /home/mysql/logs/slow_query.log
slow-query-log = 1
long_query_time =1
back_log = 600   
#在MYSQL暂时停止响应新请求之前,短时间内的多少个请求可以被存在堆栈中。如果系统在短时间内有很多连接,则需要增大该参数的值,该参数值指定到来的TCP/IP连接的监听队列的大小。默认值50

max_connect_errors = 6000   
#设置每个主机的连接请求异常中断的最大次数,当超过该次数,MYSQL服务器将禁止host的连接请求,直到mysql服务器重启或通过flush hosts命令清空此host的相关信息。

expire-logs-days=7  #只保留 7 天的二进制日志,以防磁盘被日志占满
binlog_format=MIXED  #设置 binlog 的格式为 MIXED
log-bin = /data/3306/mysql-bin
binlog_cache_size = 4M
max_binlog_cache_size = 8M
max_binlog_size = 512M

key_buffer_size = 2048M 
#批定用于索引的缓冲区大小,增加它可以得到更好的索引处理性能,对于内存在4GB左右的服务器来说,该参数可设置为256MB或384MB。

bulk_insert_buffer_size = 64M   
#批量插入数据缓存大小,可以有效提高插入效率,默认为8M

innodb_buffer_pool_size = 2048M   
# 这对Innodb表来说非常重要。Innodb相比MyISAM表对缓冲更为敏感。MyISAM可以在默认的 key_buffer_size 设置下运行的可以,然而Innodb在默认的 innodb_buffer_pool_size 设置下却跟蜗牛似的。由于Innodb把数据和索引都缓存起来,无需留给操作系统太多的内存,因此如果只需要用Innodb的话则可以设置它高达 70-80% 的可用内存。一些应用于 key_buffer 的规则有 — 如果你的数据量不大,并且不会暴增,那么无需把 innodb_buffer_pool_size 设置的太大了,不要超过2g

innodb_data_file_path = ibdata1:1024M:autoextend   
#表空间文件 重要数据

innodb_thread_concurrency = 8   
#服务器有几个CPU就设置为几,建议用默认设置,一般为8

innodb_flush_log_at_trx_commit = 2   
# 如果将此参数设置为1,将在每次提交事务后将日志写入磁盘。为提供性能,可以设置为0或2,但要承担在发生故障时丢失数据的风险。设置为0表示事务日志写入日志文件,而日志文件每秒刷新到磁盘一次。设置为2表示事务日志将在提交时写入日志,但日志文件每次刷新到磁盘一次。

innodb_max_dirty_pages_pct = 90   
#推荐阅读 http://www.taobaodba.com/html/221_innodb_max_dirty_pages_pct_checkpoint.html
# Buffer_Pool中Dirty_Page所占的数量,直接影响InnoDB的关闭时间。参数innodb_max_dirty_pages_pct 可以直接控制了Dirty_Page在Buffer_Pool中所占的比率,而且幸运的是innodb_max_dirty_pages_pct是可以动态改变的。所以,在关闭InnoDB之前先将innodb_max_dirty_pages_pct调小,强制数据块Flush一段时间,则能够大大缩短 MySQL关闭的时间。

innodb_lock_wait_timeout = 120   
# InnoDB 有其内置的死锁检测机制,能导致未完成的事务回滚。但是,如果结合InnoDB使用MyISAM的lock tables 语句或第三方事务引擎,则InnoDB无法识别死锁。为消除这种可能性,可以将innodb_lock_wait_timeout设置为一个整数值,指示 MySQL在允许其他事务修改那些最终受事务回滚的数据之前要等待多长时间(秒数)




[mysqld_safe]
log-error=/home/mysql/logs/error.log






参考资料:



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值