mysql-5.7.xx在lcentos7下的安装以及mysql在windows以及linux上的性能差异

   2023-02-09 学习力0
核心提示:前言:在centos上安装mysql,整整折腾了将近一天,因为是第一次安装,的确是踩了不少坑,这里详细记录下来,方便各位有同样需求的小伙伴参考。该选择什么版本?mysql5.7有很多小版本,但是,从5.7.18版本开始,是一个分界线,因为从5.7.18版本及以后版本,安

前言:

在centos上安装mysql,整整折腾了将近一天,因为是第一次安装,的确是踩了不少坑,这里详细记录下来,方便各位有同样需求的小伙伴参考。

该选择什么版本?

mysql5.7有很多小版本,但是,从5.7.18版本开始,是一个分界线,因为从5.7.18版本及以后版本,安装包里面的的support-files文件夹下,便没有default.cnf了,所以这里导致5.7.18以前的版本和5.7.18及以后版本的安装,是略有不同的。我这里安装选择5.7.28版本,当然,如果您选择其他版本安装也是可以的,但是我建议还是选择5.7.18以后的版本。

安装准备

mysql官网同时提供了32位版本和64位版本的安装包,我这里centos是64位的,所以这里下载的是64位的mysql安装包。【注意:如果懵懵懂懂的就去安装,在64位系统上安装了32位的mysql,安装过程中会报各种错误,如果您再去百度这些错误去解决,就走了一个大大的弯路,很遗憾,笔者就犯了这个错误,折腾了一个小时,才又重新下载64位的安装包,引以为戒啊】

网盘地址:  链接:https://pan.baidu.com/s/1PgMzZITE4BciEYUEh_Sphg    提取码:2n5t    【网盘速度很慢,也可以用这个地址:http://mirrors.sohu.com/mysql/MySQL-5.7/mysql-5.7.28-linux-glibc2.12-x86_64.tar.gz

 

具体安装过程

1.卸载自带的mariadb

 执行:

 rpm -qa | grep mariadb

mysql-5.7.xx在lcentos7下的安装以及mysql在windows以及linux上的性能差异

 

 

发现系统已经默认安装了mariadb,根据系统查询出来的信息,进行删除

    执行:

 yum remove mariadb-libs-5.5.56-2.e17.x86_64 

 

 

2.卸载已经安装的mysql

执行:

 

rpm -qa | grep mysql

 

 

mysql-5.7.xx在lcentos7下的安装以及mysql在windows以及linux上的性能差异

 

 

 我的系统以前没有安装过mysql,所以不需要做任何操作。 如果您的系统以前安装过mysql,可以参考centos下彻底删除mysql这篇文章进行彻底删除

 

 

3.下载mysql-5.7.28安装包并解压

您可以用我百度网盘里面的地址拷贝下来,并粘贴到linux服务器相应地址,也可以使用该地址:http://mirrors.sohu.com/mysql/MySQL-5.7/mysql-5.7.28-linux-glibc2.12-x86_64.tar.gz

关于安装地址的选择,我们显然需要将mysql安装在大磁盘里,

执行脚本:

df -h

 

mysql-5.7.xx在lcentos7下的安装以及mysql在windows以及linux上的性能差异

 

 

 根据脚本执行结果来看,我的系统/home挂载点空间较大,所以我将mysql安装在/home 下【您可以根据您的需求安装在其他位置,如/usr/local也是不错的选择】

依次执行脚本:

cd /home            
mkdir mysql   
cd mysql      
wget http://mirrors.sohu.com/mysql/MySQL-5.7/mysql-5.7.28-linux-glibc2.12-x86_64.tar.gz

 

mysql-5.7.xx在lcentos7下的安装以及mysql在windows以及linux上的性能差异

tar -zxvf mysql-5.7.28-linux-glibc2.12-x86_64.tar.gz      
mv  mysql-5.7.28-linux-glibc2.12-x86_64   mysql-5.7.28  

 

    执行ls脚本,可以发现mysql文件夹下已经有了mysql-5.7.28文件夹

mysql-5.7.xx在lcentos7下的安装以及mysql在windows以及linux上的性能差异

 


  4.在/usr/local/目录下创建到/home/mysql/mysql-5.7.28的软链接


cd /usr/local                       
ln -s /home/mysql/mysql-5.7.28 mysql  

mysql-5.7.xx在lcentos7下的安装以及mysql在windows以及linux上的性能差异

 

 

 

