最小化centos安装mysql5.6问题集锦

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

本文系统Centos6.0

其实一般本人安装自己使用的系统的时候都会安装软件工作站,然后进行更新所有包;安装其他软件的时候少了很多的依赖关系,少了很多麻烦;这里本人故意安装最小化的系统进行源码包安装mysql5.6;只为记录其中遇到的问题进行解决;

1、安装yum源;

1
[root@bogon ~]# rpm -vhi ftp: //ftp.univie.ac.at/systems/linux/fedora/epel/beta/6/i386/epel-release-6-5.noarch.rpm

2、安装编译环境:

1
[root@bogon ~]# yum install wget gcc* make -y


1
2
[root@bogon ~]# ls *gz
cmake- 2.8 . 11.2 .tar.gz  mysql- 5.6 . 12 .tar.gz

3、首先安装cmake

1
2
3
4
5
tar zxvf cmake- 2.8 . 11.2 .tar.gz
  cd cmake- 2.8 . 11.2
./bootstrap
make
make install

4、安装mysql

1
2
3
4
5
6
useradd -s /sbin/nologin mysql
mkdir /data
chown -R  mysql.mysql /data
tar zxvf mysql- 5.6 . 12 .tar.gz
cd mysql- 5.6 . 12
[root@bogon mysql- 5.6 . 12 ]# cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/data -DWITH_INNOBASE_STORAGE_ENGINE= 1  -DWITH_ARCHIVE_STORAGE_ENGINE= 1  -DWITH_BLACKHOLE_STORAGE_ENGINE= 1  -DWITH_READLINE= 1  -DWITH_SSL:STRING=bundled -DWITH_ZLIB:STRING=bundled -DWITH_LIBWARP= 0  -DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DEXTRA_CHARSETS=all

提示报错;

153047692.jpg

安装相关包

1
yum install openssl openssl-devel ncurses ncurses-devel -y

重新编译

1
2
3
4
5
6
7
8
rm -rf CMakeCache.txt
[root@bogon mysql- 5.6 . 12 ]# cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/data -DWITH_INNOBASE_STORAGE_ENGINE= 1  -DWITH_ARCHIVE_STORAGE_ENGINE= 1  -DWITH_BLACKHOLE_STORAGE_ENGINE= 1  -DWITH_READLINE= 1  -DWITH_SSL:STRING=bundled -DWITH_ZLIB:STRING=bundled -DWITH_LIBWARP= 0  -DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci
make
make install
  cp support-files/mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld
chkconfig --add mysqld
chkconfig mysqld on

5、调整lib库路径:将mysql的库文件路径:“/usr/local/mysql/lib/mysql” 加入带系统的库文件搜索路径中

1
2
[root@bogon mysql]# vim /etc/ld.so.conf.d/mysql.conf
/usr/local/mysql/lib

ldconfig      //刷新,使修改生效

6、设置mysql程序的执行路径:

1
2
3
[root@bogon mysql]# vim /etc/profile.d/mysql.sh
export PATH=$PATH:/usr/local/mysql/bin
[root@bogon mysql]# source /etc/profile

7、将mysql的man文档输入到系统手册;

1
2
3
yum install man
vim /etc/man.config
MANPATH /usr/local/mysql/man

8、输出mysql的头文件到系统头文件

1
ln -sv /usr/local/mysql/ include / /usr/ include /mysql

9、编辑my.cnf文件;然后进行初始化

1
2
3
4
5
6
7
8
9
10
11
12
13
14
[root@bogon mysql]# vim /etc/my.cnf
[mysqld]
datadir=/data
socket=/tmp/mysql.sock
user=mysql
server-id= 1
log-bin=mysql-bin
report-port= 3306
port= 3306
# Disabling symbolic-links  is  recommended to prevent assorted security risks
symbolic-links= 0
[mysqld_safe]
log-error=/ var /log/mysqld.log
pid-file=/ var /run/mysqld/mysqld.pid
1
/usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/data --user=mysql

000055967.jpg

至此安装完毕;下面说明相关编译参数:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql     #安装目录
-DMYSQL_DATADIR=/data                       #数据库存放目录
-DSYSCONFDIR=/etc                           #MySQL配辑文件
-DWITH_MYISAM_STORAGE_ENGINE= 1               #安装myisam存储引擎
-DWITH_INNOBASE_STORAGE_ENGINE= 1             #安装innodb存储引擎
-DWITH_ARCHIVE_STORAGE_ENGINE= 1              #安装archive存储引擎
-DWITH_BLACKHOLE_STORAGE_ENGINE= 1            #安装blackhole存储引擎
-DWITH_LOCAL_INFILE= 1                        #允许从本地导入数据
-DWITH_READLINE= 1                            #快捷键功能
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock           #Unix socket 文件路径
-DDEFAULT_CHARSET=utf8                      #默认字符
-DDEFAULT_COLLATION=utf8_general_ci         #校验字符
-DEXTRA_CHARSETS=all                        #安装所有扩展字符集
-DMYSQL_TCP_PORT= 3306                    
-DMYSQL_USER=mysql                          、
-DWITH_SSL=yes       
-DWITH_MEMORY_STORAGE_ENGINE= 1               #安装memory存储引擎
-DWITH_FEDERATED_STORAGE_ENGINE= 1            #安装frderated存储引擎

再下面是my.cnf的一些配置项:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
[client]
port =  3309
socket = /home/mysql/mysql/tmp/mysql.sock
[mysqld]
! include  /home/mysql/mysql/etc/mysqld.cnf #包含的配置文件 ,把用户名,密码文件单独存放
port =  3309
socket = /home/mysql/mysql/tmp/mysql.sock
pid-file = /usr/local/mysql/ var /mysql.pid
basedir = /home/mysql/mysql/
datadir = /usr/local/mysql/mysql/mysql/ var /
# tmp dir settings
tmpdir = /home/mysql/mysql/tmp/
slave-load-tmpdir = /home/mysql/mysql/tmp/
#当slave 执行 load data infile 时用
#language = /home/mysql/mysql/share/mysql/english/
character-sets-dir = /home/mysql/mysql/share/mysql/charsets/
# skip options
skip-name-resolve #grant 时,必须使用ip不能使用主机名
skip-symbolic-links #不能使用连接文件
skip-external-locking #不使用系统锁定,要使用myisamchk,必须关闭服务器
skip-slave-start #启动mysql,不启动复制
#sysdate- is -now
# res settings
back_log =  50  #接受队列,对于没建立tcp连接的请求队列放入缓存中,队列大小为back_log,受限制与OS参数
max_connections =  1000  #最大并发连接数 ,增大该值需要相应增加允许打开的文件描述符数
max_connect_errors =  10000  #如果某个用户发起的连接error超过该数值,则该用户的下次连接将被阻塞,直到管理员执行flush hosts ; 命令;防止黑客
#open_files_limit =  10240
connect-timeout =  10  #连接超时之前的最大秒数,在Linux平台上,该超时也用作等待服务器首次回应的时间
wait-timeout =  28800  #等待关闭连接的时间
interactive-timeout =  28800  #关闭连接之前,允许interactive_timeout(取代了wait_timeout)秒的不活动时间。客户端的会话wait_timeout变量被设为会话interactive_timeout变量的值。
slave-net-timeout =  600  #从服务器也能够处理网络连接中断。但是,只有从服务器超过slave_net_timeout秒没有从主服务器收到数据才通知网络中断
net_read_timeout =  30  #从服务器读取信息的超时
net_write_timeout =  60  #从服务器写入信息的超时
net_retry_count =  10  #如果某个通信端口的读操作中断了,在放弃前重试多次
net_buffer_length =  16384  #包消息缓冲区初始化为net_buffer_length字节,但需要时可以增长到max_allowed_packet字节
max_allowed_packet = 64M #
#table_cache =  512  #所有线程打开的表的数目。增大该值可以增加mysqld需要的文件描述符的数量
thread_stack = 192K #每个线程的堆栈大小
thread_cache_size =  20  #线程缓存
thread_concurrency =  8  #同时运行的线程的数据 此处最好为CPU个数两倍。本机配置为CPU的个数
# qcache settings
query_cache_size = 256M #查询缓存大小
query_cache_limit = 2M #不缓存查询大于该值的结果
query_cache_min_res_unit = 2K #查询缓存分配的最小块大小
default  settings
# time zone
default -time-zone = system #服务器时区
character- set -server = utf8 #server级别字符集
default -storage-engine = InnoDB #默认存储
# tmp & heap
tmp_table_size = 512M #临时表大小,如果超过该值,则结果放到磁盘中
max_heap_table_size = 512M #该变量设置MEMORY (HEAP)表可以增长到的最大空间大小
log-bin = mysql-bin #这些路径相对于datadir
log-bin-index = mysql-bin.index
relayrelay-log = relay-log
relayrelay_log_index = relay-log.index
# warning & error log
log-warnings =  1
log-error = /home/mysql/mysql/log/mysql.err
log_output = FILE #参数log_output指定了慢查询输出的格式,默认为FILE,你可以将它设为TABLE,然后就可以查询mysql架构下的slow_log表了
# slow query log
slow_query_log =  1
long-query-time =  1  #慢查询时间 超过 1 秒则为慢查询
slow_query_log_file = /home/mysql/mysql/log/slow.log
#log-queries-not-using-indexes
#log-slow-slave-statements
general_log =  1
general_log_file = /home/mysql/mysql/log/mysql.log
max_binlog_size = 1G
max_relay_log_size = 1G
if  use  auto-ex,  set  to  0
relay-log-purge =  1  #当不用中继日志时,删除他们。这个操作有SQL线程完成
# max binlog keeps days
expire_logs_days =  30  #超过 30 天的binlog删除
binlog_cache_size = 1M #session级别
# replication
replicate-wild-ignore-table = mysql.% #复制时忽略数据库及表
replicate-wild-ignore-table = test.% #复制时忽略数据库及表
# slave_skip_errors=all
key_buffer_size = 256M #myisam索引buffer,只有key没有data
sort_buffer_size = 2M #排序buffer大小;线程级别
read_buffer_size = 2M #以全表扫描(Sequential Scan)方式扫描数据的buffer大小 ;线程级别
join_buffer_size = 8M # join buffer 大小;线程级别
read_rnd_buffer_size = 8M #MyISAM以索引扫描(Random Scan)方式扫描数据的buffer大小 ;线程级别
bulk_insert_buffer_size = 64M #MyISAM 用在块插入优化中的树缓冲区的大小。注释:这是一个per thread的限制
myisam_sort_buffer_size = 64M #MyISAM 设置恢复表之时使用的缓冲区的尺寸,当在REPAIR TABLE或用CREATE INDEX创建索引或ALTER TABLE过程中排序 MyISAM索引分配的缓冲区
myisam_max_sort_file_size = 10G #MyISAM 如果临时文件会变得超过索引,不要使用快速排序索引方法来创建一个索引。注释:这个参数以字节的形式给出.重建MyISAM索引(在REPAIR TABLE、ALTER TABLE或LOAD DATA INFILE过程中)时,允许MySQL使用的临时文件的最大空间大小。如果文件的大小超过该值,则使用键值缓存创建索引,要慢得多。该值的单位为字节
myisam_repair_threads =  1  #如果该值大于 1 ,在Repair by sorting过程中并行创建MyISAM表索引(每个索引在自己的线程内)
myisam_recover = 64K#允许的GROUP_CONCAT()函数结果的最大长度
transaction_isolation = REPEATABLE-READ
innodb_file_per_table
#innodb_status_file =  1
#innodb_open_files =  2048
innodb_additional_mem_pool_size = 100M #帧缓存的控制对象需要从此处申请缓存,所以该值与innodb_buffer_pool对应
innodb_buffer_pool_size = 2G #包括数据页、索引页、插入缓存、锁信息、自适应哈希所以、数据字典信息
innodb_data_home_dir = /usr/local/mysql/ var /
#innodb_data_file_path = ibdata1:1G:autoextend
innodb_data_file_path = ibdata1:500M;ibdata2:2210M:autoextend #表空间
innodb_file_io_threads =  4  #io线程数
innodb_thread_concurrency =  16  #InnoDB试着在InnoDB内保持操作系统线程的数量少于或等于这个参数给出的限制
innodb_flush_log_at_trx_commit =  1  #每次commit 日志缓存中的数据刷到磁盘中
innodb_log_buffer_size = 8M #事物日志缓存
innodb_log_file_size = 500M #事物日志大小
#innodb_log_file_size =100M
innodb_log_files_in_group =  2  #两组事物日志
innodb_log_group_home_dir = /usr/local/mysql/mysql/ var /#日志组
innodb_max_dirty_pages_pct =  90  #innodb主线程刷新缓存池中的数据,使脏数据比例小于 90 %
innodb_lock_wait_timeout =  50  #InnoDB事务在被回滚之前可以等待一个锁定的超时秒数。InnoDB在它自己的 锁定表中自动检测事务死锁并且回滚事务。InnoDB用LOCK TABLES语句注意到锁定设置。默认值是 50
#innodb_flush_method = O_DSYNC
[mysqldump]
quick
max_allowed_packet = 64M
[mysql]
disable-auto-rehash #允许通过TAB键提示
default -character- set  = utf8
connect-timeout =  3




