程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> percona5.7 源碼安裝,percona5.7源碼

percona5.7 源碼安裝,percona5.7源碼

編輯:MySQL綜合教程

percona5.7 源碼安裝,percona5.7源碼


介紹

主要為了測試percona的線程池的性能,這裡就簡單介紹一下percona5.7的安裝,在percona官方手冊上面介紹的很簡單按照上面的方法安裝不會成功。

 

db:percona5.7.13

os:centos6.7 

 

安裝准備

1.創建用戶

groupadd mysql

useradd -r -g mysql mysql

2.創建數據庫目錄

mkdir -p /usr/local/percona       --安裝目錄

mkdir -p /percona/data   ---數據目錄

mkdir -p /percona/log

安裝percona5.7

1.下載1.59.0版本的boost

下載路徑:http://www.boost.org/users/download/

注意:必須是1.59版本的新版本不支持,下載後解壓放在-DWITH_BOOST指定目錄下

2.安裝插件

yum install  readline-devel git gcc gcc-c++ make cmake bison bison-devel ncurses-devel libaio-devel perl

3.編譯安裝

cmake   -DCMAKE_INSTALL_PREFIX=/usr/local/percona \
-DMYSQL_UNIX_ADDR=/percona/data/mysql.sock \
-DWITH_BOOST=/usr/local/percona/boost \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_EDITLINE=bundled \
-DENABLED_LOCAL_INFILE=1 \
-DMYSQL_DATADIR=/percona/data \
-DMYSQL_TCP_PORT=3306 \
-DZLIB_INCLUDE_DIR:PATH=/usr/include \
-DENABLE_DOWNLOADS=1
make  -j  8
make install

4.初始化數據庫

./bin/mysqld --initialize-insecure --user=mysql --basedir=/usr/local/percona --datadir=/percona/data  --innodb_undo_tablespaces=3

./bin/mysql_ssl_rsa_setup --user=mysql --basedir=/usr/local/percona --datadir=/percona/data 

5.配置mysql啟動服務

進入源碼包文件

cp support-files/mysql.server /etc/init.d/mysql

chmod +x /etc/init.d/mysql   --授予文件可執行權限

chkconfig mysql on  --配置mysql開機自動啟動

service mysql start  --啟動MySQL

6.配置環境變量

為了能直接調用mysql命令,需要配置環境變量

vim /etc/profile

在/etc/profile文件末尾添加

export PATH=/usr/local/percona/bin:$PATH

使環境變量立即生效

source /etc/profile

7.設置mysql root用戶密碼

默認mysql root用戶安裝完密碼為空

mysql -uroot  ---登入

SET PASSWORD = PASSWORD('root');  --設置root密碼

默認root只運行本地訪問

use mysql

select user,host from user where user='root';

授予root遠程連接權限,生產環境慎用

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;

8.防火牆配置

默認3306端口是未啟用,啟用3306端口

vim /etc/sysconfig/iptables

在-A INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT後面加入以下內容

-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT

重新啟動防火牆

service iptables restart

總結

連接池在處理高並發的快速的效果比oracle mysql社區版的要好,但是對於處理長查詢表現的效果並不理想。默認情況下mysql會為客戶端的每一個連接創建一個線程,當線程數越多CPU處理上下文切換的次數就越多,往往CPU的時間消耗就在上下文切換上。而線程池的作用就是將線程數控制在一定的數量,減少上下文切換的次數,同時它的調度功能也可以很好的管理客戶端進程連接到db的線程池。注意要使用線程池必須將thread_handling設置為pool-of-threads。

 

 

 

 

備注:

    作者:pursuer.chen

    博客:http://www.cnblogs.com/chenmh

本站點所有隨筆都是原創,歡迎大家轉載;但轉載時必須注明文章來源,且在文章開頭明顯處給明鏈接。

《歡迎交流討論》

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved