zoukankan      html  css  js  c++  java
  • 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

    本站点所有随笔都是原创,欢迎大家转载;但转载时必须注明文章来源,且在文章开头明显处给明链接。

    《欢迎交流讨论》

  • 相关阅读:
    转载:从51CTO转来的两篇关于SQL的文章
    转载:几万年前,有一只猴子大闹地府后删库跑路...
    【java/oralce/sql】往一张仅有id,名称,创建时间三个字段的表中插入百万数据需要多久?1分26秒
    处处留心皆学问
    [oracle/java/sql]用于上十万批量数据插入Oracle表的Java程序
    Linux学习_003_虚拟机CentOS 7.5 如何固定IP地址
    Linux学习_002_VMware12.0 Pro 中安装 CentOS-7.5(桌面版)
    Linux学习_001_VMware10.0 && VMware12.0 Pro && VMware14.0 Pro && VMware 15.0 Pro 的安装与破解
    day76_淘淘商城项目_09_商品详情页动态展示实现(jsp+redis) + FreeMarker模板引擎入门 + 商品详情页静态化实现(Win版本的nginx作http服务器)_匠心笔记
    Eclipse注释模板设置详解
  • 原文地址:https://www.cnblogs.com/chenmh/p/5738209.html
Copyright © 2011-2022 走看看