CentOS6.4下Mysql数据库的安装与配置

一、mysql简介

说到数据库,我们大多想到的是关系型数据库,比如mysql、oracle、sqlserver等等,这些数据库软件在windows上安装都非常的方便,在Linux上如果要安装数据库,咱不得不首先推荐的是mysql数据库了,而且Mysql数据库的第一个版本就是发行在Linux系统上的。

MySQL是一个关系型数据库管理系统,由瑞典MySQLAB公司开发,目前属于Oracle公司。MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。MySQL的SQL语言是用于访问数据库的最常用标准化语言。MySQL软件采用了双授权政策(本词条“授权政策”),它分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择MySQL作为网站数据库。由于其社区版的性能卓越,搭配PHP和Apache可组成良好的开发环境。

在Linux上安装mysql数据库,我们可以去其官网上下载mysql数据库的rpm包,http://dev.mysql.com/downloads/mysql/5.6.html#downloads,大家可以根据自己的操作系统去下载对应的数据库文件,目前最新的版本是5.6.10了。

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

二、卸载掉原有mysql

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

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

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

[root@xiaoluo~]#rpm-emysql  //普通删除模式

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

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

三、通过yum来进行mysql的安装

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

[root@xiaoluo~]#yumlist|grepmysql

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

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

[root@xiaoluo~]#yuminstall-ymysql-servermysqlmysql-deve

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

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

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

[root@xiaoluo~]#rpm-qimysql-server

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

四、mysql数据库的初始化及相关配置

我们在安装完mysql数据库以后,会发现会多出一个mysqld的服务,这个就是咱们的数据库服务,我们通过输入servicemysqldstart命令就可以启动我们的mysql服务。

注意:如果我们是第一次启动mysql服务,mysql服务器首先会进行初始化的配置,如:

复制代码

[root@xiaoluo~]#servicemysqldstart

初始化MySQL数据库:WARNING:Thehost'xiaoluo'couldnotbelookedupwithresolveip.

Thisprobablymeansthatyourlibclibrariesarenot100%compatible

withthisbinaryMySQLversion.TheMySQLdaemon,mysqld,shouldwork

normallywiththeexceptionthathostnameresolvingwillnotwork.

ThismeansthatyoushoulduseIPaddressesinsteadofhostnames

whenspecifyingMySQLprivileges!

InstallingMySQLsystemtables...

OK

Fillinghelptables...

OK

Tostartmysqldatboottimeyouhavetocopy

support-files/mysql.servertotherightplaceforyoursystem

PLEASEREMEMBERTOSETAPASSWORDFORTHEMySQLrootUSER!

Todoso,starttheserver,thenissuethefollowingcommands:

/usr/bin/mysqladmin-urootpassword'new-password'

/usr/bin/mysqladmin-uroot-hxiaoluopassword'new-password'

Alternativelyyoucanrun:

/usr/bin/mysql_secure_installation

whichwillalsogiveyoutheoptionofremovingthetest

databasesandanonymoususercreatedbydefault.Thisis

stronglyrecommendedforproductionservers.

Seethemanualformoreinstructions.

YoucanstarttheMySQLdaemonwith:

cd/usr;/usr/bin/mysqld_safe&

YoucantesttheMySQLdaemonwithmysql-test-run.pl

cd/usr/mysql-test;perlmysql-test-run.pl

Pleasereportanyproblemswiththe/usr/bin/mysqlbugscript!

[确定]

正在启动mysqld:[确定]

复制代码

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

[root@xiaoluo~]#servicemysqldrestart

停止mysqld:[确定]

正在启动mysqld:[确定]

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

[root@xiaoluo~]#chkconfig--list|grepmysqld

mysqld0:关闭1:关闭2:关闭3:关闭4:关闭5:关闭6:关闭

我们发现mysqld服务并没有开机自动启动,我们当然可以通过chkconfigmysqldon命令来将其设置成开机启动,这样就不用每次都去手动启动了

[root@xiaoluo~]#chkconfigmysqldon

[root@xiaoluo~]#chkconfig--list|grepmysql

mysqld0:关闭1:关闭2:启用3:启用4:启用5:启用6:关闭

mysql数据库安装完以后只会有一个root管理员账号,但是此时的root账号还并没有为其设置密码,在第一次启动mysql服务时,会进行数据库的一些初始化工作,在输出的一大串信息中,我们看到有这样一行信息:

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

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

[root@xiaoluo~]#mysqladmin-urootpassword'root'  //通过该命令给root账号设置密码为root

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

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

1./etc/my.cnf这是mysql的主配置文件

我们可以查看一下这个文件的一些信息

复制代码

[root@xiaoluoetc]#lsmy.cnf

my.cnf

[root@xiaoluoetc]#catmy.cnf

[mysqld]

datadir=/var/lib/mysql

socket=/var/lib/mysql/mysql.sock

user=mysql

#Disablingsymbolic-linksisrecommendedtopreventassortedsecurityrisks

symbolic-links=0

[mysqld_safe]

log-error=/var/log/mysqld.log

pid-file=/var/run/mysqld/mysqld.pid

复制代码

2./var/lib/mysqlmysql数据库的数据库文件存放位置

我们的mysql数据库的数据库文件通常是存放在了/ver/lib/mysql这个目录下

复制代码

[root@xiaoluo~]#cd/var/lib/mysql/

[root@xiaoluomysql]#ls-l

总用量20488

-rw-rw----.1mysqlmysql104857604月622:01ibdata1

-rw-rw----.1mysqlmysql52428804月622:01ib_logfile0

-rw-rw----.1mysqlmysql52428804月621:59ib_logfile1

drwx------.2mysqlmysql40964月621:59mysql  //这两个是mysql数据库安装时默认的两个数据库文件

srwxrwxrwx.1mysqlmysql04月622:01mysql.sock

drwx------.2mysqlmysql40964月621:59test  //这两个是mysql数据库安装时默认的两个数据库文件

复制代码

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

复制代码

创建一个我们自己的数据库:

mysql>createdatabasexiaoluo;

QueryOK,1rowaffected(0.00sec)

[root@xiaoluomysql]#ls-l

总用量20492

-rw-rw----.1mysqlmysql104857604月622:01ibdata1

-rw-rw----.1mysqlmysql52428804月622:01ib_logfile0

-rw-rw----.1mysqlmysql52428804月621:59ib_logfile1

drwx------.2mysqlmysql40964月621:59mysql

srwxrwxrwx.1mysqlmysql04月622:01mysql.sock

drwx------.2mysqlmysql40964月621:59test

drwx------.2mysqlmysql40964月622:15xiaoluo  //这个就是我们刚自己创建的xiaoluo数据库

[root@xiaoluomysql]#cdxiaoluo/

[root@xiaoluoxiaoluo]#ls

db.opt

复制代码

3./var/logmysql数据库的日志输出存放位置

我们的mysql数据库的一些日志输出存放位置都是在/var/log这个目录下

复制代码

[root@xiaoluoxiaoluo]#cd

[root@xiaoluo~]#cd/var/log

[root@xiaoluolog]#ls

amandacronmaillog-20130331spice-vdagent.log

anaconda.ifcfg.logcron-20130331mcelogspooler

anaconda.logcupsmessagesspooler-20130331

anaconda.program.logdirsrvmessages-20130331sssd

anaconda.storage.logdmesgmysqld.logtallylog

anaconda.syslogdmesg.oldntpstatstomcat6

anaconda.xlogdracut.logpiranhawpa_supplicant.log

anaconda.yum.loggdmpm-powersave.logwtmp

audithttpdpppXorg.0.log

boot.logibacm.logprelinkXorg.0.log.old

btmplastlogsaXorg.1.log

btmp-20130401libvirtsambaXorg.2.log

clusterlucisecureXorg.9.log

ConsoleKitmaillogsecure-20130331yum.log

复制代码

其中mysqld.log这个文件就是我们存放我们跟mysql数据库进行操作而产生的一些日志信息,通过查看该日志文件,我们可以从中获得很多信息

因为我们的mysql数据库是可以通过网络访问的,并不是一个单机版数据库,其中使用的协议是tcp/ip协议,我们都知道mysql数据库绑定的端口号是3306,所以我们可以通过netstat-anp命令来查看一下,Linux系统是否在监听3306这个端口号:

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

相关推荐