系統環境: php
Percona Server 是 MySQL 的衍生版,專一於 Linux/BSD 下 MySQL 數據庫服務器的改進, 在功能和性能上較 MySQL 有着顯著的提高。 html
Percona Server 的編譯、配置和使用與 MySQL 徹底一致,你徹底能夠把它當成是 MySQL 來使用。 mysql
# wget http://www.percona.com/downloads/Percona-Server-5.6/LATEST/source/tarball/percona-server-5.6.17-66.0.tar.gz 或 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 包: linux
# yum install perl-Data-Dumper
# groupadd mysql # useradd -g mysql -s /sbin/nologin -M mysql
# 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 表名。 c++
DWITH_READLINE:綁定 readline 的終端快捷鍵及歷史記錄功能。可是安裝完後是否是仍然找不着 readline 的感受, 由於 DWITH_READLINE 在 MySQL 5.6.5 版本就被移除了,一樣 DWITH_LIBEDIT 在 MySQL 5.6.12 版本也被移除了。 git
點擊查看 更多編譯參數。 github
若是編譯失敗,清理源碼目錄下的 CMakeCache.txt 文件,從新編譯便可。 sql
# 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
# 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
請注意文件路徑。
# service mysql56 start Starting 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 配置的路徑及權限。
轉載請註明出處。 本文地址:http://blog.aboutc.net/linux/63/compile-and-install-mysql-percona-server-on-linux