mysql 5.6安装;

1、安装必要的插件依赖

# yum install –y autoconf automake imake libxml2-devel expat-devel cmake gcc gcc-c++ libaio libaio-devel bzr bison libtool ncurses5-devel


2、解压mysql

# tar zxvf mysql-5.6.14-linux-glibc2.5-x86_64.tar.gz –C /usr/local/src/

# cd /usr/local/

创建软连接;

# ln -s mysql-5.6.14-linux-glibc2.5-x86_64 mysql


3、创建Mysql用户组和用户,及数据库存放目录,并设置权限;

# groupadd mysql

# useradd mysql -g mysql -M -s /sbin/nologin

# mkdir -p /data/mysql_data

# mkdir -p /data/mysql_log

# mkdir -p /data/log-bin

# chown -R mysql.mysql /data/mysql_data /data/mysql_log /data/log-bin

# chown -R mysql.mysql /usr/local/mysql-5.6.14-linux-glibc2.5-x86_64


4、mysql 配置文件参考 (网上参考)

# vi /etc/my.cnf

[mysqld]

user = mysql

default-storage-engine = InnoDB

socket = /data/mysql_data/mysql.sock

// *** 可以不设置 会默认到/ tmp/mysql.sock  免得启动报错;

pid-file = /data/mysql_data/mysql.pid

port = 3306

# MyISAM #

key_buffer_size = 1344M

myisam_recover = FORCE,BACKUP

# SAFETY #

max_allowed_packet = 16M

max_connect_errors = 1000000

skip_name_resolve

# DATA STORAGE #

datadir = /data/mysql_data/

long_query_time = 1

# BINARY LOGGING #

log-bin = /data/log-bin/mysql-bin-3306

expire-logs-days = 14

sync-binlog = 1

server-id = 1

max_binlog_size = 500M

# REPLICATION #

relay-log = /data/log-bin/relay-bin-3306

slave-net-timeout = 60

# CACHES AND LIMITS #

tmp_table_size = 32M

max_heap_table_size = 32M

max_connections = 500

thread_cache_size = 50

open_files_limit = 65535

table_definition_cache = 4096

table_open_cache = 4096

# INNODB #

innodb_data_file_path = ibdata1:128M;ibdata2:10M:autoextend

innodb_flush_method = O_DIRECT

innodb_log_files_in_group = 2

innodb_lock_wait_timeout = 50

innodb_log_file_size = 256M

innodb_flush_log_at_trx_commit = 1

innodb_file_per_table = 1

innodb_thread_concurrency = 8

innodb_buffer_pool_size = 8G

# LOGGING #

log-error = /data/mysql_log/mysql-error-3306.log

log-queries-not-using-indexes = 1

slow-query-log = 1

long_query_time = 1

slow-query-log-file = /data/mysql_log/mysql-slow-3306.log

# FOR SLAVE #

#binlog-format = ROW

#log-slave-updates = true

#gtid-mode = on

#enforce-gtid-consistency = true

#master-info-repository = TABLE

#relay-log-info-repository = TABLE

#sync-master-info = 1

#slave-parallel-workers = 2

#binlog-checksum = CRC32

#master-verify-checksum = 1

#slave-sql-verify-checksum = 1

#binlog-rows-query-log_events = 1

#report-port = 3306

#report-host = 0.0.0.0


5、 设置启动服务

# cp -rf /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

# vi /etc/init.d/mysqld

// ** 设置mysql 数据存放路径和启动数据

    basedir=/usr/local/mysql

    datadir=/data/mysql_data


6、初始化数据库

# cd /usr/local/mysql

# ./scripts/mysql_install_db --user=mysql --defaults-file=/etc/my.cnf


7、添加权限设置 设置开启自启;

# chmod 755 /etc/init.d/mysqld

# service mysqld start

# chkconfig --add mysqld

# chkconfig --level 345 mysqld on


8、设置密码

/usr/local/mysql/bin/mysqladmin  -uroot -p password 'password'


//** 设置mysql 开启远程远程;

mysql> GRANT ALL PRIVILEGES ON *.* TO root@"%" IDENTIFIED BY "password";

mysql> flush privileges;


//** 显示MYSQL的版本

mysql> select version(); 


//** 显示当前时间

mysql> select now(); 


//** 显示年月日

SELECT DAYOFMONTH(CURRENT_DATE); 

SELECT MONTH(CURRENT_DATE); 

SELECT YEAR(CURRENT_DATE); 


//** 显示字符串

mysql> SELECT "hell world!";  


//** 当计算器用

select ((4 * 4) / 10 ) + 25; 


//** 串接字符串

select CONCAT(f_name, " ", l_name) 

AS Name 

from employee_data 

where title = 'Marketing Executive'; 

+---------------+ 

| Name          | 

+---------------+ 

| Monica Sehgal | 

| Hal Simlai    | 

| Joseph Irvine | 

+---------------+ 

3 rows in set (0.00 sec) 



Mysql 优化示例;


1、修改全站搜索   

修改my.ini(my.cnf) ,在 [mysqld] 后面加入一行“ft_min_word_len=1”,然后 重启Mysql,再登录网站后台(模块管理->全站搜索)重建全文索引。   


2、记录慢查询sql语句,修改my.ini(my.cnf),添加如下代码:   

#log-slow-queries   

long_query_time = 1 #是指 执行超过多久的 sql 会被 log 下来   

#log-slow-queries = /var /youpath/slow.log linux下     host_name-slow.log   

log-queries-not-using-indexes    


3、mysql缓存的设置   

mysql>show variables like '%query_cache%';     mysql 本身是有对sql语句缓存的机制的,合理设置我们的mysql缓存可以降低数据库的io资源。   

#query_cache_type= 查 询缓存的方式(默认是 ON)   

query_cache_size 如果你希望禁用查询缓存,设置 query_cache_size=0。禁用了查 询缓存,将没有明显的开销   

query_cache_limit 不缓存大于这个值的结果。(缺省为 1M)    

查询缓存的统计信息   

mysql> SHOW STATUS LIKE ‘qcache%’;   

Qcache_free_blocks 缓存中相邻内存块的个数。数目大说明可能有碎片。FLUSH QUERY CACHE 会对 缓存中的碎片进行整理,从而得到一个空闲块。   

Qcache_free_memory 缓存中的空闲内存。   

Qcache_hits 每次查询在缓存中命中时就增大。   

Qcache_inserts 每次插入一个查询时就增大。命中次数除以插入次数就是不中比率;用 1 减去这个值就是命中率。在上 面这个例子中,大约有 87% 的查询都在缓存中命中。   

Qcache_lowmem_prunes 缓存出现内存不足并且必须要进行清理以便为更多查询提供空间的次数。这个数字最好长时间 来看;如果这个数字在不断增长,就表示可能碎片非常严重,或者内存很少。(上面的 free_blocks 和 free_memory 可以告诉您属于 哪种情况)。   

Qcache_not_cached 不适合进行缓存的查询的数量,通常是由于这些查询不是 SELECT 语句。   

Qcache_queries_in_cache 当前缓存的查询(和响应)的数量。   

Qcache_total_blocks 缓存中块的数量。通常,间隔几秒显示这些变量就可以看出区别,这可以帮助确定缓存是否正在 有效地使用。运行 FLUSH STATUS 可以重置一些计数器,如果服务器已经运行了一段时间,这会非常有帮助。   

  

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控制台执行以下命令观察:   

# > SHOW VARIABLES LIKE '%query_cache%';   

# > SHOW STATUS LIKE 'Qcache%';   

# 如果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数据库服务器则不要开 启该选项!否则将无法正常连接