Linux下安装mysql全过程,包括删除。

本文详细介绍了在Linux系统中使用yum包管理器安装MySQL数据库的过程,包括卸载原有版本、通过yum列表查找可选版本、安装所需组件、初始化数据库、配置主要文件以及检查数据库文件存放位置和日志输出路径。同时,展示了如何通过netstat命令确认MySQL监听端口,确保数据库正常运行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

注:本文为转载,原文地址:http://zhangyouzhi.com/post/CentOS-install-MySQL/。

在Linux上安装MySQL数据库,我们可以去其官网上下载MySQL数据库的rpm包,

在这里我是通过yum来进行MySQL数据库的安装的,通过这种方式进行安装,可以将跟MySQL相关的一些服务、jar包都给我们安装好,所以省去了很多不必要的麻烦!!!

一、卸载掉原有MySQL

因为MySQL数据库在Linux上实在是太流行了,所以目前下载的主流Linux系统版本基本上都集成了MySQL数据库在里面,我们可以通过如下命令来查看我们的操作系统上是否已经安装了MySQL数据库。

1
[root@iZ23jffs85aZ /]# rpm -qa | grep mysql  // 这个命令就会查看该操作系统上是否已经安装了MySQL数据库

已经安装的会显示:

1
[root@iZ23jffs85aZ /]# rpm -qa | grep mysql
php-mysql-5.3.3-40.el6_6.x86_64
mysql-5.1.73-3.el6_5.x86_64
mysql-server-5.1.73-3.el6_5.x86_64
mysql-libs-5.1.73-3.el6_5.x86_64

有的话,我们就通过 rpm -e 命令 或者 rpm -e —nodeps 命令来卸载掉

1
[root@iZ23jffs85aZ /]# rpm -e mysql  // 普通删除模式
[root@iZ23jffs85aZ /]# rpm -e --nodeps mysql  // 强力删除模式,如果使用上面命令删除时,提示有依赖的其它文件,则用该命令可以对其进行强力删除

在删除完以后我们可以通过 rpm -qa | grep mysql 命令来查看mysql是否已经卸载成功!!

1
[root@iZ23jffs85aZ /]#  rpm -qa | grep mysql
php-mysql-5.3.3-40.el6_6.x86_64
mysql-libs-5.1.73-3.el6_5.x86_64

二、通过yum来进行MySQL的安装

我是通过yum的方式来进行MySQL的数据库安装,首先我们可以输入 yum list | grep mysql 命令来查看yum上提供的MySQL数据库可下载的版本:

1
[root@iZ23jffs85aZ /]# yum list | grep mysql

就可以得到yum服务器上MySQL数据库的可下载版本信息:

1
[root@iZ23jffs85aZ /]# yum list | grep mysql
mysql-libs.x86_64                          5.1.73-3.el6_5               @updates
php-mysql.x86_64                           5.3.3-40.el6_6               @updates
apr-util-mysql.x86_64                      1.3.9-3.el6_0.1              base    
asterisk-mysql.x86_64                      1.8.32.1-1.el6               epel    
bacula-director-mysql.x86_64               5.0.0-12.el6                 base    
bacula-storage-mysql.x86_64                5.0.0-12.el6                 base    
collectd-mysql.x86_64                      4.10.9-1.el6                 epel    
dmlite-plugins-mysql.x86_64                0.7.2-1.el6                  epel    
dovecot-mysql.x86_64                       1:2.0.9-8.el6_6.4            updates 
dpm-copy-server-mysql.x86_64               1.8.9-2.el6                  epel    
dpm-name-server-mysql.x86_64               1.8.9-2.el6                  epel    
dpm-server-mysql.x86_64                    1.8.9-2.el6                  epel    
dpm-srm-server-mysql.x86_64                1.8.9-2.el6                  epel    
dspam-mysql.x86_64                         3.10.2-6.el6                 epel    
exim-mysql.x86_64                          4.72-7.el6                   epel    
freeradius-mysql.x86_64                    2.1.12-6.el6                 base    
fts-mysql.i686                             3.2.30-1.el6                 epel    
fts-mysql.x86_64                           3.2.30-1.el6                 epel    
gnokii-smsd-mysql.x86_64                   0.6.30-2.el6                 epel    
holland-mysqldump.noarch                   1.0.10-3.el6                 epel    
holland-mysqllvm.noarch                    1.0.10-3.el6                 epel    
lfc-server-mysql.x86_64                    1.8.9-2.el6                  epel    
libdbi-dbd-mysql.x86_64                    0.8.3-5.1.el6                base    
libnss-mysql.i686                          1.5-12.el6                   epel    
libnss-mysql.x86_64                        1.5-12.el6                   epel    
libodb-mysql.i686                          2.3.0-1.el6                  epel    
libodb-mysql.x86_64                        2.3.0-1.el6                  epel    
libodb-mysql-devel.i686                    2.3.0-1.el6                  epel    
libodb-mysql-devel.x86_64                  2.3.0-1.el6                  epel    
lighttpd-mod_mysql_vhost.x86_64            1.4.35-1.el6                 epel    
lua-sql-mysql.x86_64                       2.1.1-7.el6                  epel    
mod_auth_mysql.x86_64                      1:3.0.0-11.el6_0.1           base    
mydns-mysql.x86_64                         1.2.8.31-1.el6               epel    
mysql.x86_64                               5.1.73-3.el6_5               base    
mysql++.i686                               3.0.9-3.el6                  epel    
mysql++.x86_64                             3.0.9-3.el6                  epel    
mysql++-devel.i686                         3.0.9-3.el6                  epel    
mysql++-devel.x86_64                       3.0.9-3.el6                  epel    
mysql++-manuals.x86_64                     3.0.9-3.el6                  epel    
mysql-bench.x86_64                         5.1.73-3.el6_5               base    
mysql-connector-java.noarch                1:5.1.17-6.el6               base    
mysql-connector-odbc.x86_64                5.1.5r1144-7.el6             base    
mysql-connector-python.noarch              1.1.6-1.el6                  epel    
mysql-devel.i686                           5.1.73-3.el6_5               base    
mysql-devel.x86_64                         5.1.73-3.el6_5               base    
mysql-embedded.i686                        5.1.73-3.el6_5               base    
mysql-embedded.x86_64                      5.1.73-3.el6_5               base    
mysql-embedded-devel.i686                  5.1.73-3.el6_5               base    
mysql-embedded-devel.x86_64                5.1.73-3.el6_5               base    
mysql-libs.i686                            5.1.73-3.el6_5               base    
mysql-mmm.noarch                           2.2.1-2.el6                  epel    
mysql-mmm-agent.noarch                     2.2.1-2.el6                  epel    
mysql-mmm-monitor.noarch                   2.2.1-2.el6                  epel    
mysql-mmm-tools.noarch                     2.2.1-2.el6                  epel    
mysql-proxy.i686                           0.8.5-1.el6                  epel    
mysql-proxy.x86_64                         0.8.5-1.el6                  epel    
mysql-proxy-devel.i686                     0.8.5-1.el6                  epel    
mysql-proxy-devel.x86_64                   0.8.5-1.el6                  epel    
mysql-server.x86_64                        5.1.73-3.el6_5               base    
mysql-test.x86_64                          5.1.73-3.el6_5               base    
mysql-utilities.noarch                     1.3.6-1.el6                  epel    
mysqlreport.noarch                         3.5-4.el6                    epel    
mysqltuner.noarch                          1.1.1-1.el6                  epel    
nagios-plugins-mysql.x86_64                1.4.16-10.el6                epel    
ndoutils-mysql.x86_64                      1.5.2-1.el6                  epel    
nodejs-mysql.noarch                        2.0.0-alpha9.2.el6.2         epel    
opensips-mysql.x86_64                      1.7.2-2.el6                  epel    
owncloud-mysql.noarch                      6.0.6-1.el6                  epel    
pam_mysql.i686                             1:0.7-0.12.rc1.el6           epel    
pam_mysql.x86_64                           1:0.7-0.12.rc1.el6           epel    
pdns-backend-mysql.x86_64                  3.3.1-1.el6                  epel    
perl-Class-DBI-mysql.noarch                1.00-7.el6                   epel    
php-pear-MDB2-Driver-mysql.noarch          1.5.0-0.8.b4.el6             epel    
php-pear-MDB2-Driver-mysqli.noarch         1.5.0-0.8.b4.el6             epel    
poco-mysql.i686                            1.4.2p1-2.el6                epel    
poco-mysql.x86_64                          1.4.2p1-2.el6                epel    
proftpd-mysql.x86_64                       1.3.3g-4.el6                 epel    
pyicq-t-mysql.noarch                       0.8.1.5-5.el6                epel    
qt-mysql.i686                              1:4.6.2-28.el6_5             base    
qt-mysql.x86_64                            1:4.6.2-28.el6_5             base    
qt5-qtbase-mysql.i686                      5.4.0-4.el6                  epel    
qt5-qtbase-mysql.x86_64                    5.4.0-4.el6                  epel    
rekall-mysql.i686                          2.4.6-13.el6                 epel    
rekall-mysql.x86_64                        2.4.6-13.el6                 epel    
root-sql-mysql.x86_64                      5.34.24-1.el6                epel    
rsyslog-mysql.x86_64                       5.8.10-10.el6_6              updates 
rsyslog7-mysql.x86_64                      7.4.10-3.el6_6               updates 
ruby-mysql.x86_64                          2.8.2-1.el6                  epel    
soci-mysql.i686                            3.2.2-2.el6                  epel    
soci-mysql.x86_64                          3.2.2-2.el6                  epel    
soci-mysql-devel.i686                      3.2.2-2.el6                  epel    
soci-mysql-devel.x86_64                    3.2.2-2.el6                  epel    
tcl-mysqltcl.x86_64                        3.05-8.el6                   epel    
trytond-mysql.noarch                       1.8.10-1.el6                 epel    
voms-mysql-plugin.x86_64                   3.1.6-1.el6                  epel    
zabbix-proxy-mysql.x86_64                  1.8.22-1.el6                 epel    
zabbix-server-mysql.x86_64                 1.8.22-1.el6                 epel    
zabbix-web-mysql.noarch                    1.8.22-1.el6                 epel    
zabbix20-proxy-mysql.x86_64                2.0.13-2.el6                 epel    
zabbix20-server-mysql.x86_64               2.0.13-2.el6                 epel    
zabbix20-web-mysql.noarch                  2.0.13-2.el6                 epel    
zabbix22-dbfiles-mysql.noarch              2.2.1-5.el6                  epel    
zabbix22-proxy-mysql.x86_64                2.2.1-5.el6                  epel    
zabbix22-server-mysql.x86_64               2.2.1-5.el6                  epel    
zabbix22-web-mysql.noarch                  2.2.1-5.el6                  epel    
[root@iZ23jffs85aZ /]#

