CentOS下MySQL 5.7编译安装

 

MySQL 5.7 GA版本的发布,也就是说从现在开始5.7已经可以在生产环境中使用,有任何问题官方都将立刻修复。

MySQL 5.7主要特性:

  • 更好的性能:对于多核CPU、固态硬盘、锁有着更好的优化,每秒100W QPS已不再是MySQL的追求,下个版本能否上200W QPS才是吾等用户更关心的
  • 更好的InnoDB存储引擎
  • 更为健壮的复制功能:复制带来了数据完全不丢失的方案,传统金融客户也可以选择使用MySQL数据库。此外,GTID在线平滑升级也变得可能
  • 更好的优化器:优化器代码重构的意义将在这个版本及以后的版本中带来巨大的改进,Oracle官方正在解决MySQL之前最大的难题
  • 原生JSON类型的支持
  • 更好的地理信息服务支持:InnoDB原生支持地理位置类型,支持GeoJSON,GeoHash特性
  • 新增sys库:以后这会是DBA访问最频繁的库

MySQL 5.7已经作为数据库可选项添加到《OneinStack

安装依赖包

  1. yum -y install gcc gcc-c++ ncurses ncurses-devel cmake

下载相应源码包

  1. cd /root/oneinstack/src
  2. wget http://downloads.sourceforge.net/project/boost/boost/1.59.0/boost_1_59_0.tar.gz
  3. wget http://cdn.mysql.com/Downloads/MySQL-5.7/mysql-5.7.11.tar.gz

添加mysql用户

  1. useradd -M -s /sbin/nologin mysql

预编译

  1. tar xzf boost_1_59_0.tar.gz
  2. tar xzf mysql-5.7.11.tar.gz
  3. mkdir -p /data/mysql
  4. cd mysql-5.7.11
  5. cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
  6. -DMYSQL_DATADIR=/data/mysql \
  7. -DDOWNLOAD_BOOST=1 \   #从MySQL 5.7.5开始Boost库是必需的
  8. -DWITH_BOOST=../boost_1_59_0 \
  9. -DSYSCONFDIR=/etc \
  10. -DWITH_INNOBASE_STORAGE_ENGINE=1 \
  11. -DWITH_PARTITION_STORAGE_ENGINE=1 \
  12. -DWITH_FEDERATED_STORAGE_ENGINE=1 \
  13. -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
  14. -DWITH_MYISAM_STORAGE_ENGINE=1 \
  15. -DENABLED_LOCAL_INFILE=1 \
  16. -DENABLE_DTRACE=0 \
  17. -DDEFAULT_CHARSET=utf8mb4 \
  18. -DDEFAULT_COLLATION=utf8mb4_general_ci \
  19. -DWITH_EMBEDDED_SERVER=1

编译安装

  1. make -j `grep processor /proc/cpuinfo | wc -l`  #编译很消耗系统资源,小内存可能编译通不过
  2. make install

启动脚本,设置开机自启动

  1. /bin/cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
  2. chmod +x /etc/init.d/mysqld
  3. chkconfig --add mysqld
  4. chkconfig mysqld on

/etc/my.cnf,仅供参考

  1. cat > /etc/my.cnf << EOF
  2. [client]
  3. port = 3306
  4. socket = /tmp/mysql.sock
  5. default-character-set = utf8mb4
  6. [mysqld]
  7. port = 3306
  8. socket = /tmp/mysql.sock
  9. basedir = /usr/local/mysql
  10. datadir = /data/mysql
  11. pid-file = /data/mysql/mysql.pid
  12. user = mysql
  13. bind-address = 0.0.0.0
  14. server-id = 1
  15. init-connect = 'SET NAMES utf8mb4'
  16. character-set-server = utf8mb4
  17. #skip-name-resolve
  18. #skip-networking
  19. back_log = 300
  20. max_connections = 1000
  21. max_connect_errors = 6000
  22. open_files_limit = 65535
  23. table_open_cache = 128
  24. max_allowed_packet = 4M
  25. binlog_cache_size = 1M
  26. max_heap_table_size = 8M
  27. tmp_table_size = 16M
  28. read_buffer_size = 2M
  29. read_rnd_buffer_size = 8M
  30. sort_buffer_size = 8M
  31. join_buffer_size = 8M
  32. key_buffer_size = 4M
  33. thread_cache_size = 8
  34. query_cache_type = 1
  35. query_cache_size = 8M
  36. query_cache_limit = 2M
  37. ft_min_word_len = 4
  38. log_bin = mysql-bin
  39. binlog_format = mixed
  40. expire_logs_days = 30
  41. log_error = /data/mysql/mysql-error.log
  42. slow_query_log = 1
  43. long_query_time = 1
  44. slow_query_log_file = /data/mysql/mysql-slow.log
  45. performance_schema = 0
  46. explicit_defaults_for_timestamp
  47. #lower_case_table_names = 1
  48. skip-external-locking
  49. default_storage_engine = InnoDB
  50. #default-storage-engine = MyISAM
  51. innodb_file_per_table = 1
  52. innodb_open_files = 500
  53. innodb_buffer_pool_size = 64M
  54. innodb_write_io_threads = 4
  55. innodb_read_io_threads = 4
  56. innodb_thread_concurrency = 0
  57. innodb_purge_threads = 1
  58. innodb_flush_log_at_trx_commit = 2
  59. innodb_log_buffer_size = 2M
  60. innodb_log_file_size = 32M
  61. innodb_log_files_in_group = 3
  62. innodb_max_dirty_pages_pct = 90
  63. innodb_lock_wait_timeout = 120
  64. bulk_insert_buffer_size = 8M
  65. myisam_sort_buffer_size = 8M
  66. myisam_max_sort_file_size = 10G
  67. myisam_repair_threads = 1
  68. interactive_timeout = 28800
  69. wait_timeout = 28800
  70. [mysqldump]
  71. quick
  72. max_allowed_packet = 16M
  73. [myisamchk]
  74. key_buffer_size = 8M
  75. sort_buffer_size = 8M
  76. read_buffer = 4M
  77. write_buffer = 4M
  78. EOF

