zoukankan      html  css  js  c++  java
  • centos7 minimal 安装mysql197

    CentOS 7.3.1611 安装 MySQL

    依赖

    MySQL 依赖 libaio,所以先要安装 libaio

    1. yum search libaio # 检索相关信息
    2. yum install libaio # 安装依赖包

    成功安装,提示如下:

    1. [root@bogon /]# yum install libaio
    2. 已加载插件:fastestmirror
    3. Loading mirror speeds from cached hostfile
    4. * base: mirrors.yun-idc.com
    5. * extras: mirrors.163.com
    6. * updates: mirrors.163.com
    7. 软件包 libaio-0.3.109-12.el7.x86_64 已安装并且是最新版本
    8. 无须任何处理

    检查 MySQL 是否已安装

    yum list installed | grep mysql
    

    如果有,就先全部卸载,命令如下:

    yum -y remove mysql-libs.x86_64
    

    若有多个依赖文件则依次卸载。当结果显示为 Complete!即卸载完毕。

    下载

    下载 MySQL Yum Repository

    地址为 http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm

    执行

    wget http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm
    

    如果提示-bash: wget: 未找到命令,请先执行 yum install wget 安装 wget

    安装

    添加 MySQL Yum Repository

    添加 MySQL Yum Repository 到你的系统 repository 列表中,执行

    yum localinstall mysql-community-release-el7-5.noarch.rpm
    

    显示

    1. [root@bogon software]# yum localinstall mysql-community-release-el7-5.noarch.rpm
    2. 已加载插件:fastestmirror
    3. 正在检查 mysql-community-release-el7-5.noarch.rpm: mysql-community-release-el7-5.noarch
    4. mysql-community-release-el7-5.noarch.rpm 将被安装
    5. 正在解决依赖关系
    6. --> 正在检查事务
    7. ---> 软件包 mysql-community-release.noarch.0.el7-5 将被 安装
    8. --> 解决依赖关系完成
    9.  
    10. 依赖关系解决
    11.  
    12. ================================================================================
    13. Package 架构 版本 源 大小
    14. ================================================================================
    15. 正在安装:
    16. mysql-community-release
    17. noarch el7-5 /mysql-community-release-el7-5.noarch 4.3 k
    18.  
    19. 事务概要
    20. ================================================================================
    21. 安装 1 软件包
    22.  
    23. 总计:4.3 k
    24. 安装大小:4.3 k
    25. Is this ok [y/d/N]

    提示是否 OK ,输入 y

    1. Is this ok [y/d/N]: y
    2. Downloading packages:
    3. Running transaction check
    4. Running transaction test
    5. Transaction test succeeded
    6. Running transaction
    7. 正在安装 : mysql-community-release-el7-5.noarch 1/1
    8. 验证中 : mysql-community-release-el7-5.noarch 1/1
    9.  
    10. 已安装:
    11. mysql-community-release.noarch 0:el7-5
    12.  
    13. 完毕!

    提示“完成!”,则说明 源添加成功。

    验证下是否添加成功

    yum repolist enabled | grep "mysql.*-community.*"
    

    可以看到下面内:

    1. [root@bogon software]# yum repolist enabled | grep "mysql.*-community.*"
    2. mysql-connectors-community/x86_64 MySQL Connectors Community 1
    3. mysql-tools-community/x86_64 MySQL Tools Community 1
    4. mysql56-community/x86_64 MySQL 5.6 Community Server 13

    选择要启用 MySQL 版本

    查看 MySQL 版本,执行

    yum repolist all | grep mysql
    

    可以看到 5.5, 5.7 版本是默认禁用的,因为现在最新的稳定版是 5.6

    1. [root@bogon software]# yum repolist all | grep mysql
    2. mysql-connectors-community/x86_64 MySQL Connectors Community 启用: 14
    3. mysql-connectors-community-source MySQL Connectors Community - Sourc 禁用
    4. mysql-tools-community/x86_64 MySQL Tools Community 启用: 17
    5. mysql-tools-community-source MySQL Tools Community - Source 禁用
    6. mysql55-community/x86_64 MySQL 5.5 Community Server 禁用
    7. mysql55-community-source MySQL 5.5 Community Server - Sourc 禁用
    8. mysql56-community/x86_64 MySQL 5.6 Community Server 启用: 139
    9. mysql56-community-source MySQL 5.6 Community Server - Sourc 禁用
    10. mysql57-community-dmr/x86_64 MySQL 5.7 Community Server Develop 禁用
    11. mysql57-community-dmr-source MySQL 5.7 Community Server Develop 禁用

    可以通过类似下面的语句来启动某些版本

    1. yum-config-manager --disable mysql56-community
    2. yum-config-manager --enable mysql57-community-dmr

    或者通过修改 /etc/yum.repos.d/mysql-community.repo 文件

    1. # Enable to use MySQL 5.6
    2. [mysql56-community]
    3. name=MySQL 5.6 Community Server
    4. baseurl=http://repo.mysql.com/yum/mysql-5.6-community/el/7/$basearch/
    5. enabled=1
    6. gpgcheck=1
    7. gpgkey=file:/etc/pki/rpm-gpg/RPM-GPG-KEY-mysql

    其中 enabled=0 是指禁用,enabled=1 指启用。

    注意: 任何时候,只能启用一个版本。

    执行

    yum repolist enabled | grep mysql
    

    查看当前的启动的 MySQL 版本

    1. [root@bogon software]# yum repolist enabled | grep mysql
    2. mysql-connectors-community/x86_64 MySQL Connectors Community 14
    3. mysql-tools-community/x86_64 MySQL Tools Community 17
    4. mysql56-community/x86_64 MySQL 5.6 Community Server 139

    本例,我们启用的是 5.6 版本。

    通过 Yum 来安装 MySQL

    执行

    yum install mysql-community-server 
    

    Yum 会自动处理 MySQL 与其他组件的依赖关系:

    1. [root@bogon software]# yum install mysql-community-server
    2. 已加载插件:fastestmirror
    3. Loading mirror speeds from cached hostfile
    4. * base: mirrors.yun-idc.com
    5. * extras: mirrors.163.com
    6. * updates: mirrors.163.com
    7. 正在解决依赖关系
    8. --> 正在检查事务
    9. ---> 软件包 mysql-community-server.x86_64.0.5.6.24-3.el7 将被 安装
    10. --> 正在处理依赖关系 mysql-community-common(x86-64) = 5.6.24-3.el7,它被软件包 m ysql-community-server-5.6.24-3.el7.x86_64 需要
    11. --> 正在处理依赖关系 mysql-community-client(x86-64) = 5.6.24-3.el7,它被软件包 m ysql-community-server-5.6.24-3.el7.x86_64 需要
    12. --> 正在处理依赖关系 perl(warnings),它被软件包 mysql-community-server-5.6.24-3. el7.x86_64 需要
    13. --> 正在处理依赖关系 perl(strict),它被软件包 mysql-community-server-5.6.24-3.el 7.x86_64 需要
    14. --> 正在处理依赖关系 perl(if),它被软件包 mysql-community-server-5.6.24-3.el7.x8 6_64 需要
    15. --> 正在处理依赖关系 perl(Sys::Hostname),它被软件包 mysql-community-server-5.6. 24-3.el7.x86_64 需要
    16. --> 正在处理依赖关系 perl(POSIX),它被软件包 mysql-community-server-5.6.24-3.el7 .x86_64 需要
    17. --> 正在处理依赖关系 perl(Getopt::Long),它被软件包 mysql-community-server-5.6.2 4-3.el7.x86_64 需要
    18. --> 正在处理依赖关系 perl(File::Temp),它被软件包 mysql-community-server-5.6.24- 3.el7.x86_64 需要
    19. --> 正在处理依赖关系 perl(File::Spec),它被软件包 mysql-community-server-5.6.24- 3.el7.x86_64 需要
    20. --> 正在处理依赖关系 perl(File::Path),它被软件包 mysql-community-server-5.6.24- 3.el7.x86_64 需要
    21. --> 正在处理依赖关系 perl(File::Copy),它被软件包 mysql-community-server-5.6.24- 3.el7.x86_64 需要
    22. --> 正在处理依赖关系 perl(File::Basename),它被软件包 mysql-community-server-5.6 .24-3.el7.x86_64 需要
    23. --> 正在处理依赖关系 perl(Fcntl),它被软件包 mysql-community-server-5.6.24-3.el7 .x86_64 需要
    24. --> 正在处理依赖关系 perl(Data::Dumper),它被软件包 mysql-community-server-5.6.2 4-3.el7.x86_64 需要
    25. --> 正在处理依赖关系 perl(DBI),它被软件包 mysql-community-server-5.6.24-3.el7.x 86_64 需要
    26. --> 正在处理依赖关系 net-tools,它被软件包 mysql-community-server-5.6.24-3.el7.x 86_64 需要
    27. --> 正在处理依赖关系 /usr/bin/perl,它被软件包 mysql-community-server-5.6.24-3.e l7.x86_64 需要
    28. --> 正在检查事务
    29. ---> 软件包 mysql-community-client.x86_64.0.5.6.24-3.el7 将被 安装
    30. --> 正在处理依赖关系 mysql-community-libs(x86-64) = 5.6.24-3.el7,它被软件包 mys ql-community-client-5.6.24-3.el7.x86_64 需要
    31. --> 正在处理依赖关系 perl(Exporter),它被软件包 mysql-community-client-5.6.24-3. el7.x86_64 需要
    32. ---> 软件包 mysql-community-common.x86_64.0.5.6.24-3.el7 将被 安装
    33. ---> 软件包 net-tools.x86_64.0.2.0-0.17.20131004git.el7 将被 安装
    34. ---> 软件包 perl.x86_64.4.5.16.3-285.el7 将被 安装
    35. --> 正在处理依赖关系 perl-libs = 4:5.16.3-285.el7,它被软件包 4:perl-5.16.3-285. el7.x86_64 需要
    36. --> 正在处理依赖关系 perl(Socket) >= 1.3,它被软件包 4:perl-5.16.3-285.el7.x86_6 4 需要
    37. --> 正在处理依赖关系 perl(Scalar::Util) >= 1.10,它被软件包 4:perl-5.16.3-285.el 7.x86_64 需要
    38. --> 正在处理依赖关系 perl-macros,它被软件包 4:perl-5.16.3-285.el7.x86_64 需要
    39. --> 正在处理依赖关系 perl-libs,它被软件包 4:perl-5.16.3-285.el7.x86_64 需要
    40. --> 正在处理依赖关系 perl(threads::shared),它被软件包 4:perl-5.16.3-285.el7.x86 _64 需要
    41. --> 正在处理依赖关系 perl(threads),它被软件包 4:perl-5.16.3-285.el7.x86_64 需要
    42. --> 正在处理依赖关系 perl(constant),它被软件包 4:perl-5.16.3-285.el7.x86_64 需 要
    43. --> 正在处理依赖关系 perl(Time::Local),它被软件包 4:perl-5.16.3-285.el7.x86_64 需要
    44. --> 正在处理依赖关系 perl(Time::HiRes),它被软件包 4:perl-5.16.3-285.el7.x86_64 需要
    45. --> 正在处理依赖关系 perl(Storable),它被软件包 4:perl-5.16.3-285.el7.x86_64 需 要
    46. --> 正在处理依赖关系 perl(Socket),它被软件包 4:perl-5.16.3-285.el7.x86_64 需要
    47. --> 正在处理依赖关系 perl(Scalar::Util),它被软件包 4:perl-5.16.3-285.el7.x86_64 需要
    48. --> 正在处理依赖关系 perl(Pod::Simple::XHTML),它被软件包 4:perl-5.16.3-285.el7. x86_64 需要
    49. --> 正在处理依赖关系 perl(Pod::Simple::Search),它被软件包 4:perl-5.16.3-285.el7 .x86_64 需要
    50. --> 正在处理依赖关系 perl(Filter::Util::Call),它被软件包 4:perl-5.16.3-285.el7. x86_64 需要
    51. --> 正在处理依赖关系 perl(Carp),它被软件包 4:perl-5.16.3-285.el7.x86_64 需要
    52. --> 正在处理依赖关系 libperl.so()(64bit),它被软件包 4:perl-5.16.3-285.el7.x86_6 4 需要
    53. ---> 软件包 perl-DBI.x86_64.0.1.627-4.el7 将被 安装
    54. --> 正在处理依赖关系 perl(RPC::PlServer) >= 0.2001,它被软件包 perl-DBI-1.627-4. el7.x86_64 需要
    55. --> 正在处理依赖关系 perl(RPC::PlClient) >= 0.2000,它被软件包 perl-DBI-1.627-4. el7.x86_64 需要
    56. ---> 软件包 perl-Data-Dumper.x86_64.0.2.145-3.el7 将被 安装
    57. ---> 软件包 perl-File-Path.noarch.0.2.09-2.el7 将被 安装
    58. ---> 软件包 perl-File-Temp.noarch.0.0.23.01-3.el7 将被 安装
    59. ---> 软件包 perl-Getopt-Long.noarch.0.2.40-2.el7 将被 安装
    60. --> 正在处理依赖关系 perl(Pod::Usage) >= 1.14,它被软件包 perl-Getopt-Long-2.40- 2.el7.noarch 需要
    61. --> 正在处理依赖关系 perl(Text::ParseWords),它被软件包 perl-Getopt-Long-2.40-2. el7.noarch 需要
    62. ---> 软件包 perl-PathTools.x86_64.0.3.40-5.el7 将被 安装
    63. --> 正在检查事务
    64. ---> 软件包 mariadb-libs.x86_64.1.5.5.41-2.el7_0 将被 取代
    65. ---> 软件包 mysql-community-libs.x86_64.0.5.6.24-3.el7 将被 舍弃
    66. ---> 软件包 perl-Carp.noarch.0.1.26-244.el7 将被 安装
    67. ---> 软件包 perl-Exporter.noarch.0.5.68-3.el7 将被 安装
    68. ---> 软件包 perl-Filter.x86_64.0.1.49-3.el7 将被 安装
    69. ---> 软件包 perl-PlRPC.noarch.0.0.2020-14.el7 将被 安装
    70. --> 正在处理依赖关系 perl(Net::Daemon) >= 0.13,它被软件包 perl-PlRPC-0.2020-14. el7.noarch 需要
    71. --> 正在处理依赖关系 perl(Net::Daemon::Test),它被软件包 perl-PlRPC-0.2020-14.el 7.noarch 需要
    72. --> 正在处理依赖关系 perl(Net::Daemon::Log),它被软件包 perl-PlRPC-0.2020-14.el7 .noarch 需要
    73. --> 正在处理依赖关系 perl(Compress::Zlib),它被软件包 perl-PlRPC-0.2020-14.el7.n oarch 需要
    74. ---> 软件包 perl-Pod-Simple.noarch.1.3.28-4.el7 将被 安装
    75. --> 正在处理依赖关系 perl(Pod::Escapes) >= 1.04,它被软件包 1:perl-Pod-Simple-3. 28-4.el7.noarch 需要
    76. --> 正在处理依赖关系 perl(Encode),它被软件包 1:perl-Pod-Simple-3.28-4.el7.noarc h 需要
    77. ---> 软件包 perl-Pod-Usage.noarch.0.1.63-3.el7 将被 安装
    78. --> 正在处理依赖关系 perl(Pod::Text) >= 3.15,它被软件包 perl-Pod-Usage-1.63-3.e l7.noarch 需要
    79. --> 正在处理依赖关系 perl-Pod-Perldoc,它被软件包 perl-Pod-Usage-1.63-3.el7.noar ch 需要
    80. ---> 软件包 perl-Scalar-List-Utils.x86_64.0.1.27-248.el7 将被 安装
    81. ---> 软件包 perl-Socket.x86_64.0.2.010-3.el7 将被 安装
    82. ---> 软件包 perl-Storable.x86_64.0.2.45-3.el7 将被 安装
    83. ---> 软件包 perl-Text-ParseWords.noarch.0.3.29-4.el7 将被 安装
    84. ---> 软件包 perl-Time-HiRes.x86_64.4.1.9725-3.el7 将被 安装
    85. ---> 软件包 perl-Time-Local.noarch.0.1.2300-2.el7 将被 安装
    86. ---> 软件包 perl-constant.noarch.0.1.27-2.el7 将被 安装
    87. ---> 软件包 perl-libs.x86_64.4.5.16.3-285.el7 将被 安装
    88. ---> 软件包 perl-macros.x86_64.4.5.16.3-285.el7 将被 安装
    89. ---> 软件包 perl-threads.x86_64.0.1.87-4.el7 将被 安装
    90. ---> 软件包 perl-threads-shared.x86_64.0.1.43-6.el7 将被 安装
    91. --> 正在检查事务
    92. ---> 软件包 perl-Encode.x86_64.0.2.51-7.el7 将被 安装
    93. ---> 软件包 perl-IO-Compress.noarch.0.2.061-2.el7 将被 安装
    94. --> 正在处理依赖关系 perl(Compress::Raw::Zlib) >= 2.061,它被软件包 perl-IO-Comp ress-2.061-2.el7.noarch 需要
    95. --> 正在处理依赖关系 perl(Compress::Raw::Bzip2) >= 2.061,它被软件包 perl-IO-Com press-2.061-2.el7.noarch 需要
    96. ---> 软件包 perl-Net-Daemon.noarch.0.0.48-5.el7 将被 安装
    97. ---> 软件包 perl-Pod-Escapes.noarch.1.1.04-285.el7 将被 安装
    98. ---> 软件包 perl-Pod-Perldoc.noarch.0.3.20-4.el7 将被 安装
    99. --> 正在处理依赖关系 perl(parent),它被软件包 perl-Pod-Perldoc-3.20-4.el7.noarch 需要
    100. --> 正在处理依赖关系 perl(HTTP::Tiny),它被软件包 perl-Pod-Perldoc-3.20-4.el7.no arch 需要
    101. ---> 软件包 perl-podlators.noarch.0.2.5.1-3.el7 将被 安装
    102. --> 正在检查事务
    103. ---> 软件包 perl-Compress-Raw-Bzip2.x86_64.0.2.061-3.el7 将被 安装
    104. ---> 软件包 perl-Compress-Raw-Zlib.x86_64.1.2.061-4.el7 将被 安装
    105. ---> 软件包 perl-HTTP-Tiny.noarch.0.0.033-3.el7 将被 安装
    106. ---> 软件包 perl-parent.noarch.1.0.225-244.el7 将被 安装
    107. --> 解决依赖关系完成
    108.  
    109. 依赖关系解决
    110.  
    111. ================================================================================
    112. Package 架构 版本 源 大小
    113. ================================================================================
    114. 正在安装:
    115. mysql-community-libs x86_64 5.6.24-3.el7 mysql56-community 2.0 M
    116. 替换 mariadb-libs.x86_64 1:5.5.41-2.el7_0
    117. mysql-community-server x86_64 5.6.24-3.el7 mysql56-community 58 M
    118. 为依赖而安装:
    119. mysql-community-client x86_64 5.6.24-3.el7 mysql56-community 19 M
    120. mysql-community-common x86_64 5.6.24-3.el7 mysql56-community 256 k
    121. net-tools x86_64 2.0-0.17.20131004git.el7 base 304 k
    122. perl x86_64 4:5.16.3-285.el7 base 8.0 M
    123. perl-Carp noarch 1.26-244.el7 base 19 k
    124. perl-Compress-Raw-Bzip2
    125. x86_64 2.061-3.el7 base 32 k
    126. perl-Compress-Raw-Zlib x86_64 1:2.061-4.el7 base 57 k
    127. perl-DBI x86_64 1.627-4.el7 base 802 k
    128. perl-Data-Dumper x86_64 2.145-3.el7 base 47 k
    129. perl-Encode x86_64 2.51-7.el7 base 1.5 M
    130. perl-Exporter noarch 5.68-3.el7 base 28 k
    131. perl-File-Path noarch 2.09-2.el7 base 26 k
    132. perl-File-Temp noarch 0.23.01-3.el7 base 56 k
    133. perl-Filter x86_64 1.49-3.el7 base 76 k
    134. perl-Getopt-Long noarch 2.40-2.el7 base 56 k
    135. perl-HTTP-Tiny noarch 0.033-3.el7 base 38 k
    136. perl-IO-Compress noarch 2.061-2.el7 base 260 k
    137. perl-Net-Daemon noarch 0.48-5.el7 base 51 k
    138. perl-PathTools x86_64 3.40-5.el7 base 82 k
    139. perl-PlRPC noarch 0.2020-14.el7 base 36 k
    140. perl-Pod-Escapes noarch 1:1.04-285.el7 base 50 k
    141. perl-Pod-Perldoc noarch 3.20-4.el7 base 87 k
    142. perl-Pod-Simple noarch 1:3.28-4.el7 base 216 k
    143. perl-Pod-Usage noarch 1.63-3.el7 base 27 k
    144. perl-Scalar-List-Utils x86_64 1.27-248.el7 base 36 k
    145. perl-Socket x86_64 2.010-3.el7 base 49 k
    146. perl-Storable x86_64 2.45-3.el7 base 77 k
    147. perl-Text-ParseWords noarch 3.29-4.el7 base 14 k
    148. perl-Time-HiRes x86_64 4:1.9725-3.el7 base 45 k
    149. perl-Time-Local noarch 1.2300-2.el7 base 24 k
    150. perl-constant noarch 1.27-2.el7 base 19 k
    151. perl-libs x86_64 4:5.16.3-285.el7 base 687 k
    152. perl-macros x86_64 4:5.16.3-285.el7 base 42 k
    153. perl-parent noarch 1:0.225-244.el7 base 12 k
    154. perl-podlators noarch 2.5.1-3.el7 base 112 k
    155. perl-threads x86_64 1.87-4.el7 base 49 k
    156. perl-threads-shared x86_64 1.43-6.el7 base 39 k
    157.  
    158. 事务概要
    159. ================================================================================
    160. 安装 2 软件包 (+37 依赖软件包)
    161.  
    162. 总下载量:92 M
    163. Is this ok [y/d/N]:

    输入 y 继续下载相关文件;

    1. --------------------------------------------------------------------------------
    2. 总计 1.1 MB/s | 92 MB 01:24
    3. 从 file:/etc/pki/rpm-gpg/RPM-GPG-KEY-mysql 检索密钥
    4. 导入 GPG key 0x5072E1F5:
    5. 用户ID : "MySQL Release Engineering <mysql-build@oss.oracle.com>"
    6. 指纹 : a4a9 4068 76fc bd3c 4567 70c8 8c71 8d3b 5072 e1f5
    7. 软件包 : mysql-community-release-el7-5.noarch (@/mysql-community-release-el7-5.noarch)
    8. 来自 : file:/etc/pki/rpm-gpg/RPM-GPG-KEY-mysql
    9. 是否继续?[y/N]:
    10.  

    遇到上述提示,输入 y 继续,执行完成会提示“完毕!”。此时MySQL 安装完成,它包含了 mysql-community-server、mysql-community-client、mysql-community-common、mysql-community-libs 四个包。

    执行

    rpm -qi mysql-community-server.x86_64 0:5.6.24-3.el7
    

    执行

    whereis mysql
    

    可以看到 MySQL 的安装目录是 /usr/bin/

    1. [root@localhost ~]# whereis mysql
    2. mysql: /usr/bin/mysql /usr/lib64/mysql /usr/share/mysql /usr/share/man/man1/mysql.1.gz

    启动和关闭 MySQL Server

    启动 MySQL Server

    systemctl start  mysqld
    

    查看 MySQL Server 状态

    systemctl status  mysqld
    

    关闭 MySQL Server

    systemctl stop mysqld
    

    测试是否安装成功

    mysql
    

    可以进入 mysql 命令行界面

    1. [root@bogon software]# mysql
    2. Welcome to the MySQL monitor. Commands end with ; or g.
    3. Your MySQL connection id is 2
    4. Server version: 5.6.24 MySQL Community Server (GPL)
    5.  
    6. Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.
    7.  
    8. Oracle is a registered trademark of Oracle Corporation and/or its
    9. affiliates. Other names may be trademarks of their respective
    10. owners.
    11.  
    12. Type 'help;' or 'h' for help. Type 'c' to clear the current input statement.
    13.  
    14. mysql>

    防火墙设置

    远程访问 MySQL, 需开放默认端口号 3306.

    方式1:iptables(CentOS 7.x版本之前用法,不推荐)

    打开 iptables 的配置文件:

    vi /etc/sysconfig/iptables
    

    修改

    1. *filter
    2. :INPUT ACCEPT [0:0]
    3. :FORWARD ACCEPT [0:0]
    4. :OUTPUT ACCEPT [0:0]
    5. -A INPUT -m state --state RELATED,ESTABLISHED -j ACCEPT
    6. -A INPUT -p icmp -j ACCEPT
    7. -A INPUT -i lo -j ACCEPT
    8. -A INPUT -p tcp -m state --state NEW -m tcp --dport 22 -j ACCEPT
    9. -A INPUT -j REJECT --reject-with icmp-host-prohibited
    10. -A FORWARD -j REJECT --reject-with icmp-host-prohibited
    11. COMMIT

    在里面加入这2行:

    1. -A RH-Firewall-1-INPUT -m statestate NEW -m tcp -p tcp –dport 3306 -j ACCEPT
    2. -A RH-Firewall-1-INPUT -m statestate NEW -m udp -p udp –dport 3306 -j ACCEPT

    改为

    1. *filter
    2. :INPUT ACCEPT [0:0]
    3. :FORWARD ACCEPT [0:0]
    4. :OUTPUT ACCEPT [0:0]
    5. -A INPUT -m state --state RELATED,ESTABLISHED -j ACCEPT
    6. -A INPUT -p icmp -j ACCEPT
    7. -A INPUT -i lo -j ACCEPT
    8. -A INPUT -p tcp -m state --state NEW -m tcp --dport 22 -j ACCEPT
    9. -A RH-Firewall-1-INPUT -m statestate NEW -m tcp -p tcp –dport 3306 -j ACCEPT
    10. -A RH-Firewall-1-INPUT -m statestate NEW -m udp -p udp –dport 3306 -j ACCEPT
    11. -A INPUT -j REJECT --reject-with icmp-host-prohibited
    12. -A FORWARD -j REJECT --reject-with icmp-host-prohibited
    13. COMMIT

    如果该 iptables 配置文件 不存在,先执行 yum install iptables-services 安装

    执行 iptables 重启生效

    service iptables restart
    

    方式2:firewall-cmd(推荐)

    执行

    1. firewall-cmd --permanent --zone=public --add-port=3306/tcp
    2. firewall-cmd --permanent --zone=public --add-port=3306/udp

    这样就开放了相应的端口。

    执行

    firewall-cmd --reload 
    

    使最新的防火墙设置规则生效。

    MySQL 安全设置

    服务器启动后,可以执行

    mysql_secure_installation;
    

    看到如下提示

    1. [root@bogon software]# mysql_secure_installation
    2.  
    3. NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MySQL
    4. SERVERS IN PRODUCTION USE! PLEASE READ EACH STEP CAREFULLY!
    5.  
    6. In order to log into MySQL to secure it, we'll need the current
    7. password for the root user. If you've just installed MySQL, and
    8. you haven't set the root password yet, the password will be blank,
    9. so you should just press enter here.
    10.  
    11. Enter current password for root (enter for none):
    12.  

    此时输入 root 原始密码(初始化安装的话为空),接下来,为了安全,MySQL 会提示你重置 root 密码,移除其他用户账号,禁用 root 远程登录,移除 test 数据库,重新加载 privilege 表格等,你只需输入 y 继续执行即可。

    1. OK, successfully used password, moving on...
    2.  
    3. Setting the root password ensures that nobody can log into the MySQL
    4. root user without the proper authorisation.
    5.  
    6. Set root password? [Y/n] y
    7. New password:
    8. Re-enter new password:
    9. Password updated successfully!
    10. Reloading privilege tables..
    11. ... Success!
    12.  
    13.  
    14. By default, a MySQL installation has an anonymous user, allowing anyone
    15. to log into MySQL without having to have a user account created for
    16. them. This is intended only for testing, and to make the installation
    17. go a bit smoother. You should remove them before moving into a
    18. production environment.
    19.  
    20. Remove anonymous users? [Y/n] y
    21. ... Success!
    22.  
    23. Normally, root should only be allowed to connect from 'localhost'. This
    24. ensures that someone cannot guess at the root password from the network.
    25.  
    26. Disallow root login remotely? [Y/n] y
    27. ... Success!
    28.  
    29. By default, MySQL comes with a database named 'test' that anyone can
    30. access. This is also intended only for testing, and should be removed
    31. before moving into a production environment.
    32.  
    33. Remove test database and access to it? [Y/n] y
    34. - Dropping test database...
    35. ERROR 1008 (HY000) at line 1: Can't drop database 'test'; database doesn't exist
    36. ... Failed! Not critical, keep moving...
    37. - Removing privileges on test database...
    38. ... Success!
    39.  
    40. Reloading the privilege tables will ensure that all changes made so far
    41. will take effect immediately.
    42.  
    43. Reload privilege tables now? [Y/n] y
    44. ... Success!
    45.  
    46. All done! If you've completed all of the above steps, your MySQL
    47. installation should now be secure.
    48.  
    49. Thanks for using MySQL!
    50.  
    51.  
    52. Cleaning up...
    53.  

    至此,整个 MySQL 安装完成。

    远程访问设置

    创建一个普通用户 sa ,密码是 some_pass

    CREATE USER 'sa'@'%' IDENTIFIED BY 'some_pass';
    

    给这个用户授予 SELECT,INSERT,UPDATE,DELETE 的远程访问的权限,这个账号一般用于提供给实施的系统访问

    GRANT SELECT,INSERT,UPDATE,DELETE  ON *.* TO 'sa'@'%';
    

    创建一个管理员用户 admin 账号 ,密码是 some_pass

    CREATE USER 'admin'@'%' IDENTIFIED BY 'some_pass';
    

    给这个用户授予所有的远程访问的权限。这个用户主要用于管理整个数据库、备份、还原等操作。

    GRANT ALL  ON *.* TO 'admin'@'%';
    

    使授权立刻生效

    flush privileges;
    

    更改数据存放目录

    创建数据存放目录

    home 目录下建立 data 目录

    mkdir /home/data
    

    把 MySQL 服务进程停掉

    如果 MySQL 是启动的,要先关闭

    mysqladmin -u root -p shutdown
    

    移动数据到数据存放目录

    /var/lib/mysql 整个目录移到 /home/data,执行

    mv /var/lib/mysql /home/data
    

    这样就把 MySQL 的数据文件移动到了 /home/data/mysql 下

    修改 /etc/my.cnf 文件,

    1. [mysqld]
    2. datadir=/home/data/mysql
    3. socket=/home/data/mysql/mysql.sock
    4.  
    5. [mysql]
    6. socket=/home/data/mysql/mysql.sock

    修改权限

    chown -R mysql:mysql /home/data/mysql
    

    重启后,如果不能启动 MySQL 服务,执行

    vi  /etc/sysconfig/selinux
    

    调整

    SELINUX=permissive
    

    保存设置,执行 reboot 重启生效

    开机自起

    查看 MySQL 服务是否开机启动

    1. [root@localhost ~]# systemctl is-enabled mysql.service;echo $?
    2. enabled
    3. 0

    如果是 enabled 则说明是开机自动,如果不是,执行

    chkconfig --levels 235 mysqld on
    

    设置字符集

    一般的,为了支持中文,我们应该讲字符集设为 UTF-8, 执行

    SHOW VARIABLES LIKE 'character%';
    

    查看当前 MySQL 字符集

    1. mysql> SHOW VARIABLES LIKE 'character%';
    2. +--------------------------+----------------------------+
    3. | Variable_name | Value |
    4. +--------------------------+----------------------------+
    5. | character_set_client | utf8 |
    6. | character_set_connection | utf8 |
    7. | character_set_database | latin1 |
    8. | character_set_filesystem | binary |
    9. | character_set_results | utf8 |
    10. | character_set_server | latin1 |
    11. | character_set_system | utf8 |
    12. | character_sets_dir | /usr/share/mysql/charsets/ |
    13. +--------------------------+----------------------------+
    14. 8 rows in set (0.00 sec)

    可以看到默认服务器的字符器是 latin1 ,对中文不友好。
    修改 /etc/my.cnf 文件,添加字符集的设置

    1. [mysqld]
    2. character_set_server = utf8
    3.  
    4. [mysql]
    5. default-character-set = utf8

    重启 MySQL ,可以看到字符集已经修改了

    1. mysql> SHOW VARIABLES LIKE 'character%'
    2. -> ;
    3. +--------------------------+----------------------------+
    4. | Variable_name | Value |
    5. +--------------------------+----------------------------+
    6. | character_set_client | utf8 |
    7. | character_set_connection | utf8 |
    8. | character_set_database | utf8 |
    9. | character_set_filesystem | binary |
    10. | character_set_results | utf8 |
    11. | character_set_server | utf8 |
    12. | character_set_system | utf8 |
    13. | character_sets_dir | /usr/share/mysql/charsets/ |
    14. +--------------------------+----------------------------+
    15. 8 rows in set (0.00 sec)

    其他常用配置配置

    调整 MySQL 运行参数,修改 /etc/my.cnf 文件,常用配置如下:

    1. [mysqld]
    2. basedir = path # 使用给定目录作为根目录(安装目录)。
    3. datadir = path # 从给定目录读取数据库文件。
    4. pid-file = filename # 为mysqld程序指定一个存放进程ID的文件(仅适用于UNIX/Linux系统);
    5.  
    6.  
    7. socket = /tmp/mysql.sock # 为MySQL客户程序与服务器之间的本地通信指定一个套接字文件(Linux下默认是/var/lib/mysql/mysql.sock文件)
    8. port = 3306 # 指定MsSQL侦听的端口
    9. key_buffer = 384M # key_buffer是用于索引块的缓冲区大小,增加它可得到更好处理的索引(对所有读和多重写)。
    10. 索引块是缓冲的并且被所有的线程共享,key_buffer的大小视内存大小而定。
    11. table_cache = 512 # 为所有线程打开表的数量。增加该值能增加mysqld要求的文件描述符的数量。可以避免频繁的打开数据表产生的开销
    12. sort_buffer_size = 2M # 每个需要进行排序的线程分配该大小的一个缓冲区。增加这值加速ORDER BY或GROUP BY操作。
    13. 注意:该参数对应的分配内存是每连接独占!如果有100个连接,那么实际分配的总共排序缓冲区大小为100×6=600MB
    14. read_buffer_size = 2M # 读查询操作所能使用的缓冲区大小。和sort_buffer_size一样,该参数对应的分配内存也是每连接独享。
    15. query_cache_size = 32M # 指定MySQL查询结果缓冲区的大小
    16. read_rnd_buffer_size = 8M # 改参数在使用行指针排序之后,随机读用的。
    17. myisam_sort_buffer_size =64M # MyISAM表发生变化时重新排序所需的缓冲
    18. thread_concurrency = 8 # 最大并发线程数,取值为服务器逻辑CPU数量×2,如果CPU支持H.T超线程,再×2
    19. thread_cache = 8 # #缓存可重用的线程数
    20. skip-locking # 避免MySQL的外部锁定,减少出错几率增强稳定性。
    21. [mysqldump]
    22. max_allowed_packet =16M # 服务器和客户端之间最大能发送的可能信息包
    23.  
    24. [myisamchk]
    25. key_buffer = 256M
    26. sort_buffer = 256M
    27. read_buffer = 2M
    28. write_buffer = 2M

    其他可选参数:

    back_log = 384

    指定MySQL可能的连接数量。 当MySQL主线程在很短时间内接收到非常多的连接请求,该参数生效,主线程花费很短时间检查连接并且启动一个新线程。 back_log参数的值指出在MySQL暂时停止响应新请求之前的短时间内多少个请求可以被存在堆栈中。 如果系统在一个短时间内有很多连接,则需要增大该参数的值,该参数值指定到来的TCP/IP连接的侦听队列的大小。 试图设定back_log高于你的操作系统的限制将是无效的。默认值为50。对于Linux系统推荐设置为小于512的整数。

    max_connections = n

    MySQL服务器同时处理的数据库连接的最大数量(默认设置是100)。超过限制后会报 Too many connections 错误

    key_buffer_size = n

    用来存放索引区块的RMA值(默认设置是8M),增加它可得到更好处理的索引(对所有读和多重写)

    record_buffer:

    每个进行一个顺序扫描的线程为其扫描的每张表分配这个大小的一个缓冲区。 如果你做很多顺序扫描,你可能想要增加该值。默认数值是131072(128K)

    wait_timeout:

    服务器在关闭它之前在一个连接上等待行动的秒数。

    interactive_timeout:

    服务器在关闭它前在一个交互连接上等待行动的秒数。 一个交互的客户被定义为对 mysql_real_connect()使用 CLIENT_INTERACTIVE 选项的客户。 默认数值是28800,可以把它改为3600。

    skip-name-resolve

    禁止MySQL对外部连接进行DNS解析,使用这一选项可以消除MySQL进行DNS解析的时间。 但需要注意,如果开启该选项,则所有远程主机连接授权都要使用IP地址方式,否则MySQL将无法正常处理连接请求!

    log-slow-queries = slow.log

    记录慢查询,然后对慢查询一一优化

    skip-innodb

    skip-bdb

    关闭不需要的表类型,如果你需要,就不要加上这个

    备份、还原

    方法1:命令行

    备份

    mysqldump --socket=/home/data/mysql/mysql.sock --single-transaction=TRUE  -u root -p emsc > emsc.sql
    

    还原

    mysql --socket=/home/data/mysql/mysql.sock  -u root -p emsc < emsc.sql
    

    方法2:Workbench

    备份

    还原

    转至:http://www.centoscn.com/mysql/2016/0315/6844.html

    CentOS 7.3.1611 安装 MySQL

    依赖

    MySQL 依赖 libaio,所以先要安装 libaio

    1. yum search libaio # 检索相关信息
    2. yum install libaio # 安装依赖包

    成功安装,提示如下:

    1. [root@bogon /]# yum install libaio
    2. 已加载插件:fastestmirror
    3. Loading mirror speeds from cached hostfile
    4. * base: mirrors.yun-idc.com
    5. * extras: mirrors.163.com
    6. * updates: mirrors.163.com
    7. 软件包 libaio-0.3.109-12.el7.x86_64 已安装并且是最新版本
    8. 无须任何处理

    检查 MySQL 是否已安装

    yum list installed | grep mysql
    

    如果有,就先全部卸载,命令如下:

    yum -y remove mysql-libs.x86_64
    

    若有多个依赖文件则依次卸载。当结果显示为 Complete!即卸载完毕。

    下载

    下载 MySQL Yum Repository

    地址为 http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm

    执行

    wget http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm
    

    如果提示-bash: wget: 未找到命令,请先执行 yum install wget 安装 wget

    安装

    添加 MySQL Yum Repository

    添加 MySQL Yum Repository 到你的系统 repository 列表中,执行

    yum localinstall mysql-community-release-el7-5.noarch.rpm
    

    显示

    1. [root@bogon software]# yum localinstall mysql-community-release-el7-5.noarch.rpm
    2. 已加载插件:fastestmirror
    3. 正在检查 mysql-community-release-el7-5.noarch.rpm: mysql-community-release-el7-5.noarch
    4. mysql-community-release-el7-5.noarch.rpm 将被安装
    5. 正在解决依赖关系
    6. --> 正在检查事务
    7. ---> 软件包 mysql-community-release.noarch.0.el7-5 将被 安装
    8. --> 解决依赖关系完成
    9.  
    10. 依赖关系解决
    11.  
    12. ================================================================================
    13. Package 架构 版本 源 大小
    14. ================================================================================
    15. 正在安装:
    16. mysql-community-release
    17. noarch el7-5 /mysql-community-release-el7-5.noarch 4.3 k
    18.  
    19. 事务概要
    20. ================================================================================
    21. 安装 1 软件包
    22.  
    23. 总计:4.3 k
    24. 安装大小:4.3 k
    25. Is this ok [y/d/N]

    提示是否 OK ,输入 y

    1. Is this ok [y/d/N]: y
    2. Downloading packages:
    3. Running transaction check
    4. Running transaction test
    5. Transaction test succeeded
    6. Running transaction
    7. 正在安装 : mysql-community-release-el7-5.noarch 1/1
    8. 验证中 : mysql-community-release-el7-5.noarch 1/1
    9.  
    10. 已安装:
    11. mysql-community-release.noarch 0:el7-5
    12.  
    13. 完毕!

    提示“完成!”,则说明 源添加成功。

    验证下是否添加成功

    yum repolist enabled | grep "mysql.*-community.*"
    

    可以看到下面内:

    1. [root@bogon software]# yum repolist enabled | grep "mysql.*-community.*"
    2. mysql-connectors-community/x86_64 MySQL Connectors Community 1
    3. mysql-tools-community/x86_64 MySQL Tools Community 1
    4. mysql56-community/x86_64 MySQL 5.6 Community Server 13

    选择要启用 MySQL 版本

    查看 MySQL 版本,执行

    yum repolist all | grep mysql
    

    可以看到 5.5, 5.7 版本是默认禁用的,因为现在最新的稳定版是 5.6

    1. [root@bogon software]# yum repolist all | grep mysql
    2. mysql-connectors-community/x86_64 MySQL Connectors Community 启用: 14
    3. mysql-connectors-community-source MySQL Connectors Community - Sourc 禁用
    4. mysql-tools-community/x86_64 MySQL Tools Community 启用: 17
    5. mysql-tools-community-source MySQL Tools Community - Source 禁用
    6. mysql55-community/x86_64 MySQL 5.5 Community Server 禁用
    7. mysql55-community-source MySQL 5.5 Community Server - Sourc 禁用
    8. mysql56-community/x86_64 MySQL 5.6 Community Server 启用: 139
    9. mysql56-community-source MySQL 5.6 Community Server - Sourc 禁用
    10. mysql57-community-dmr/x86_64 MySQL 5.7 Community Server Develop 禁用
    11. mysql57-community-dmr-source MySQL 5.7 Community Server Develop 禁用

    可以通过类似下面的语句来启动某些版本

    1. yum-config-manager --disable mysql56-community
    2. yum-config-manager --enable mysql57-community-dmr

    或者通过修改 /etc/yum.repos.d/mysql-community.repo 文件

    1. # Enable to use MySQL 5.6
    2. [mysql56-community]
    3. name=MySQL 5.6 Community Server
    4. baseurl=http://repo.mysql.com/yum/mysql-5.6-community/el/7/$basearch/
    5. enabled=1
    6. gpgcheck=1
    7. gpgkey=file:/etc/pki/rpm-gpg/RPM-GPG-KEY-mysql

    其中 enabled=0 是指禁用,enabled=1 指启用。

    注意: 任何时候,只能启用一个版本。

    执行

    yum repolist enabled | grep mysql
    

    查看当前的启动的 MySQL 版本

    1. [root@bogon software]# yum repolist enabled | grep mysql
    2. mysql-connectors-community/x86_64 MySQL Connectors Community 14
    3. mysql-tools-community/x86_64 MySQL Tools Community 17
    4. mysql56-community/x86_64 MySQL 5.6 Community Server 139

    本例,我们启用的是 5.6 版本。

    通过 Yum 来安装 MySQL

    执行

    yum install mysql-community-server 
    

    Yum 会自动处理 MySQL 与其他组件的依赖关系:

    1. [root@bogon software]# yum install mysql-community-server
    2. 已加载插件:fastestmirror
    3. Loading mirror speeds from cached hostfile
    4. * base: mirrors.yun-idc.com
    5. * extras: mirrors.163.com
    6. * updates: mirrors.163.com
    7. 正在解决依赖关系
    8. --> 正在检查事务
    9. ---> 软件包 mysql-community-server.x86_64.0.5.6.24-3.el7 将被 安装
    10. --> 正在处理依赖关系 mysql-community-common(x86-64) = 5.6.24-3.el7,它被软件包 m ysql-community-server-5.6.24-3.el7.x86_64 需要
    11. --> 正在处理依赖关系 mysql-community-client(x86-64) = 5.6.24-3.el7,它被软件包 m ysql-community-server-5.6.24-3.el7.x86_64 需要
    12. --> 正在处理依赖关系 perl(warnings),它被软件包 mysql-community-server-5.6.24-3. el7.x86_64 需要
    13. --> 正在处理依赖关系 perl(strict),它被软件包 mysql-community-server-5.6.24-3.el 7.x86_64 需要
    14. --> 正在处理依赖关系 perl(if),它被软件包 mysql-community-server-5.6.24-3.el7.x8 6_64 需要
    15. --> 正在处理依赖关系 perl(Sys::Hostname),它被软件包 mysql-community-server-5.6. 24-3.el7.x86_64 需要
    16. --> 正在处理依赖关系 perl(POSIX),它被软件包 mysql-community-server-5.6.24-3.el7 .x86_64 需要
    17. --> 正在处理依赖关系 perl(Getopt::Long),它被软件包 mysql-community-server-5.6.2 4-3.el7.x86_64 需要
    18. --> 正在处理依赖关系 perl(File::Temp),它被软件包 mysql-community-server-5.6.24- 3.el7.x86_64 需要
    19. --> 正在处理依赖关系 perl(File::Spec),它被软件包 mysql-community-server-5.6.24- 3.el7.x86_64 需要
    20. --> 正在处理依赖关系 perl(File::Path),它被软件包 mysql-community-server-5.6.24- 3.el7.x86_64 需要
    21. --> 正在处理依赖关系 perl(File::Copy),它被软件包 mysql-community-server-5.6.24- 3.el7.x86_64 需要
    22. --> 正在处理依赖关系 perl(File::Basename),它被软件包 mysql-community-server-5.6 .24-3.el7.x86_64 需要
    23. --> 正在处理依赖关系 perl(Fcntl),它被软件包 mysql-community-server-5.6.24-3.el7 .x86_64 需要
    24. --> 正在处理依赖关系 perl(Data::Dumper),它被软件包 mysql-community-server-5.6.2 4-3.el7.x86_64 需要
    25. --> 正在处理依赖关系 perl(DBI),它被软件包 mysql-community-server-5.6.24-3.el7.x 86_64 需要
    26. --> 正在处理依赖关系 net-tools,它被软件包 mysql-community-server-5.6.24-3.el7.x 86_64 需要
    27. --> 正在处理依赖关系 /usr/bin/perl,它被软件包 mysql-community-server-5.6.24-3.e l7.x86_64 需要
    28. --> 正在检查事务
    29. ---> 软件包 mysql-community-client.x86_64.0.5.6.24-3.el7 将被 安装
    30. --> 正在处理依赖关系 mysql-community-libs(x86-64) = 5.6.24-3.el7,它被软件包 mys ql-community-client-5.6.24-3.el7.x86_64 需要
    31. --> 正在处理依赖关系 perl(Exporter),它被软件包 mysql-community-client-5.6.24-3. el7.x86_64 需要
    32. ---> 软件包 mysql-community-common.x86_64.0.5.6.24-3.el7 将被 安装
    33. ---> 软件包 net-tools.x86_64.0.2.0-0.17.20131004git.el7 将被 安装
    34. ---> 软件包 perl.x86_64.4.5.16.3-285.el7 将被 安装
    35. --> 正在处理依赖关系 perl-libs = 4:5.16.3-285.el7,它被软件包 4:perl-5.16.3-285. el7.x86_64 需要
    36. --> 正在处理依赖关系 perl(Socket) >= 1.3,它被软件包 4:perl-5.16.3-285.el7.x86_6 4 需要
    37. --> 正在处理依赖关系 perl(Scalar::Util) >= 1.10,它被软件包 4:perl-5.16.3-285.el 7.x86_64 需要
    38. --> 正在处理依赖关系 perl-macros,它被软件包 4:perl-5.16.3-285.el7.x86_64 需要
    39. --> 正在处理依赖关系 perl-libs,它被软件包 4:perl-5.16.3-285.el7.x86_64 需要
    40. --> 正在处理依赖关系 perl(threads::shared),它被软件包 4:perl-5.16.3-285.el7.x86 _64 需要
    41. --> 正在处理依赖关系 perl(threads),它被软件包 4:perl-5.16.3-285.el7.x86_64 需要
    42. --> 正在处理依赖关系 perl(constant),它被软件包 4:perl-5.16.3-285.el7.x86_64 需 要
    43. --> 正在处理依赖关系 perl(Time::Local),它被软件包 4:perl-5.16.3-285.el7.x86_64 需要
    44. --> 正在处理依赖关系 perl(Time::HiRes),它被软件包 4:perl-5.16.3-285.el7.x86_64 需要
    45. --> 正在处理依赖关系 perl(Storable),它被软件包 4:perl-5.16.3-285.el7.x86_64 需 要
    46. --> 正在处理依赖关系 perl(Socket),它被软件包 4:perl-5.16.3-285.el7.x86_64 需要
    47. --> 正在处理依赖关系 perl(Scalar::Util),它被软件包 4:perl-5.16.3-285.el7.x86_64 需要
    48. --> 正在处理依赖关系 perl(Pod::Simple::XHTML),它被软件包 4:perl-5.16.3-285.el7. x86_64 需要
    49. --> 正在处理依赖关系 perl(Pod::Simple::Search),它被软件包 4:perl-5.16.3-285.el7 .x86_64 需要
    50. --> 正在处理依赖关系 perl(Filter::Util::Call),它被软件包 4:perl-5.16.3-285.el7. x86_64 需要
    51. --> 正在处理依赖关系 perl(Carp),它被软件包 4:perl-5.16.3-285.el7.x86_64 需要
    52. --> 正在处理依赖关系 libperl.so()(64bit),它被软件包 4:perl-5.16.3-285.el7.x86_6 4 需要
    53. ---> 软件包 perl-DBI.x86_64.0.1.627-4.el7 将被 安装
    54. --> 正在处理依赖关系 perl(RPC::PlServer) >= 0.2001,它被软件包 perl-DBI-1.627-4. el7.x86_64 需要
    55. --> 正在处理依赖关系 perl(RPC::PlClient) >= 0.2000,它被软件包 perl-DBI-1.627-4. el7.x86_64 需要
    56. ---> 软件包 perl-Data-Dumper.x86_64.0.2.145-3.el7 将被 安装
    57. ---> 软件包 perl-File-Path.noarch.0.2.09-2.el7 将被 安装
    58. ---> 软件包 perl-File-Temp.noarch.0.0.23.01-3.el7 将被 安装
    59. ---> 软件包 perl-Getopt-Long.noarch.0.2.40-2.el7 将被 安装
    60. --> 正在处理依赖关系 perl(Pod::Usage) >= 1.14,它被软件包 perl-Getopt-Long-2.40- 2.el7.noarch 需要
    61. --> 正在处理依赖关系 perl(Text::ParseWords),它被软件包 perl-Getopt-Long-2.40-2. el7.noarch 需要
    62. ---> 软件包 perl-PathTools.x86_64.0.3.40-5.el7 将被 安装
    63. --> 正在检查事务
    64. ---> 软件包 mariadb-libs.x86_64.1.5.5.41-2.el7_0 将被 取代
    65. ---> 软件包 mysql-community-libs.x86_64.0.5.6.24-3.el7 将被 舍弃
    66. ---> 软件包 perl-Carp.noarch.0.1.26-244.el7 将被 安装
    67. ---> 软件包 perl-Exporter.noarch.0.5.68-3.el7 将被 安装
    68. ---> 软件包 perl-Filter.x86_64.0.1.49-3.el7 将被 安装
    69. ---> 软件包 perl-PlRPC.noarch.0.0.2020-14.el7 将被 安装
    70. --> 正在处理依赖关系 perl(Net::Daemon) >= 0.13,它被软件包 perl-PlRPC-0.2020-14. el7.noarch 需要
    71. --> 正在处理依赖关系 perl(Net::Daemon::Test),它被软件包 perl-PlRPC-0.2020-14.el 7.noarch 需要
    72. --> 正在处理依赖关系 perl(Net::Daemon::Log),它被软件包 perl-PlRPC-0.2020-14.el7 .noarch 需要
    73. --> 正在处理依赖关系 perl(Compress::Zlib),它被软件包 perl-PlRPC-0.2020-14.el7.n oarch 需要
    74. ---> 软件包 perl-Pod-Simple.noarch.1.3.28-4.el7 将被 安装
    75. --> 正在处理依赖关系 perl(Pod::Escapes) >= 1.04,它被软件包 1:perl-Pod-Simple-3. 28-4.el7.noarch 需要
    76. --> 正在处理依赖关系 perl(Encode),它被软件包 1:perl-Pod-Simple-3.28-4.el7.noarc h 需要
    77. ---> 软件包 perl-Pod-Usage.noarch.0.1.63-3.el7 将被 安装
    78. --> 正在处理依赖关系 perl(Pod::Text) >= 3.15,它被软件包 perl-Pod-Usage-1.63-3.e l7.noarch 需要
    79. --> 正在处理依赖关系 perl-Pod-Perldoc,它被软件包 perl-Pod-Usage-1.63-3.el7.noar ch 需要
    80. ---> 软件包 perl-Scalar-List-Utils.x86_64.0.1.27-248.el7 将被 安装
    81. ---> 软件包 perl-Socket.x86_64.0.2.010-3.el7 将被 安装
    82. ---> 软件包 perl-Storable.x86_64.0.2.45-3.el7 将被 安装
    83. ---> 软件包 perl-Text-ParseWords.noarch.0.3.29-4.el7 将被 安装
    84. ---> 软件包 perl-Time-HiRes.x86_64.4.1.9725-3.el7 将被 安装
    85. ---> 软件包 perl-Time-Local.noarch.0.1.2300-2.el7 将被 安装
    86. ---> 软件包 perl-constant.noarch.0.1.27-2.el7 将被 安装
    87. ---> 软件包 perl-libs.x86_64.4.5.16.3-285.el7 将被 安装
    88. ---> 软件包 perl-macros.x86_64.4.5.16.3-285.el7 将被 安装
    89. ---> 软件包 perl-threads.x86_64.0.1.87-4.el7 将被 安装
    90. ---> 软件包 perl-threads-shared.x86_64.0.1.43-6.el7 将被 安装
    91. --> 正在检查事务
    92. ---> 软件包 perl-Encode.x86_64.0.2.51-7.el7 将被 安装
    93. ---> 软件包 perl-IO-Compress.noarch.0.2.061-2.el7 将被 安装
    94. --> 正在处理依赖关系 perl(Compress::Raw::Zlib) >= 2.061,它被软件包 perl-IO-Comp ress-2.061-2.el7.noarch 需要
    95. --> 正在处理依赖关系 perl(Compress::Raw::Bzip2) >= 2.061,它被软件包 perl-IO-Com press-2.061-2.el7.noarch 需要
    96. ---> 软件包 perl-Net-Daemon.noarch.0.0.48-5.el7 将被 安装
    97. ---> 软件包 perl-Pod-Escapes.noarch.1.1.04-285.el7 将被 安装
    98. ---> 软件包 perl-Pod-Perldoc.noarch.0.3.20-4.el7 将被 安装
    99. --> 正在处理依赖关系 perl(parent),它被软件包 perl-Pod-Perldoc-3.20-4.el7.noarch 需要
    100. --> 正在处理依赖关系 perl(HTTP::Tiny),它被软件包 perl-Pod-Perldoc-3.20-4.el7.no arch 需要
    101. ---> 软件包 perl-podlators.noarch.0.2.5.1-3.el7 将被 安装
    102. --> 正在检查事务
    103. ---> 软件包 perl-Compress-Raw-Bzip2.x86_64.0.2.061-3.el7 将被 安装
    104. ---> 软件包 perl-Compress-Raw-Zlib.x86_64.1.2.061-4.el7 将被 安装
    105. ---> 软件包 perl-HTTP-Tiny.noarch.0.0.033-3.el7 将被 安装
    106. ---> 软件包 perl-parent.noarch.1.0.225-244.el7 将被 安装
    107. --> 解决依赖关系完成
    108.  
    109. 依赖关系解决
    110.  
    111. ================================================================================
    112. Package 架构 版本 源 大小
    113. ================================================================================
    114. 正在安装:
    115. mysql-community-libs x86_64 5.6.24-3.el7 mysql56-community 2.0 M
    116. 替换 mariadb-libs.x86_64 1:5.5.41-2.el7_0
    117. mysql-community-server x86_64 5.6.24-3.el7 mysql56-community 58 M
    118. 为依赖而安装:
    119. mysql-community-client x86_64 5.6.24-3.el7 mysql56-community 19 M
    120. mysql-community-common x86_64 5.6.24-3.el7 mysql56-community 256 k
    121. net-tools x86_64 2.0-0.17.20131004git.el7 base 304 k
    122. perl x86_64 4:5.16.3-285.el7 base 8.0 M
    123. perl-Carp noarch 1.26-244.el7 base 19 k
    124. perl-Compress-Raw-Bzip2
    125. x86_64 2.061-3.el7 base 32 k
    126. perl-Compress-Raw-Zlib x86_64 1:2.061-4.el7 base 57 k
    127. perl-DBI x86_64 1.627-4.el7 base 802 k
    128. perl-Data-Dumper x86_64 2.145-3.el7 base 47 k
    129. perl-Encode x86_64 2.51-7.el7 base 1.5 M
    130. perl-Exporter noarch 5.68-3.el7 base 28 k
    131. perl-File-Path noarch 2.09-2.el7 base 26 k
    132. perl-File-Temp noarch 0.23.01-3.el7 base 56 k
    133. perl-Filter x86_64 1.49-3.el7 base 76 k
    134. perl-Getopt-Long noarch 2.40-2.el7 base 56 k
    135. perl-HTTP-Tiny noarch 0.033-3.el7 base 38 k
    136. perl-IO-Compress noarch 2.061-2.el7 base 260 k
    137. perl-Net-Daemon noarch 0.48-5.el7 base 51 k
    138. perl-PathTools x86_64 3.40-5.el7 base 82 k
    139. perl-PlRPC noarch 0.2020-14.el7 base 36 k
    140. perl-Pod-Escapes noarch 1:1.04-285.el7 base 50 k
    141. perl-Pod-Perldoc noarch 3.20-4.el7 base 87 k
    142. perl-Pod-Simple noarch 1:3.28-4.el7 base 216 k
    143. perl-Pod-Usage noarch 1.63-3.el7 base 27 k
    144. perl-Scalar-List-Utils x86_64 1.27-248.el7 base 36 k
    145. perl-Socket x86_64 2.010-3.el7 base 49 k
    146. perl-Storable x86_64 2.45-3.el7 base 77 k
    147. perl-Text-ParseWords noarch 3.29-4.el7 base 14 k
    148. perl-Time-HiRes x86_64 4:1.9725-3.el7 base 45 k
    149. perl-Time-Local noarch 1.2300-2.el7 base 24 k
    150. perl-constant noarch 1.27-2.el7 base 19 k
    151. perl-libs x86_64 4:5.16.3-285.el7 base 687 k
    152. perl-macros x86_64 4:5.16.3-285.el7 base 42 k
    153. perl-parent noarch 1:0.225-244.el7 base 12 k
    154. perl-podlators noarch 2.5.1-3.el7 base 112 k
    155. perl-threads x86_64 1.87-4.el7 base 49 k
    156. perl-threads-shared x86_64 1.43-6.el7 base 39 k
    157.  
    158. 事务概要
    159. ================================================================================
    160. 安装 2 软件包 (+37 依赖软件包)
    161.  
    162. 总下载量:92 M
    163. Is this ok [y/d/N]:

    输入 y 继续下载相关文件;

    1. --------------------------------------------------------------------------------
    2. 总计 1.1 MB/s | 92 MB 01:24
    3. 从 file:/etc/pki/rpm-gpg/RPM-GPG-KEY-mysql 检索密钥
    4. 导入 GPG key 0x5072E1F5:
    5. 用户ID : "MySQL Release Engineering <mysql-build@oss.oracle.com>"
    6. 指纹 : a4a9 4068 76fc bd3c 4567 70c8 8c71 8d3b 5072 e1f5
    7. 软件包 : mysql-community-release-el7-5.noarch (@/mysql-community-release-el7-5.noarch)
    8. 来自 : file:/etc/pki/rpm-gpg/RPM-GPG-KEY-mysql
    9. 是否继续?[y/N]:
    10.  

    遇到上述提示,输入 y 继续,执行完成会提示“完毕!”。此时MySQL 安装完成,它包含了 mysql-community-server、mysql-community-client、mysql-community-common、mysql-community-libs 四个包。

    执行

    rpm -qi mysql-community-server.x86_64 0:5.6.24-3.el7
    

    执行

    whereis mysql
    

    可以看到 MySQL 的安装目录是 /usr/bin/

    1. [root@localhost ~]# whereis mysql
    2. mysql: /usr/bin/mysql /usr/lib64/mysql /usr/share/mysql /usr/share/man/man1/mysql.1.gz

    启动和关闭 MySQL Server

    启动 MySQL Server

    systemctl start  mysqld
    

    查看 MySQL Server 状态

    systemctl status  mysqld
    

    关闭 MySQL Server

    systemctl stop mysqld
    

    测试是否安装成功

    mysql
    

    可以进入 mysql 命令行界面

    1. [root@bogon software]# mysql
    2. Welcome to the MySQL monitor. Commands end with ; or g.
    3. Your MySQL connection id is 2
    4. Server version: 5.6.24 MySQL Community Server (GPL)
    5.  
    6. Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.
    7.  
    8. Oracle is a registered trademark of Oracle Corporation and/or its
    9. affiliates. Other names may be trademarks of their respective
    10. owners.
    11.  
    12. Type 'help;' or 'h' for help. Type 'c' to clear the current input statement.
    13.  
    14. mysql>

    防火墙设置

    远程访问 MySQL, 需开放默认端口号 3306.

    方式1:iptables(CentOS 7.x版本之前用法,不推荐)

    打开 iptables 的配置文件:

    vi /etc/sysconfig/iptables
    

    修改

    1. *filter
    2. :INPUT ACCEPT [0:0]
    3. :FORWARD ACCEPT [0:0]
    4. :OUTPUT ACCEPT [0:0]
    5. -A INPUT -m state --state RELATED,ESTABLISHED -j ACCEPT
    6. -A INPUT -p icmp -j ACCEPT
    7. -A INPUT -i lo -j ACCEPT
    8. -A INPUT -p tcp -m state --state NEW -m tcp --dport 22 -j ACCEPT
    9. -A INPUT -j REJECT --reject-with icmp-host-prohibited
    10. -A FORWARD -j REJECT --reject-with icmp-host-prohibited
    11. COMMIT

    在里面加入这2行:

    1. -A RH-Firewall-1-INPUT -m statestate NEW -m tcp -p tcp –dport 3306 -j ACCEPT
    2. -A RH-Firewall-1-INPUT -m statestate NEW -m udp -p udp –dport 3306 -j ACCEPT

    改为

    1. *filter
    2. :INPUT ACCEPT [0:0]
    3. :FORWARD ACCEPT [0:0]
    4. :OUTPUT ACCEPT [0:0]
    5. -A INPUT -m state --state RELATED,ESTABLISHED -j ACCEPT
    6. -A INPUT -p icmp -j ACCEPT
    7. -A INPUT -i lo -j ACCEPT
    8. -A INPUT -p tcp -m state --state NEW -m tcp --dport 22 -j ACCEPT
    9. -A RH-Firewall-1-INPUT -m statestate NEW -m tcp -p tcp –dport 3306 -j ACCEPT
    10. -A RH-Firewall-1-INPUT -m statestate NEW -m udp -p udp –dport 3306 -j ACCEPT
    11. -A INPUT -j REJECT --reject-with icmp-host-prohibited
    12. -A FORWARD -j REJECT --reject-with icmp-host-prohibited
    13. COMMIT

    如果该 iptables 配置文件 不存在,先执行 yum install iptables-services 安装

    执行 iptables 重启生效

    service iptables restart
    

    方式2:firewall-cmd(推荐)

    执行

    1. firewall-cmd --permanent --zone=public --add-port=3306/tcp
    2. firewall-cmd --permanent --zone=public --add-port=3306/udp

    这样就开放了相应的端口。

    执行

    firewall-cmd --reload 
    

    使最新的防火墙设置规则生效。

    MySQL 安全设置

    服务器启动后,可以执行

    mysql_secure_installation;
    

    看到如下提示

    1. [root@bogon software]# mysql_secure_installation
    2.  
    3. NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MySQL
    4. SERVERS IN PRODUCTION USE! PLEASE READ EACH STEP CAREFULLY!
    5.  
    6. In order to log into MySQL to secure it, we'll need the current
    7. password for the root user. If you've just installed MySQL, and
    8. you haven't set the root password yet, the password will be blank,
    9. so you should just press enter here.
    10.  
    11. Enter current password for root (enter for none):
    12.  

    此时输入 root 原始密码(初始化安装的话为空),接下来,为了安全,MySQL 会提示你重置 root 密码,移除其他用户账号,禁用 root 远程登录,移除 test 数据库,重新加载 privilege 表格等,你只需输入 y 继续执行即可。

    1. OK, successfully used password, moving on...
    2.  
    3. Setting the root password ensures that nobody can log into the MySQL
    4. root user without the proper authorisation.
    5.  
    6. Set root password? [Y/n] y
    7. New password:
    8. Re-enter new password:
    9. Password updated successfully!
    10. Reloading privilege tables..
    11. ... Success!
    12.  
    13.  
    14. By default, a MySQL installation has an anonymous user, allowing anyone
    15. to log into MySQL without having to have a user account created for
    16. them. This is intended only for testing, and to make the installation
    17. go a bit smoother. You should remove them before moving into a
    18. production environment.
    19.  
    20. Remove anonymous users? [Y/n] y
    21. ... Success!
    22.  
    23. Normally, root should only be allowed to connect from 'localhost'. This
    24. ensures that someone cannot guess at the root password from the network.
    25.  
    26. Disallow root login remotely? [Y/n] y
    27. ... Success!
    28.  
    29. By default, MySQL comes with a database named 'test' that anyone can
    30. access. This is also intended only for testing, and should be removed
    31. before moving into a production environment.
    32.  
    33. Remove test database and access to it? [Y/n] y
    34. - Dropping test database...
    35. ERROR 1008 (HY000) at line 1: Can't drop database 'test'; database doesn't exist
    36. ... Failed! Not critical, keep moving...
    37. - Removing privileges on test database...
    38. ... Success!
    39.  
    40. Reloading the privilege tables will ensure that all changes made so far
    41. will take effect immediately.
    42.  
    43. Reload privilege tables now? [Y/n] y
    44. ... Success!
    45.  
    46. All done! If you've completed all of the above steps, your MySQL
    47. installation should now be secure.
    48.  
    49. Thanks for using MySQL!
    50.  
    51.  
    52. Cleaning up...
    53.  

    至此,整个 MySQL 安装完成。

    远程访问设置

    创建一个普通用户 sa ,密码是 some_pass

    CREATE USER 'sa'@'%' IDENTIFIED BY 'some_pass';
    

    给这个用户授予 SELECT,INSERT,UPDATE,DELETE 的远程访问的权限,这个账号一般用于提供给实施的系统访问

    GRANT SELECT,INSERT,UPDATE,DELETE  ON *.* TO 'sa'@'%';
    

    创建一个管理员用户 admin 账号 ,密码是 some_pass

    CREATE USER 'admin'@'%' IDENTIFIED BY 'some_pass';
    

    给这个用户授予所有的远程访问的权限。这个用户主要用于管理整个数据库、备份、还原等操作。

    GRANT ALL  ON *.* TO 'admin'@'%';
    

    使授权立刻生效

    flush privileges;
    

    更改数据存放目录

    创建数据存放目录

    home 目录下建立 data 目录

    mkdir /home/data
    

    把 MySQL 服务进程停掉

    如果 MySQL 是启动的,要先关闭

    mysqladmin -u root -p shutdown
    

    移动数据到数据存放目录

    /var/lib/mysql 整个目录移到 /home/data,执行

    mv /var/lib/mysql /home/data
    

    这样就把 MySQL 的数据文件移动到了 /home/data/mysql 下

    修改 /etc/my.cnf 文件,

    1. [mysqld]
    2. datadir=/home/data/mysql
    3. socket=/home/data/mysql/mysql.sock
    4.  
    5. [mysql]
    6. socket=/home/data/mysql/mysql.sock

    修改权限

    chown -R mysql:mysql /home/data/mysql
    

    重启后,如果不能启动 MySQL 服务,执行

    vi  /etc/sysconfig/selinux
    

    调整

    SELINUX=permissive
    

    保存设置,执行 reboot 重启生效

    开机自起

    查看 MySQL 服务是否开机启动

    1. [root@localhost ~]# systemctl is-enabled mysql.service;echo $?
    2. enabled
    3. 0

    如果是 enabled 则说明是开机自动,如果不是,执行

    chkconfig --levels 235 mysqld on
    

    设置字符集

    一般的,为了支持中文,我们应该讲字符集设为 UTF-8, 执行

    SHOW VARIABLES LIKE 'character%';
    

    查看当前 MySQL 字符集

    1. mysql> SHOW VARIABLES LIKE 'character%';
    2. +--------------------------+----------------------------+
    3. | Variable_name | Value |
    4. +--------------------------+----------------------------+
    5. | character_set_client | utf8 |
    6. | character_set_connection | utf8 |
    7. | character_set_database | latin1 |
    8. | character_set_filesystem | binary |
    9. | character_set_results | utf8 |
    10. | character_set_server | latin1 |
    11. | character_set_system | utf8 |
    12. | character_sets_dir | /usr/share/mysql/charsets/ |
    13. +--------------------------+----------------------------+
    14. 8 rows in set (0.00 sec)

    可以看到默认服务器的字符器是 latin1 ,对中文不友好。
    修改 /etc/my.cnf 文件,添加字符集的设置

    1. [mysqld]
    2. character_set_server = utf8
    3.  
    4. [mysql]
    5. default-character-set = utf8

    重启 MySQL ,可以看到字符集已经修改了

    1. mysql> SHOW VARIABLES LIKE 'character%'
    2. -> ;
    3. +--------------------------+----------------------------+
    4. | Variable_name | Value |
    5. +--------------------------+----------------------------+
    6. | character_set_client | utf8 |
    7. | character_set_connection | utf8 |
    8. | character_set_database | utf8 |
    9. | character_set_filesystem | binary |
    10. | character_set_results | utf8 |
    11. | character_set_server | utf8 |
    12. | character_set_system | utf8 |
    13. | character_sets_dir | /usr/share/mysql/charsets/ |
    14. +--------------------------+----------------------------+
    15. 8 rows in set (0.00 sec)

    其他常用配置配置

    调整 MySQL 运行参数,修改 /etc/my.cnf 文件,常用配置如下:

    1. [mysqld]
    2. basedir = path # 使用给定目录作为根目录(安装目录)。
    3. datadir = path # 从给定目录读取数据库文件。
    4. pid-file = filename # 为mysqld程序指定一个存放进程ID的文件(仅适用于UNIX/Linux系统);
    5.  
    6.  
    7. socket = /tmp/mysql.sock # 为MySQL客户程序与服务器之间的本地通信指定一个套接字文件(Linux下默认是/var/lib/mysql/mysql.sock文件)
    8. port = 3306 # 指定MsSQL侦听的端口
    9. key_buffer = 384M # key_buffer是用于索引块的缓冲区大小,增加它可得到更好处理的索引(对所有读和多重写)。
    10. 索引块是缓冲的并且被所有的线程共享,key_buffer的大小视内存大小而定。
    11. table_cache = 512 # 为所有线程打开表的数量。增加该值能增加mysqld要求的文件描述符的数量。可以避免频繁的打开数据表产生的开销
    12. sort_buffer_size = 2M # 每个需要进行排序的线程分配该大小的一个缓冲区。增加这值加速ORDER BY或GROUP BY操作。
    13. 注意:该参数对应的分配内存是每连接独占!如果有100个连接,那么实际分配的总共排序缓冲区大小为100×6=600MB
    14. read_buffer_size = 2M # 读查询操作所能使用的缓冲区大小。和sort_buffer_size一样,该参数对应的分配内存也是每连接独享。
    15. query_cache_size = 32M # 指定MySQL查询结果缓冲区的大小
    16. read_rnd_buffer_size = 8M # 改参数在使用行指针排序之后,随机读用的。
    17. myisam_sort_buffer_size =64M # MyISAM表发生变化时重新排序所需的缓冲
    18. thread_concurrency = 8 # 最大并发线程数,取值为服务器逻辑CPU数量×2,如果CPU支持H.T超线程,再×2
    19. thread_cache = 8 # #缓存可重用的线程数
    20. skip-locking # 避免MySQL的外部锁定,减少出错几率增强稳定性。
    21. [mysqldump]
    22. max_allowed_packet =16M # 服务器和客户端之间最大能发送的可能信息包
    23.  
    24. [myisamchk]
    25. key_buffer = 256M
    26. sort_buffer = 256M
    27. read_buffer = 2M
    28. write_buffer = 2M

    其他可选参数:

    back_log = 384

    指定MySQL可能的连接数量。 当MySQL主线程在很短时间内接收到非常多的连接请求,该参数生效,主线程花费很短时间检查连接并且启动一个新线程。 back_log参数的值指出在MySQL暂时停止响应新请求之前的短时间内多少个请求可以被存在堆栈中。 如果系统在一个短时间内有很多连接,则需要增大该参数的值,该参数值指定到来的TCP/IP连接的侦听队列的大小。 试图设定back_log高于你的操作系统的限制将是无效的。默认值为50。对于Linux系统推荐设置为小于512的整数。

    max_connections = n

    MySQL服务器同时处理的数据库连接的最大数量(默认设置是100)。超过限制后会报 Too many connections 错误

    key_buffer_size = n

    用来存放索引区块的RMA值(默认设置是8M),增加它可得到更好处理的索引(对所有读和多重写)

    record_buffer:

    每个进行一个顺序扫描的线程为其扫描的每张表分配这个大小的一个缓冲区。 如果你做很多顺序扫描,你可能想要增加该值。默认数值是131072(128K)

    wait_timeout:

    服务器在关闭它之前在一个连接上等待行动的秒数。

    interactive_timeout:

    服务器在关闭它前在一个交互连接上等待行动的秒数。 一个交互的客户被定义为对 mysql_real_connect()使用 CLIENT_INTERACTIVE 选项的客户。 默认数值是28800,可以把它改为3600。

    skip-name-resolve

    禁止MySQL对外部连接进行DNS解析,使用这一选项可以消除MySQL进行DNS解析的时间。 但需要注意,如果开启该选项,则所有远程主机连接授权都要使用IP地址方式,否则MySQL将无法正常处理连接请求!

    log-slow-queries = slow.log

    记录慢查询,然后对慢查询一一优化

    skip-innodb

    skip-bdb

    关闭不需要的表类型,如果你需要,就不要加上这个

    备份、还原

    方法1:命令行

    备份

    mysqldump --socket=/home/data/mysql/mysql.sock --single-transaction=TRUE  -u root -p emsc > emsc.sql
    

    还原

    mysql --socket=/home/data/mysql/mysql.sock  -u root -p emsc < emsc.sql
    

    方法2:Workbench

    备份

    还原

    转至:http://www.centoscn.com/mysql/2016/0315/6844.html

  • 相关阅读:
    flex4的s:states和mx:states的区别
    Flash Builder快捷键
    PE经典DIY案例1:全解开方案让量产PE也能
    U+V2深度隐藏PE制作技术初探
    SQL Server存储过程的删除方法
    利用sql server直接创建日历
    推荐一个好的数据库工具Embarcadero DBArtisan
    css样式大全(整理版)
    asp.net Excel导入&导出
    SQL删除重复数据方法
  • 原文地址:https://www.cnblogs.com/Ai-Hen-Jiao-zhi/p/7minimysql.html
Copyright © 2011-2022 走看看