序:程序员做了好久了,希望往后的发展有一个稳定的路线和使用的技能,准备深入学习一下数据库。重新认识一下MySQL~从今天起开启我的数据库学习之旅~
- MySQL简介
说到数据库,我们大多想到的是关系型数据库,比如MySQL、oracle、sqlserver等等,这些数据库软件在windows上安装都非常的方便,在Linux上如果要安装数据库,咱不得不首先推荐的是mysql数据库了,而且Mysql数据库的第一个版本就是发行在Linux系统上的。
MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司。MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。MySQL的SQL语言是用于访问数据库的最常用标准化语言。MySQL软件采用了双授权政策(本词条“授权政策”),它分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择MySQL作为网站数据库。由于其社区版的性能卓越,搭配PHP和Apache可组成良好的开发环境。
MySQL官方网址:https://www.mysql.com/
当前最新版本的MySQL是5.7.19,下载地址:https://dev.mysql.com/downloads/mysql/ - 安装MySQL
系统版本:CentOS 6.4 64位
linux 系统版本 查看命令:
“uname -a”, 可显示电脑以及操作系统的相关信息。
“cat /proc/version”,说明正在运行的内核版本。
“cat /etc/issue”, 显示的是发行版本信息。
下载版本可以使用这个版本:
1)卸载原有MySQL
因为mysql数据库在Linux上实在是太流行了,所以目前下载的主流Linux系统版本基本上都集成了mysql数据库在里面,我们可以通过如下命令来查看我们的操作系统上是否已经安装了mysql数据库
[root@localhost ~]# rpm -qa | grep mysql // 这个命令就会查看该操作系统上是否已经安装了mysql数据库
有的话,我们就通过 rpm -e 命令 或者 rpm -e –nodeps 命令来卸载掉
[root@localhost ~]# rpm -e mysql // 普通删除模式
[root@localhost ~]# rpm -e --nodeps mysql // 强力删除模式,如果使用上面命令删除时,提示有依赖的其它文件,则用该命令可以对其进行强力删除
在删除完以后我们可以通过 rpm -qa | grep mysql 命令来查看mysql是否已经卸载成功!!
2) CentOS 通过yum 安装 MySQL
我是通过yum的方式来进行mysql的数据库安装,首先我们可以输入 yum list | grep mysql 命令来查看yum上提供的mysql数据库可下载的版本:
[root@localhost~]# yum list | grep mysql
得到 yum 服务器上的 MySQL版本
然后我们可以通过输入 yum install -y mysql-server mysql mysql-devel 命令将mysql mysql-server mysql-devel都安装好(注意:安装mysql时我们并不是安装了mysql客户端就相当于安装好了mysql数据库了,我们还需要安装mysql-server服务端才行)
[root@localhost ~]# yum install -y mysql-server mysql mysql-deve
安装完成之后 可以通过下面的命令查看安装的mysql-server 版本
[root@localhost ~]# rpm -qi mysql-server
3)安装完成后对MySQL进行配置
我们在安装完mysql数据库以后,会发现会多出一个mysqld的服务,这个就是咱们的数据库服务,我们通过输入 service mysqld start 命令就可以启动我们的mysql服务。
[root@localhost ~]# service mysqld start
重启mysql 服务
[root@localhost ~]# service mysqld restart
我们在使用mysql数据库时,都得首先启动mysqld服务,我们可以 通过 chkconfig –list | grep mysqld 命令来查看mysql服务是不是开机自动启动,如:
[root@localhost ~]# chkconfig --list | grep mysqld
mysqld 0:关闭 1:关闭 2:关闭 3:关闭 4:关闭 5:关闭 6:关闭
我们发现mysqld服务并没有开机自动启动,我们当然可以通过 chkconfig mysqld on 命令来将其设置成开机启动,这样就不用每次都去手动启动了
[root@localhost ~]# chkconfig mysqld on
[root@localhost ~]# chkconfig --list | grep mysql
mysqld 0:关闭 1:关闭 2:启用 3:启用 4:启用 5:启用 6:关闭
mysql数据库安装完以后只会有一个root管理员账号,但是此时的root账号还并没有为其设置密码,在第一次启动mysql服务时,会进行数据库的一些初始化工作,在输出的一大串信息中,我们看到有这样一行信息 :
/usr/bin/mysqladmin -u root password 'new-password' // 为root账号设置密码
所以我们可以通过 该命令来给我们的root账号设置密码(注意:这个root账号是mysql的root账号,非Linux的root账号)
[root@zkm ~]# mysqladmin -u root password 'root' // 通过该命令给root账号设置密码为 root
此时我们就可以通过 mysql -u root -p 命令来登录我们的mysql数据库了
[root@localhost ~]# mysqladmin -u root password 'root'
[root@localhost ~]# mysql -uroot -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>
- mysql数据库的主要配置文件
/etc/my.cnf 这是mysql的主配置文件
[root@localhost etc]# cat /etc/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
/var/lib/mysql 是数据库文件存放的地方
[root@localhost mysql]# ll /var/lib/mysql/
total 20488
-rw-rw----. 1 mysql mysql 10485760 Aug 18 05:13 ibdata1
-rw-rw----. 1 mysql mysql 5242880 Aug 21 04:04 ib_logfile0
-rw-rw----. 1 mysql mysql 5242880 Aug 18 00:30 ib_logfile1
drwx------. 2 mysql mysql 4096 Aug 18 00:30 mysql
srwxrwxrwx. 1 mysql mysql 0 Aug 21 04:04 mysql.sock
drwx------. 2 mysql mysql 4096 Aug 18 00:30 test
/var/log mysql数据库的日志输出存放位置
我们的mysql数据库的一些日志输出存放位置都是在/var/log这个目录下
[root@localhost log]# ll /var/log/mysqld.log
-rw-r-----. 1 mysql mysql 2159 Aug 21 04:04 /var/log/mysqld.log
其中mysqld.log 这个文件就是我们存放我们跟mysql数据库进行操作而产生的一些日志信息,通过查看该日志文件,我们可以从中获得很多信息。
因为我们的mysql数据库是可以通过网络访问的,并不是一个单机版数据库,其中使用的协议是 tcp/ip 协议,我们都知道mysql数据库绑定的端口号是 3306 ,所以我们可以通过 netstat -anp 命令来查看一下,Linux系统是否在监听 3306 这个端口号:
[root@localhost log]# netstat -anp | more
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program na
me
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 1909/sshd
tcp 0 0 127.0.0.1:631 0.0.0.0:* LISTEN 1807/cupsd
tcp 0 0 127.0.0.1:25 0.0.0.0:* LISTEN 2072/master
tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN 3078/mysqld
tcp 0 0 192.168.163.140:22 192.168.163.1:60793 ESTABLISHED 2406/sshd
tcp 0 0 :::22 :::* LISTEN 1909/sshd
tcp 0 0 ::1:631 :::* LISTEN 1807/cupsd
tcp 0 0 ::1:25 :::* LISTEN 2072/master
udp 0 0 0.0.0.0:631 0.0.0.0:* 1807/cupsd
udp 0 0 0.0.0.0:68 0.0.0.0:* 1791/dhclient
[root@localhost log]# netstat -anp | grep mysql
tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN 3078/mysqld
unix 2 [ ACC ] STREAM LISTENING 22287 3078/mysqld /var/lib/mysql/mysql.sock