本文转自 西索oO 51CTO博客,原文链接:http://blog.51cto.com/lansgg/1259347
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3天前
|
关系型数据库 MySQL Linux
Linux联网安装MySQL Server
Linux联网安装MySQL Server
13 0
|
4天前
|
关系型数据库 MySQL Linux
centos7安装mysql-带网盘安装包
centos7安装mysql-带网盘安装包
33 2
|
7天前
|
关系型数据库 MySQL 数据库
Docker安装MySQL
Docker安装MySQL
14 1
|
8天前
|
关系型数据库 MySQL 数据安全/隐私保护
MySQL 安装及连接
MySQL 安装及连接
25 0
|
10天前
|
关系型数据库 MySQL 数据库
docker自定义安装mysql 5.7
docker自定义安装mysql 5.7
19 0
|
10天前
|
存储 Linux Shell
centos 部署docker容器 安装 、基本使用方法(一)
centos 部署docker容器 安装 、基本使用方法(一)
19 0
|
10天前
|
分布式计算 Hadoop Java
centos 部署Hadoop-3.0-高性能集群(一)安装
centos 部署Hadoop-3.0-高性能集群(一)安装
13 0
|
10天前
|
关系型数据库 MySQL Linux
CentOS 7 下使用yum安装MySQL5.7.20 最简单 图文详解
CentOS 7 下使用yum安装MySQL5.7.20 最简单 图文详解
48 0
|
11天前
|
关系型数据库 MySQL 数据库
mysql卸载、下载、安装(window版本)
mysql卸载、下载、安装(window版本)
|
1月前
|
关系型数据库 MySQL 数据库连接
关于MySQL-ODBC的zip包安装方法
关于MySQL-ODBC的zip包安装方法

热门文章

最新文章