5.添加mysql用户,修改mysql目录权限,并用此用户执行应用
useradd -s /bin/false -M mysql     
cd /home/mysql                   
chown -R mysql:mysql mysql-5.7.28 

 


6.拷贝配置文件,将mysql的配置文件拷贝为/etc/目录下的my.cnf,并修改配置文件
这里特别注意:/etc文件夹下并没有my.cnf文件,没有关系,我们直接执行:

vi /etc/my.cnf 

 


并下下面的内容拷贝到编辑框里面,并执行 :wq 进行保存
 
[mysqld]
# binlog 配置
log-bin=/usr/local/mysql/logs/mysql-bin.log
expire-logs-days=14
max-binlog-size=500M
server-id=1
# GENERAL
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
socket=/usr/local/mysql/mysql.sock
user=mysql
default-storage-engine=InnoDB
character-set-server=utf8lower_case_table_names = 1explicit_defaults_for_timestamp=true
[mysqld_safe]
log-error=/usr/local/mysql/mysql-error.log
pid-file=/usr/local/mysql/mysqld.pid
[client]
socket=/usr/local/mysql/mysql.sock
[mysql]
default-character-set=utf8
socket=/usr/local/mysql/mysql.sock

 

7.安装mysql,进入mysql目录执行以下命令

yum -y install autoconf          
cd /home/mysql/mysql-5.7.28     
bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data  

mysql-5.7.xx在lcentos7下的安装以及mysql在windows以及linux上的性能差异

 


执行脚本如果报以上错误,请执行以下脚本解决:


mkdir logs
touch mysql-bin.index
chgrp -R mysql /home/mysql/mysql-5.7.28

 


再次执行:

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

 

mysql-5.7.xx在lcentos7下的安装以及mysql在windows以及linux上的性能差异

 

 

 出现以上提示,则表示安装成功,记录下默认密码:fa&fJH-Wt0FQ 

 

8.拷贝启动程序,将mysql的启动程序拷贝到/etc/init.d/目录下


cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

 

9.安装完,启动mysql服务
service mysqld start

 

 mysql-5.7.xx在lcentos7下的安装以及mysql在windows以及linux上的性能差异

 

 

 出现以上错误,说明日志文件没有创建,创建日志文件并修改权限即可

cd /home/mysql/mysql-5.7.28
touch mysql-error.log
chown mysql:mysql mysql-error.log

 

 

再次执行: 

service mysqld start
mysql-5.7.xx在lcentos7下的安装以及mysql在windows以及linux上的性能差异

 


 说明mysql已经安装成功

 

10.配置环境变量,编辑/etc/profile,方便在任何地方用mysql命令


vim /etc/profile 
在文件的最后面加入
#mysql
export MYSQL_HOME=/usr/local/mysql
export PATH=$PATH:$MYSQL_HOME/bin

 

mysql-5.7.xx在lcentos7下的安装以及mysql在windows以及linux上的性能差异

 

 重新编译:


source /etc/profile

11.登录mysql,修改密码

首次登录没有密码,提示输入密码时,输入第7步安装时生成的密码:fa&fJH-Wt0FQ 

mysql -uroot -p

mysql-5.7.xx在lcentos7下的安装以及mysql在windows以及linux上的性能差异

 


使用alter user重置密码:

mysql> alter user 'root'@'localhost' identified by '******';
mysql> flush privileges;

 

配置远程访问:

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '******' WITH GRANT OPTION;

 

至此,mysql安装完成。

 

 

后记:

因为对linux钻研的不是十分透彻,所以,一直有抵触心理,以至于安装mysql时,百度了一下看看mysql在windows上和linux上的差异,大部分人说的是差异并不大。 我妥协了,把mysql安装在了windows server 2016 上,但是性能并不十分出众,虽然也勉强能用,但是绝对不是最优。 身为资深码农,就是不能怕困难,所以我决定拥抱linux,把mysql装在linux上,并比较性能差异:

 

