介紹 主要為了測試percona的線程池的性能,這裡就簡單介紹一下percona5.7的安裝,在percona官方手冊上面介紹的很簡單按照上面的方法安裝不會成功。 db:percona5.7.13 os:centos6.7 安裝準備 1.創建用戶 groupadd mysql useradd -r ...
介紹
主要為了測試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 本站點所有隨筆都是原創,歡迎大家轉載;但轉載時必須註明文章來源,且在文章開頭明顯處給明鏈接。 《歡迎交流討論》 |