然后我们可以通过输入 yum install -y mysql-server mysql mysql-devel 命令将mysql mysql-server mysql-devel都安装好(注意:安装MySQL时我们并不是安装了MySQL客户端就相当于安装好了MySQL数据库了,我们还需要安装mysql-server服务端才行)

1
[root@iZ23jffs85aZ /]# yum install -y mysql-server mysql mysql-deve

在等待了一番时间后,yum会帮我们选择好安装MySQL数据库所需要的软件以及其它附属的一些软件。

我们发现,通过yum方式安装MySQL数据库省去了很多没必要的麻烦,当出现下面的结果时,就代表MySQL数据库安装成功了。

此时我们可以通过如下命令,查看刚安装好的mysql-server的版本

1
[root@iZ23jffs85aZ /]# rpm -qi mysql-server

1
[root@iZ23jffs85aZ /]# rpm -qi mysql-server
Name        : mysql-server                 Relocations: (not relocatable)
Version     : 5.1.73                            Vendor: CentOS
Release     : 3.el6_5                       Build Date: Thu 13 Feb 2014 03:42:39 AM CST
Install Date: Thu 12 Mar 2015 02:50:14 PM CST      Build Host: c6b9.bsys.dev.centos.org
Group       : Applications/Databases        Source RPM: mysql-5.1.73-3.el6_5.src.rpm
Size        : 25882723                         License: GPLv2 with exceptions
Signature   : RSA/SHA1, Thu 13 Feb 2014 03:48:08 AM CST, Key ID 0946fca2c105b9de
Packager    : CentOS BuildSystem <http://bugs.centos.org>
URL         : http://www.mysql.com
Summary     : The MySQL server and related files
Description :
MySQL is a multi-user, multi-threaded SQL database server. MySQL is a
client/server implementation consisting of a server daemon (mysqld)
and many different client programs and libraries. This package contains
the MySQL server and some accompanying files and directories.
[root@iZ23jffs85aZ /]#