指标 windows server 2016下时间(16核32GB) cnetos7下时间(16核32GB)
1200万+数据取count的时间 10.711秒 2.939秒
600万+数据取count时间 6.216秒 1.303
175万+数据取count的时间 3.025秒 0.671秒
1200万+数据创建1个索引时间 1300秒 237秒
600万+数据创建1个索引时间 700秒 120秒
175万+数据创建1个索引时间 130秒 28秒

 

         经过比较得出的结论,同样的配置,linux下的mysql各项性能指标,是windows的3-7倍之间。  所以,身为程序员,我们要选择最优的,不要妥协,不要将就,不要纠结,mysql就装在linux上吧,人家刚诞生时,就是装在linux上的,linux和mysql本身就是天生一对,我们不要拆散他。

 

 
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • 【强转】QEMU+GDB调试linux内核全过程
    【强转】QEMU+GDB调试linux内核全过程
    昨天更新了一篇名为《QEMU+GDB调试linux内核全过程》[link][https://blog.csdn.net/weixin_37867857/article/details/88138432]的博客,发现排版比较混乱,而且思维也比较混乱。咋一看下来简直是惨不忍睹,而且会给读者在安装过程中一种云里雾里的感觉,加上
    03-08
  • Linux下Bochs,NASM安装和使用 linux bom
    Linux下Bochs,NASM安装和使用 linux bom
    以Ubuntu为例,先更新一下:sudo apt-get updatesudo apt-get upgrade然后安装Bochs环境:sudo apt-get install build-essential xorg-dev libgtk2.0-dev安装NASMNASM官网下载,这以nasm-2.14.02.tar.gz为例:用tar zxvf nasm-2.14.02.tar.gz解压后编译安装cd
    03-08
  • 把玩Alpine linux(一):安装
    把玩Alpine linux(一):安装
    导读Alpine Linux是一个面向安全应用的轻量级Linux发行版。它采用了musl libc和busybox以减小系统的体积和运行时资源消耗,同时还提供了自己的包管理工具apk。Alpine 的内核都打了grsecurity/PaX补丁,并且所有的程序都编译为Position Independent Executabl
    03-08
  • 日志审计与分析实验三(rsyslog服务器端和客户端配置)(Linux日志收集)
    日志审计与分析实验三(rsyslog服务器端和客户
     Linux日志收集一、实验目的:1、掌握rsyslog配置方法2、配置rsyslog服务收集其他Linux服务器日志:C/S架构:客户端将其日志上传到服务器端,通过对服务器端日志的查询,来实现对其他客户端的日志进行集中管理;下面实现就是通过两套机器来实现,(server:19
    03-08
  • Linux学习系列--如何在Linux中进行文件的管理
    Linux学习系列--如何在Linux中进行文件的管理
    文件在常见的Linux的文件系统中,经常使用能了解到的文件管理系统是分为多个文件夹进行管理的。如何查看文件路径 pwd ,在文件目录中,会有一个点(.)代表的是当前目录,两个点(..)代表的是当前目录的上层目录在Linux下,所有以点开始的文件都是“隐藏文件
    03-08
  • [JetBrains] 我想在 Linux 上使用 macOS 键绑定!
    [JetBrains] 我想在 Linux 上使用 macOS 键绑定
    很高兴认识你,我的名字是kitakkun。我最近开始实习,是工程界的新手。顺便说一句,这是我的第一篇文章。你最喜欢的操作系统是什么?视窗?苹果系统?还是Linux?我将它们全部用于不同的目的,但感觉就像 macOS ≒ LinuxWindows。一两个月前,我最喜欢 Linux
    03-08
  • linux 配置Socks51
    linux 配置Socks51
    ***大家耳熟能详,但是socks用到的人比较少,那什么是socks呢?请看第二段或者百度百科,socks分别有4和5两个版本,现在5为主流。工作中经常用***访问国外,但是同时国内的速度又慢了,让人很纠结,实际上这个时候可以考虑使用socks。指定某一个程序使用国外s
    02-10
  • linux下如何单独编译设备树? linux设备树是什
    答: make vendor/device_name.dtb  如: make freescale/fsl-1043a-rdb.dtb
    02-10
  • linux下mysql开启远程访问权限及防火墙开放3306端口
    linux下mysql开启远程访问权限及防火墙开放3306
    开启mysql的远程访问权限默认mysql的用户是没有远程访问的权限的,因此当程序跟数据库不在同一台服务器上时,我们需要开启mysql的远程访问权限。主流的有两种方法,改表法和授权法。相对而言,改表法比较容易一点,个人也是比较倾向于使用这种方法,因此,这
    02-10
  • 移植linux3.7到nuc900系列开发板遇到的问题
    通过移植学习linux新版本内核,大概了解一下内核变化。记录一下移植过程中遇到的问题或值得注意的地方。1,添加一款arm9芯片的支持首先修改\arch\arm\tools\mach-types文件添加一行w90p950evbMACH_W90P950EVBW90P950EVB同目录下的脚本文件在编译内核时会根据
    02-10
点击排行