初始化数据库

注:

  1. 之前版本mysql_install_db是在mysql_basedir/script下,5.7放在了mysql_install_db/bin目录下,且已被废弃
  2. "--initialize"会生成一个随机密码(~/.mysql_secret),而"--initialize-insecure"不会生成密码
  3. --datadir目标目录下不能有数据文件

启动数据库

  1. /usr/local/mysql/bin/mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql

设置数据库密码

  1. dbrootpwd=oneinstack  #数据库root密码
  2. /usr/local/mysql/bin/mysql -e "grant all privileges on *.* to root@'127.0.0.1' identified by \"$dbrootpwd\" with grant option;"
  3. /usr/local/mysql/bin/mysql -e "grant all privileges on *.* to root@'localhost' identified by \"$dbrootpwd\" with grant option;"
Sun Oct 25 21:05:49 CST 2015
 

CentOS下MySQL 5.7编译安装的更多相关文章

  1. CentOS 下 MySQL 5.7 编译安装

    MySQL5.7主要特性: 1—更好的性能:对于多核CPU.固态硬盘.锁有着更好的优化,每秒100W QPS已不再是MySQL的追求,下个版本能否上200W QPS才是吾等用户更关心的 2—更好的In ...

  2. CentOS MySQL 5.7编译安装

    CentOS MySQL 5.7编译安装 MySQL 5.7 GA版本的发布,也就是说从现在开始5.7已经可以在生产环境中使用,有任何问题官方都将立刻修复. MySQL 5.7主要特性: 更好的性能: ...

  3. centos下mysql 5源码安装全过程记录

    参考:http://blog.csdn.net/mycwq/article/details/24488691 安装cmake,mysql 5.5以后的版本要通过cmake进行编译 在新装的CentOS ...

  4. ubuntu下mysql源码编译安装

    建议:cpu4核以上,内存4G以上 1. 安装环境:Ubuntu Server 14.10MySQL-5.6.23.tar.gz 2. 安装必备的工具sudo apt-get install make ...

  5. centos 下nginx源码编译安装

    1.下载nginx 进入nginx官网下载nginx的稳定版本,我下载的是1.10.3. 下载:wget http://nginx.org/download/nginx-1.10.3.tar.gz 解 ...

  6. centos下httpd-2.4的编译安装

    httpd-2.4编译安装     依赖于更高版本的apr和apr-util      apr 全称  apache portable runtime 首先停用低版本的httpd服务 service ...

  7. Centos下Sphinx中文分词编译安装测试---CoreSeek

    要支持中文分词,还需要下载Coreseek,可以去官方搜索下载,这里我用的4.1 百度云下载地址:      https://pan.baidu.com/s/1slNIyHf tar -zxvf co ...

  8. CentOS下Mysql安装教程

    CentOS下Mysql安装教程 本人学习Linux时使用的是CentOs5.5版本,在该环境中,Mysql的安装方法有很多种,下面我只讲我这次成功了的方法,作为一个记录,供大家参考,同时给自己做一个 ...

  9. CentOS 下 MySQL 5.6 基于 RPM 的下载、安装、配置

    CentOS 下 MySQL 5.6 基于 RPM 的下载.安装.配置 系统: CentOS 7 x86_64 MySQL 版本: 5.6.40 安装方式: RPM 下载 下载地址 操作系统 选择 R ...

随机推荐

  1. 发布FireBird数据库所需要DLL文件

    数据库版本:2.5.2 ib_util.dll; icudt30.dll; icuin30.dll icuuc30.dll

  2. Hibernate一对一双向关联(外键)

    网站上各种搜索,都是一些清晰或者不清晰的例子,但是用下来一是确实不给力,二是完全不知道所以然. 后来终于在书中查到了就在这里记一下. 首先要说明,这里只解释双向一对一只有一个表里面有外键的情况. 就以 ...

  3. Linq学习之旅——LINQ查询表达式

    1. 概述 2. from子句 3. where子句 4. select子句 5. group子句 6. into子句 7. 排序子句 8. let子句 9. join子句 10. 小结 1. 概述 ...

  4. How to new a screen in linux

    screen -R -D: create a screen Ctrl + A & Ctrl + D: leave a screen

  5. 【Xamarin开发 Android 系列 7】 Android 结构基础(下)

    原文:[Xamarin开发 Android 系列 7] Android 结构基础(下) *******前期我们不打算进行太深入的东西,省的吓跑刚进门的,感觉门槛高,so,我们一开始就是跑马灯一样,向前 ...

  6. Android ListView中 每一项都有不同的布局

    实现代码 Adapter的代码 其中:ViewHolder分别是三个不同的布局,也就是ListView中每一项的布局 TYPE_1...是三种类型. 在使用不同布局的时候,getItemViewTyp ...

  7. Datetime中yyyy-MM-dd-hh-mm-ss的格式

    namespace yyyy_MM_dd_hh_mm{    class Program    {        static void Main(string[] args)        { wh ...

  8. Codevs_1048_石子归并_(动态规划)

    描述 http://codevs.cn/problem/1048/  1048 石子归并 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold       题目描述 Des ...

  9. HDU-2547 无剑无我

    无剑无我 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  10. linux命令 cp 递归复制 带权限复制

    cp -r 递归复制源目录下所有文件及子目录 到 目标目录或文件 cp -p 把源文件或目录下的所具有的权限一同复制 到 目标目录或文件