我们安装的mysql-server并不是最新版本,如果你想尝试最新版本,那就去mysql官网下载rpm包安装就行了,至此我们的MySQL数据库已经安装完成了。

三、MySQL数据库的初始化及相关配置

我们在安装完MySQL数据库以后,会发现会多出一个mysqld的服务,这个就是咱们的数据库服务,我们通过输入 service mysqld start 命令就可以启动我们的MySQL服务。
注意:如果我们是第一次启动MySQL服务,MySQL服务器首先会进行初始化的配置,如:

1
[root@iZ23jffs85aZ /]# service mysqld start
Initializing MySQL database:  Installing MySQL system tables...
OK
Filling help tables...
OK

To start mysqld at boot time you have to copy
support-files/mysql.server to the right place for your system

PLEASE REMEMBER TO SET A PASSWORD FOR THE MySQL root USER !
To do so, start the server, then issue the following commands:

/usr/bin/mysqladmin -u root password 'new-password'
/usr/bin/mysqladmin -u root -h iZ23jffs85aZ password 'new-password'

Alternatively you can run:
/usr/bin/mysql_secure_installation

which will also give you the option of removing the test
databases and anonymous user created by default.  This is
strongly recommended for production servers.

See the manual for more instructions.

You can start the MySQL daemon with:
cd /usr ; /usr/bin/mysqld_safe &

You can test the MySQL daemon with mysql-test-run.pl
cd /usr/mysql-test ; perl mysql-test-run.pl

Please report any problems with the /usr/bin/mysqlbug script!

                                                           [  OK  ]
Starting mysqld:                                           [  OK  ]
[root@iZ23jffs85aZ /]#

这时我们会看到第一次启动MySQL服务器以后会提示非常多的信息,目的就是对MySQL数据库进行初始化操作,当我们再次重新启动MySQL服务时,就不会提示这么多信息了,如:

1
[root@iZ23jffs85aZ /]# service mysqld restart
Stopping mysqld:                                           [  OK  ]
Starting mysqld:                                           [  OK  ]
[root@iZ23jffs85aZ /]#

我们在使用MySQL数据库时,都得首先启动mysqld服务,我们可以 通过 chkconfig —list | grep mysqld 命令来查看mysql服务是不是开机自动启动,如:

1
[root@iZ23jffs85aZ /]# chkconfig --list | grep mysqld
mysqld         	0:off	1:off	2:off	3:off	4:off	5:off	6:off
[root@iZ23jffs85aZ /]#

我们发现mysqld服务并没有开机自动启动,我们当然可以通过 chkconfig mysqld on 命令来将其设置成开机启动,这样就不用每次都去手动启动了。
MySQL数据库安装完以后只会有一个root管理员账号,但是此时的root账号还并没有为其设置密码,在第一次启动mysql服务时,会进行数据库的一些初始化工作,在输出的一大串信息中,我们看到有这样一行信息 :

1
/usr/bin/mysqladmin -u root password 'new-password'  // 为root账号设置密码

所以我们可以通过 该命令来给我们的root账号设置密码(注意:这个root账号是mysql的root账号,非Linux的root账号)

1
[root@iZ23jffs85aZ /]# mysqladmin -u root password 'root'  // 通过该命令给root账号设置密码为 root

此时我们就可以通过 mysql -u root -p 命令来登录我们的mysql数据库了。

1
[root@iZ23jffs85aZ /]# mysqladmin -u root password 'root'
[root@iZ23jffs85aZ /]# mysql -u root -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 3
Server version: 5.1.73 Source distribution

Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| test               |
+--------------------+
3 rows in set (0.00 sec)

mysql>

四、mysql数据库的主要配置文件

  1. /etc/my.cnf 这是mysql的主配置文件
    我们可以查看一下这个文件的一些信息:

    1
    [root@iZ23jffs85aZ /]# cd /etc
    [root@iZ23jffs85aZ etc]# ls my.cnf 
    my.cnf
    [root@iZ23jffs85aZ etc]# cat my.cnf 
    [mysqld]
    datadir=/var/lib/mysql
    socket=/var/lib/mysql/mysql.sock
    user=mysql
    # Disabling symbolic-links is recommended to prevent assorted security risks
    symbolic-links=0
    
    [mysqld_safe]
    log-error=/var/log/mysqld.log
    pid-file=/var/run/mysqld/mysqld.pid
    [root@iZ23jffs85aZ etc]#
  2. /var/lib/mysql mysql数据库的数据库文件存放位置
    我们的mysql数据库的数据库文件通常是存放在了/ver/lib/mysql这个目录下

    1
    [root@iZ23jffs85aZ /]# cd /var/lib/mysql
    [root@iZ23jffs85aZ mysql]# ls -l
    total 20488
    -rw-rw---- 1 mysql mysql 10485760 Mar 12 14:58 ibdata1
    -rw-rw---- 1 mysql mysql  5242880 Mar 12 14:58 ib_logfile0
    -rw-rw---- 1 mysql mysql  5242880 Mar 12 14:57 ib_logfile1
    drwx------ 2 mysql mysql     4096 Mar 12 14:57 mysql  // 这两个是mysql数据库安装时默认的两个数据库文件
    srwxrwxrwx 1 mysql mysql        0 Mar 12 14:58 mysql.sock
    drwx------ 2 mysql mysql     4096 Mar 12 14:57 test   // 这两个是mysql数据库安装时默认的两个数据库文件
    [root@iZ23jffs85aZ mysql]#

我们可以自己创建一个数据库,来验证一下该数据库文件的存放位置

1
[root@iZ23jffs85aZ mysql]# cd /
[root@iZ23jffs85aZ /]# mysql -u root -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 4
Server version: 5.1.73 Source distribution

Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

//创建新的数据库xiaobaobao
mysql> create database xiaobaobao;
Query OK, 1 row affected (0.00 sec)

mysql> quit
Bye
[root@iZ23jffs85aZ /]# cd /var/lib/mysql/
[root@iZ23jffs85aZ mysql]# ls -l
total 20492
-rw-rw---- 1 mysql mysql 10485760 Mar 12 14:58 ibdata1
-rw-rw---- 1 mysql mysql  5242880 Mar 12 14:58 ib_logfile0
-rw-rw---- 1 mysql mysql  5242880 Mar 12 14:57 ib_logfile1
drwx------ 2 mysql mysql     4096 Mar 12 14:57 mysql
srwxrwxrwx 1 mysql mysql        0 Mar 12 14:58 mysql.sock
drwx------ 2 mysql mysql     4096 Mar 12 14:57 test
drwx------ 2 mysql mysql     4096 Mar 12 15:14 xiaobaobao	// 这个就是我们刚自己创建的xiaobaobao数据库
[root@iZ23jffs85aZ mysql]#

  1. /var/log mysql数据库的日志输出存放位置
    我们的mysql数据库的一些日志输出存放位置都是在/var/log这个目录下
    1
    [root@iZ23jffs85aZ mysql]# cd /var/log
    [root@iZ23jffs85aZ log]# ls
    audit          cron-20150308     maillog-20150222   ntp.log          secure-20150222   vmstart.log
    boot.log       dmesg             maillog-20150301   ntpstats         secure-20150301   wtmp
    btmp           dmesg.old         maillog-20150308   prelink          secure-20150308   yum.log
    btmp-20150301  dracut.log        messages           rdate.log        spooler           yum.log-20150101
    ConsoleKit     gshell.log        messages-20150215  repair.log       spooler-20150215
    cron           httpd             messages-20150222  rsyncd.log       spooler-20150222
    cron-20150215  lastlog           messages-20150301  sa               spooler-20150301
    cron-20150222  maillog           messages-20150308  secure           spooler-20150308
    cron-20150301  maillog-20150215  mysqld.log         secure-20150215  tallylog
    [root@iZ23jffs85aZ log]#

其中mysqld.log 这个文件就是我们存放我们跟mysql数据库进行操作而产生的一些日志信息,通过查看该日志文件,我们可以从中获得很多信息。
因为我们的mysql数据库是可以通过网络访问的,并不是一个单机版数据库,其中使用的协议是 tcp/ip 协议,我们都知道mysql数据库绑定的端口号是 3306 ,所以我们可以通过 netstat -anp 命令来查看一下,Linux系统是否在监听 3306 这个端口号:

1
[root@iZ23jffs85aZ log]# netstat -anp | more
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address               Foreign Address             
......
tcp        0      0 0.0.0.0:3306                0.0.0.0:*                   LISTEN      7459/mysqld         
......

结果如上所示,Linux系统监听的3306端口号就是我们的mysql数据库。

如有侵权,请联系我:534624117@qq.com

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值