一、MysqL简介
说到数据库,我们大多想到的是关系型数据库,比如MysqL、oracle、sqlserver等等,这些数据库软件在windows上安装都非常的方便,在Linux上如果要安装数据库,咱不得不首先推荐的是MysqL数据库了,而且MysqL数据库的第一个版本就是发行在Linux系统上的。
MysqL是一个关系型数据库管理系统,由瑞典MysqL AB公司开发,目前属于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 | grep MysqL
// 上面这个命令就会查看该操作系统上是否已经安装了MysqL数据库
有的话,我们就通过 rpm -e 命令 或者 rpm -e –nodeps 命令来卸载掉
如果使用上面命令删除时,提示有依赖的其它文件,则用该命令可以对其进行强力删除
在删除完以后我们可以通过 rpm -qa | grep MysqL
命令来查看MysqL是否已经卸载成功!!
三、通过yum来进行MysqL的安装
我是通过yum的方式来进行MysqL的数据库安装,首先我们可以输入 yum list | grep MysqL
命令来查看yum上提供的MysqL数据库可下载的版本:
- [root@xiaoluo ~]# yum list | grep MysqL
然后我们可以通过输入 yum install -y MysqL-server MysqL MysqL-devel 命令将MysqL MysqL-server MysqL-devel都安装好(注意:安装MysqL时我们并不是安装了MysqL客户端就相当于安装好了MysqL数据库了,我们还需要安装MysqL-server服务端才行)
在等待了一番时间后,yum会帮我们选择好安装MysqL数据库所需要的软件以及其它附属的一些软件
我们发现,通过yum方式安装MysqL数据库省去了很多没必要的麻烦,当出现下面的结果时,就代表MysqL数据库安装成功了
此时我们可以通过如下命令,查看刚安装好的MysqL-server的版本
- [root@xiaoluo ~]# rpm -qi MysqL-server
我们安装的MysqL-server并不是最新版本,如果你想尝试最新版本,那就去MysqL官网下载rpm包安装就行了,至此我们的MysqL数据库已经安装完成了。
我们在安装完MysqL数据库以后,会发现会多出一个MysqLd的服务,这个就是咱们的数据库服务,我们通过输入 service MysqLd start 命令就可以启动我们的MysqL服务。
注意:如果我们是第一次启动MysqL服务,MysqL服务器首先会进行初始化的配置,如:
- [root@xiaoluo ~]# service MysqLd start
- 初始化 MysqL 数据库: WARNING: The host 'xiaoluo' could not be looked up with resolveip.
- This probably means that your libc libraries are not 100 % compatible
- with this binary MysqL version. The MysqL daemon,MysqLd,should work
- normally with the exception that host name resolving will not work.
- This means that you should use IP addresses instead of hostnames
- when specifying MysqL privileges !
- 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 xiaoluo 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!
正在启动 MysqLd:
这时我们会看到第一次启动MysqL服务器以后会提示非常多的信息,目的就是对MysqL数据库进行初始化操作,当我们再次重新启动MysqL服务时,就不会提示这么多信息了,如:
我们在使用MysqL数据库时,都得首先启动MysqLd服务,我们可以 通过 chkconfig --list | grep MysqLd
命令来查看MysqL服务是不是开机自动启动,如:
- [root@xiaoluo ~]# chkconfig --list | grep MysqLd
MysqLd 0:关闭 1:关闭 2:关闭 3:关闭 4:关闭 5:关闭 6:关闭
我们发现MysqLd服务并没有开机自动启动,我们当然可以通过 chkconfig MysqLd on
命令来将其设置成开机启动,这样就不用每次都去手动启动了
MysqL数据库安装完以后只会有一个root管理员账号,但是此时的root账号还并没有为其设置密码,在第一次启动MysqL服务时,会进行数据库的一些初始化工作,在输出的一大串信息中,我们看到有这样一行信息 :
/usr/bin/MysqLadmin -u root password ‘new-password’ // 为root账号设置密码
所以我们可以通过 该命令来给我们的root账号设置密码(注意:这个root账号是MysqL的root账号,非Linux的root账号)
- [root@xiaoluo ~]# MysqLadmin -u root password 'root'
// 通过该命令给root账号设置密码为 root
此时我们就可以通过 MysqL -u root -p
命令来登录我们的MysqL数据库
我们可以查看一下这个文件的一些信息
- [root@xiaoluo etc]# ls my.cnf
- my.cnf
[root@xiaoluo etc]# cat my.cnf
[MysqLd]
datadir=/var/lib/MysqL
socket=/var/lib/MysqL/MysqL.sock
user=MysqL
2./var/lib/MysqL MysqL数据库的数据库文件存放位置
我们的MysqL数据库的数据库文件通常是存放在了/ver/lib/MysqL这个目录下
总用量 20488
-rw-rw—-. 1 MysqL MysqL 10485760 4月 6 22:01 ibdata1
-rw-rw—-. 1 MysqL MysqL 5242880 4月 6 22:01 ib_logfile0
-rw-rw—-. 1 MysqL MysqL 5242880 4月 6 21:59 ib_logfile1
drwx——. 2 MysqL MysqL 4096 4月 6 21:59 MysqL // 这两个是MysqL数据库安装时默认的两个数据库文件
srwxrwxrwx. 1 MysqL MysqL 0 4月 6 22:01 MysqL.sock
drwx——. 2 MysqL MysqL 4096 4月 6 21:59 test // 这两个是MysqL数据库安装时默认的两个数据库文件
我们可以自己创建一个数据库,来验证一下该数据库文件的存放位置
创建一个我们自己的数据库:
- MysqL> create database xiaoluo;
- Query OK,1 row affected (0.00 sec)
-
- [root@xiaoluo MysqL]# ls -l
- 总用量 20492
- -rw-rw----. 1 MysqL MysqL 10485760 4月 6 22:01 ibdata1
- -rw-rw----. 1 MysqL MysqL 5242880 4月 6 22:01 ib_logfile0
- -rw-rw----. 1 MysqL MysqL 5242880 4月 6 21:59 ib_logfile1
- drwx------. 2 MysqL MysqL 4096 4月 6 21:59 MysqL
- srwxrwxrwx. 1 MysqL MysqL 0 4月 6 22:01 MysqL.sock
- drwx------. 2 MysqL MysqL 4096 4月 6 21:59 test
- drwx------. 2 MysqL MysqL 4096 4月 6 22:15 xiaoluo
// 这个就是我们刚自己创建的xiaoluo数据库
- [root@xiaoluo MysqL]# cd xiaoluo/
- [root@xiaoluo xiaoluo]# ls db.opt
我们的MysqL数据库的一些日志输出存放位置都是在/var/log这个目录下
- [root@xiaoluo xiaoluo]# cd
- [root@xiaoluo ~]# cd /var/log
- [root@xiaoluo log]# ls
- amanda cron maillog-20130331 spice-vdagent.log
- anaconda.ifcfg.log cron-20130331 mcelog spooler
- anaconda.log cups messages spooler-20130331
- anaconda.program.log dirsrv messages-20130331 sssd
- anaconda.storage.log dmesg MysqLd.log tallylog
- anaconda.syslog dmesg.old ntpstats tomcat6
- anaconda.xlog dracut.log piranha wpa_supplicant.log
- anaconda.yum.log gdm pm-powersave.log wtmp
- audit httpd ppp Xorg.0.log
- boot.log ibacm.log prelink Xorg.0.log.old
- btmp lastlog sa Xorg.1.log
- btmp-20130401 libvirt samba Xorg.2.log
- cluster luci secure Xorg.9.log
- ConsoleKit maillog secure-20130331 yum.log
其中MysqLd.log 这个文件就是我们存放我们跟MysqL数据库进行操作而产生的一些日志信息,通过查看该日志文件,我们可以从中获得很多信息
因为我们的MysqL数据库是可以通过网络访问的,并不是一个单机版数据库,其中使用的协议是 tcp/ip 协议,我们都知道MysqL数据库绑定的端口号是 3306 ,所以我们可以通过 netstat -anp 命令来查看一下,Linux系统是否在监听 3306 这个端口号: