centos6.5安装mysql5.6.17

#安装依赖包
yum -y install make gcc-c++ cmake bison-devel  ncurses-devel
#(不然yum不支持使用zlib*里的*号)
yum update 
yum -y install  gcc gcc-c++ gcc-g77 autoconf automake zlib* fiex* libxml* ncurses-devel libmcrypt* libtool-ltdl-devel* make cmake
#下载源码
wget http://dev.mysql.com/get/Downloads/MySQL-5.6/mysql-5.6.17.tar.gz
#添加mysql用户
groupadd mysql
useradd -g mysql mysql
#解压
tar zxvf mysql-5.6.17.tar.gz 
cd mysql-5.6.17
#编译
cmake \
-DCMAKE_INSTALl_PREFIX=/usr/local/mysql \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DSYSCONFDIR=/usr/local/mysql/etc \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_MEMORY_STORAGE_ENGINE=1 \
-DWITH_READLINE=1 \
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock \
-DMYSQL_TCP_PORT=3306 \
-DENABLED_LOCAL_INFILE=1 \
-DEXTRA_CHARSETS=all \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DENABLE_DOWNLOADS=1

#发现报错信息
#Warning: Bison executable not found in PATH
#CMake Error: Problem with tar_extract_all(): Invalid argument
CMake Error: Problem with tar_extract_all(): Invalid argument
CMake Error: Problem extracting tar: /soft/mysql-5.6.17/source_downloads/gmock-1.6.0.zip
报错的大概原因是tar解包gmock-1.6.0.zip出错了。
cmake的时候,怎么能用tar去解包zip压缩包呢?!gmock-1.6.0.zip是google的c++mock框架,从mysql 5.6开始支持。
cmake参数中设置了DENABLE_DOWNLOADS=1且服务器能连接Internet的话,就会自动下载。
上面报错信息可知,cmake时gmock-1.6.0.zip自动下载到了/soft/mysql-5.6.17/source_downloads/目录下。

#解决办法
yum -y install bison unzip
#手动编译安装gmock,然后再cmake:
cd /soft/mysql-5.6.17/source_downloads/
unzip gmock-1.6.0.zip
cd gmock-1.6.0
./configure
make
#当然,个人觉得这个报错关系不大,可忽略之。
#尤其是MySQL服务器在内网无法联接到互联网网的情况,是无法下载gmock-1.6.0.zip,也不会报错上面的CMake Error报错
#解决完毕

#重新编译mysql后发现没有问题
#编译参数可以参考http://dev.mysql.com/doc/refman/5.5/en/source-configuration-options.html
#安装
make
make install
#到此mysql安装完毕

#修改/usr/local/mysql权限
chown -R mysql:mysql /usr/local/mysql
#进入安装路径
cd /usr/local/mysql
#初始化mysql数据库
scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/3306/data --user=mysql

WARNING: Default config file /etc/my.cnf exists on the system
This file will be read by default by the MySQL server
If you do not want to use this, either remove it, or use the
--defaults-file argument to mysqld_safe when starting the server
注:在启动MySQL服务时,会按照一定次序搜索my.cnf,先在/etc目录下找,找不到则会搜索"$basedir/my.cnf",在本例中就是 /usr/local/mysql/my.cnf,这是新版MySQL的配置文件的默认位置!注意:在CentOS 6.4版操作系统的最小安装完成后,在/etc目录下会存在一个my.cnf,需要将此文件更名为其他的名字,如:/etc/my.cnf.bak,否则,该文件会干扰源码安装的MySQL的正确配置,造成无法启动。
或者使用--defaults-file参数指定配置文件

#添加服务,拷贝服务脚本到init.d目录,并设置开机启动
cp support-files/mysql.server /etc/init.d/mysql
chkconfig mysql on

mkdir -p /usr/local/mysql/3306/binlog/
mkdir -p /usr/local/mysql/3306/relaylog/
chown -R mysql:mysql /usr/local/mysql/3306

#编辑/usr/local/mysql/my.cnf
vi /usr/local/mysql/my.cnf

#输入
[client]
character-set-server = utf8
port    = 3306
socket  = /tmp/mysql.sock

[mysqld]
character-set-server = utf8
replicate-ignore-db = mysql
replicate-ignore-db = test
replicate-ignore-db = information_schema

user    = mysql
port    = 3306
socket  = /tmp/mysql.sock
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
log-error = /usr/local/mysql/3306/mysql_error.log
pid-file = /usr/local/mysql/3306/mysql.pid

open_files_limit    = 10240
back_log = 600
max_connections = 5000
max_connect_errors = 6000
#table_cache = 614
external-locking = FALSE
max_allowed_packet = 32M
sort_buffer_size = 1M
join_buffer_size = 1M
thread_cache_size = 300
#thread_concurrency = 8
query_cache_size = 512M
query_cache_limit = 2M
query_cache_min_res_unit = 2k
default-storage-engine = MyISAM
thread_stack = 192K
transaction_isolation = READ-COMMITTED
tmp_table_size = 246M
max_heap_table_size = 246M
long_query_time = 3
log-slave-updates
log-bin = /usr/local/mysql/3306/binlog/binlog
binlog_cache_size = 4M
binlog_format = MIXED
max_binlog_cache_size = 8M
max_binlog_size = 1G
relay-log-index =/usr/local/mysql/3306/relaylog/relaylog
relay-log-info-file = /usr/local/mysql/3306/relaylog/relaylog
relay-log = /usr/local/mysql/3306/relaylog/relaylog
expire_logs_days = 30
key_buffer_size = 256M
read_buffer_size = 1M
read_rnd_buffer_size = 16M
bulk_insert_buffer_size = 64M
myisam_sort_buffer_size = 128M
myisam_max_sort_file_size = 10G
myisam_repair_threads = 1
myisam_recover

interactive_timeout = 120
wait_timeout = 120

skip-name-resolve
#master-connect-retry = 10
slave-skip-errors = 1032,1062,126,1114,1146,1048,1396

#master-host     =   192.168.1.2
#master-user     =   username
#master-password =   password
#master-port     =  3306

server-id = 1

innodb_additional_mem_pool_size = 16M
innodb_buffer_pool_size = 512M
innodb_data_file_path = ibdata1:12M:autoextend
innodb_file_io_threads = 4
innodb_thread_concurrency = 8
innodb_flush_log_at_trx_commit = 2
innodb_log_buffer_size = 16M
innodb_log_file_size = 128M
innodb_log_files_in_group = 3
innodb_max_dirty_pages_pct = 90
innodb_lock_wait_timeout = 120
innodb_file_per_table = 0

#log-slow-queries = /usr/local/mysql/3306/slow.log
#long_query_time = 10

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

[mysqldump]
quick
max_allowed_packet = 32M

#启动mysql
service mysql start

#发现报错,查看错误日志
[ERROR] InnoDB: auto-extending data file ./ibdata1 is of a different size 768 pages (rounded down to MB) than specified in the .cnf file: initial 16384 pages, max 0 (relevant if non-zero) pages!
因为没有修改数据文件的配置,这里发现数据文件大小校验失败了。
从这里看见,需要恢复的数据文件有3200页,通过查询mysql文档innodb也结构,可以知道现在mysql innodb每个页的大小是固定的,均为16k,这里的3200页,折算下:768 * 16 / 1024 = 12M
因此,修改mysql的my.cnf为:
innodb_data_file_path = ibdata1:12M:autoextend

#又发现错误[ERROR] /usr/local/mysql/bin/mysqld: unknown variable 'table_cache=614'
原来已经没有这个参数了,注释这行

到此mysql终于启动了~!

这里总结要学会通过错误日志分析结果,动态计算mysql的innerdb的文件大小,即使更新配置文件。

#添加环境变量
[root@kudo mysql]# PATH=/usr/local/mysql/bin:$PATH
[root@kudo mysql]# export PATH
[root@kudo mysql]# source /etc/profile

通过命令行登录管理MySQL服务器(提示输入密码时直接回车):
mysql -u root -p -S /tmp/mysql.sock

输入以下SQL语句,创建一个具有root权限的用户(root)和密码(centos):
GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' IDENTIFIED BY 'centos';
GRANT ALL PRIVILEGES ON *.* TO 'root'@'127.0.0.1' IDENTIFIED BY 'centos';

GRANT ALL PRIVILEGES ON *.* TO 'mysql'@'%' IDENTIFIED BY 'mysql';
flush privileges
停止MySQL:

service mysql stop

#添加防火墙规则运行远程访问
iptables -A INPUT -p tcp -m state --state NEW -m tcp --dport 3306 -j ACCEPT service iptables save service iptables restart
 注意: 
-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT
-A RH-Firewall-1-INPUT -j REJECT --reject-with icmp-host-prohibited

-A   RH-Firewall-1-INPUT   -j   REJECT   --reject-with   icmp-host-prohibited 
是拒绝icmp访问,对于其它的报文返回一个主机禁止访问的错误


开通3306 端口的行必须在icmp-host-prohibited前

 



posted on 2014-05-12 15:12  kudosharry  阅读(1115)  评论(0编辑  收藏  举报

导航