Linux 下编译安装 MySQL(Percona Server) 5.6
admin
2023-06-07 06:01:15
0

系统环境:

  • CentOS 6.5 / 7.0 x86_64

  • Fedora 20 x86_64

简介

Percona Server 是 MySQL 的衍生版,专注于 Linux/BSD 下 MySQL 数据库服务器的改进, 在功能和性能上较 MySQL 有着显著的提升。

Percona Server 的编译、配置和使用与 MySQL 完全一致,你完全可以把它当成是 MySQL 来使用。

下载 Percona Server 源码包
# wget 
 或 MySQL 源码包
 # wget http://cdn.mysql.com/Downloads/MySQL-5.6/mysql-5.6.19.tar.gz
安装依赖
# yum install gcc-c++ make cmake bison bison-devel ncurses-devel libaio-devel perl

对于 Fedora 20 和 CentOS 7 需要另外安装一个 perl-Data-Dumper 包:

# yum install  perl-Data-Dumper
创建 MySQL 用户
# groupadd mysql# useradd -g mysql -s /sbin/nologin -M mysql
创建日志目录和 SOCK 目录并更改权限
# mkdir /var/log/mysql56# chown -R mysql:mysql /var/log/mysql56/
编译安装
# tar zxf percona-server-5.6.17-66.0.tar.gz -C /usr/local/src/
# cd /usr/local/src/percona-server-5.6.17-66.0
/# cmake 
\-DCMAKE_INSTALL_PREFIX=/usr/local/mysql56 
\-DSYSCONFDIR=/usr/local/mysql56/etc 
\-DMYSQL_DATADIR=/var/lib/mysql56 
\-DMYSQL_UNIX_ADDR=/var/run/mysql56/mysqld.sock 
\-DMYSQL_USER=mysql 
\-DMYSQL_TCP_PORT=3306 
\-DWITH_MYISAM_STORAGE_ENGINE=1 
\-DWITH_INNOBASE_STORAGE_ENGINE=1 
\-DWITH_MEMORY_STORAGE_ENGINE=1 
\-DWITH_PARTITION_STORAGE_ENGINE=1 
\-DEXTRA_CHARSETS=all 
\-DDEFAULT_CHARSET=utf8 
\-DDEFAULT_COLLATION=utf8_general_ci 
\-DENABLED_LOCAL_INFILE=1 
\-DWITH_READLINE=1

DENABLED_LOCAL_INFILE:允许导入文件到数据库,以加快数据导入速度, 使用 SQL 语句:

LOAD DATA LOCAL INFILE 数据文件 INTO TABLE 表名

WITH_READLINE:绑定 readline 的终端快捷键及历史记录功能。但是安装完后是不是仍然找不着 readline 的感觉, 因为 DWITH_READLINE 在 MySQL 5.6.5 版本就被移除了,同样 DWITH_LIBEDIT 在 MySQL 5.6.12 版本也被移除了

如果编译失败,清理源码目录下的 CMakeCache.txt 文件,重新编译即可。

# make -j8# make install
初始化数据库

切换到 MySQL 安装目录

# cd /usr/local/mysql56/

以 mysql 用户的身份创建 /var/lib/mysql56 datadir 目录,并写入初始化数据库信息:

# ./scripts/mysql_install_db --user=mysql --datadir=/var/lib/mysql56

拷贝服务文件到 /etc/init.d/mysql56,mysql56 这个文件名也是服务名,可以任意更改, 为了统一我们使用 mysql56 作为文件名:

# cp support-files/mysql.server /etc/init.d/mysql56
配置 my.cnf
# vi /usr/local/mysql56/etc/my.cnf[mysqld]datadir=/var/lib/mysql56
socket=/var/run/mysql56/mysqld.sock
skip-name-resolve
symbolic-links=0[mysqld_safe]log-error=/var/log/mysql56/mysqld-err.log#pid-file=/var/lib/mysql56/aboutc.pid

请注意文件路径。

启动 MySQL 服务
# service mysql56 startStarting MySQL (Percona Server).. SUCCESS!

更改 root 用户密码

# ./bin/mysqladmin -u root password 'new-password'

删除登录用户密码为空的数据

# ./bin/mysql -uroot -p
Enter password:
mysql> delete from mysql.user where password = '';
Query OK, 5 rows affected (0.51 sec
)mysql> select user,host,password from mysql.user;
+------+-----------+-------------------------------------------+
| user | host      | password                                  |
+------+-----------+-------------------------------------------+
| root | localhost | *9F6F2XXXX40B6DF5D2A5F762E1CF33782CA1ABXX |
+------+-----------+-------------------------------------------+
1 row in set (0.01 sec)
到此 MySQL(Percona Server) 编译安装完毕,你同样可以选择使用 YUM 安装 Percona Server, 关于不同的内存大小你也可以选择相应的 my.cnf 配置文件,使你的服务器资源可以平衡,提供更好的性能。
常见问题
如果启动 MySQL 服务时出现:Starting MySQL. ERROR! The server quit without updating PID file 错误, 请检查 my.cnf 中 log-error 配置的路径及权限。
如果访问数据库时出现:Can't connect to local MySQL server through socket 'xxx.sock' 错误, 请检查 my.cnf 中 socket 配置的路径及权限。


相关内容

热门资讯

煤矿瓦斯爆炸后,高压氧如何抢回... 据新华社报道,5月22日19时29分,山西长治市沁源县山西通洲集团留神峪煤业有限公司井下发生瓦斯爆炸...
每天刷手机5小时以上的人,都怎... “别再刷手机了,越刷越傻”“再这么玩手机,你就要废了”……在人手一部智能手机的时代,手机上瘾现象特别...
香江警花,即将绽放于星空之间 潮新闻客户端 记者 屠晨昕 今天(23日)上午,神舟二十三号载人飞行任务新闻发布会,给了整个香港乃至...
美官员披露美伊即将签署协议的更... △霍尔木兹海峡(资料图)据美国方面23日消息,美国和伊朗即将达成一份协议,其中包括将停火再延长60天...
现代AI系统通过图灵测试首获证... 美国加州大学圣迭戈分校科学家开展了一项实证研究,首次证明现代人工智能(AI)系统通过了图灵测试。相关...
强劲“中国心” 国产自研600... 5月23日,内蒙古锡林郭勒盟上空传来轰鸣声:由我国自主研制的600公斤推力级F406涡扇发动机,双发...
留神峪矿难获救矿工讲述:自救器... 5月22日晚7时29分,山西留神峪煤矿发生瓦斯爆炸事故,已致82人死亡。据央视新闻,事故发生后,留神...
预祝圆满成功!李家超与黎家盈视... 据凤凰卫视报道,神舟二十三号载人飞船即将发射,乘组成员包括首位来自香港的航天员黎家盈。香港特区行政长...
《给阿嬷的情书》,票房超10亿... 据网络平台数据截至5月24日,2026年度电影总票房(含预售)已突破151亿元!其中,电影《给阿嬷的...
美媒称伊朗同意放弃高浓缩铀库存 新华社华盛顿5月23日电(记者黄强 颜亮)据美国媒体23日报道,作为美国与伊朗即将达成的协议中的一个...