介绍
主要为了测试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/p/5738209.html,如需转载请自行联系原作者