一、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 命令来卸载掉

[root@xiaoluo ~]# rpm -e MysqL // 普通删除模式
[root@xiaoluo ~]# rpm -e --nodeps MysqL  // 强力删除模式,

如果使用上面命令删除时,提示有依赖的其它文件,则用该命令可以对其进行强力删除

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

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

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

[root@xiaoluo ~]# 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@xiaoluo ~]# yum install -y MysqL-server MysqL MysqL-deve

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

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

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

[root@xiaoluo ~]# rpm -qi MysqL-server

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

四、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服务时,就不会提示这么多信息了,如:

[root@xiaoluo ~]# service MysqLd restart
停止 MysqLd:                                             
正在启动 MysqLd:

我们在使用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 命令来将其设置成开机启动,这样就不用每次都去手动启动了

[root@xiaoluo ~]# chkconfig MysqLd on
[root@xiaoluo ~]# 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@xiaoluo ~]# MysqLadmin -u root password 'root' 

 // 通过该命令给root账号设置密码为 root

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

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

1./etc/my.cnf 这是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这个目录下

[root@xiaoluo ~]# cd /var/lib/MysqL/
[root@xiaoluo MysqL]# ls -l

总用量 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

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

我们的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 这个端口号:

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

centos6.4下MySQL数据库的安装和配置超详细,超实用!的更多相关文章

  1. 详解前端HTML5几种存储方式的总结

    本篇文章主要介绍了前端HTML5几种存储方式的总结 ,主要包括本地存储localstorage,本地存储sessionstorage,离线缓存(application cache),Web SQL,IndexedDB。有兴趣的可以了解一下。

  2. PhoneGap / iOS上的SQLite数据库 – 超过5mb可能

    我误解了什么吗?Phonegap中的sqlitedbs真的有5mb的限制吗?我正在使用Phonegap1.2和iOS5.解决方法您可以使用带有phonegap插件的原生sqliteDB,您将没有任何限制.在iOS5.1中,Websql被认为是可以随时删除的临时数据…

  3. ios – 领域:如何获取数据库的当前大小

    是否有RealmAPI方法使用RealmSwift作为数据存储来获取我的RealmSwift应用程序的当前数据库大小?

  4. ios – Realm – 无法使用现有主键值创建对象

    我有一个对象有许多狗的人.应用程序有单独的页面,它只显示狗和其他页面显示人的狗我的模型如下我有人存储在Realm中.人有详细页面,我们取,并显示他的狗.如果狗已经存在,我会更新该狗的最新信息并将其添加到人的狗列表中,否则创建新狗,保存并将其添加到人员列表中.这适用于coredata.在尝试用他的狗更新人时,领域会抛出异常无法使用现有主键值创建对象解决方法这里的问题是,即使你正在创建一个全新的Rea

  5. ios – UIWebView中的WebSQL / SQLite数据库的最大大小(phonegap)

    我知道一般来说,Web应用程序的本地存储空间有5MB的限制.本地网页浏览应用程式是否也有这个限制?

  6. ios – Firebase离线存储高级 – 手动同步和进度信息

    >我可以提供一个捆绑数据库–安装App后我可以已经离线查询了Firebase数据?然后我有另一个关于Firebase的主要问题:>JSON存储是伟大的–但是这样我们不关心一个独特的结构,我们必须注意这一点插入总是正确的数据集?我从来没有试图显示实际的进展,但是当您从firebase中检索数据时,始终会在成功检索数据时调用onDataChange方法.https://firebase.google.com/docs/database/android/retrieve-data#read_data_onceC

  7. ios – 如何处理多用户数据库

    我的应用程序就像很多应用程序–它有一个用户输入用户名和密码的登录屏幕,以及登录按钮我的应用程序还使用CoreData来保存大多数用户的业务对象,当然也是用户特定的.我也有一个登出按钮来启用切换用户.这不会发生很多,但仍然是必要的).现在如果不同的用户登录,我需要获取他的具体数据.但是我该如何做呢?

  8. ios – Swift从Firebase数据库中获取特定价值

    我正在尝试从Firebase数据库中获取特定值.我看了一些像谷歌这样的文件,但我做不到.这是数据库的JSON文件:SWIFT代码:我想获得用户的电子邮件价值,而不是每个人.我怎样才能做到这一点?解决方法在您的代码中,快照将包含子值的字典.要访问它们,请将snapshot.value转换为Dictionary,然后访问各个子项是一个快照

  9. 从iOS应用程序发送帖子到PHP脚本不工作…简单的解决方案就像

    我之前已经做了好几次了但是由于某些原因我无法通过这个帖子…我尝试了设置为_POST且没有的变量的PHP脚本……当它们未设置为发布时它工作精细.这是我的iOS代码:这里是PHP的一大块,POST变量不在正确的位置?我想这对于更有经验的开发人员来说是一个相当简单的答案,感谢您的帮助!解决方法$_POST是一个数组,而不是一个函数.您需要使用方括号来访问数组索引:

  10. ios – Realm Swift:在卸载应用程序后是否可以保留数据库?

    使用realmswift,即使从设备上卸载应用程序,是否可以在设备内存中保留和维护应用程序的领域数据库文件?非常感谢您的帮助.解决方法删除应用程序时,应用程序的所有文件都是剩余的.iOS应用程序是沙盒.这意味着每个应用程序在磁盘中都有自己的空间,并有自己的目录,这些目录充当应用程序及其数据的主页.从iPhone删除应用程序会删除此沙箱,删除与该应用程序关联的所有数据.

随机推荐

  1. 在airgapped(离线)CentOS 6系统上安装yum软件包

    我有一个CentOS6系统,出于安全考虑,它已经被空气泄漏.它可能从未连接到互联网,如果有,它很长时间没有更新.我想将所有.rpm软件包放在一个驱动器上,这样它们就可以脱机安装而无需查询互联网.但是,我在测试VM上遇到的问题是,即使指定了本地路径,yum仍然会挂起并尝试从在线存储库进行更新.另外,有没有办法使用yum-utils/yumdownloader轻松获取该包的所有依赖项和所有依赖项?目前

  2. centos – 命名在日志旋转后停止记录到rsyslog

    CentOS6.2,绑定9.7.3,rsyslog4.6.2我最近设置了一个服务器,我注意到在日志轮换后,named已停止记录到/var/log/messages.我认为这很奇怪,因为所有日志记录都是通过rsyslog进行的,并且named不会直接写入日志文件.这更奇怪,因为我在更新区域文件后命名了HUPed,但它仍然没有记录.在我停止并重新启动命名后,记录恢复.这里发生了什么?

  3. centos – 显示错误的磁盘大小

    对于其中一个磁盘,Df-h在我的服务器上显示错误的空白区域:Cpanel表明它只有34GB免费,但还有更多.几分钟前,我删除了超过80GB的日志文件.所以,我确信它完全错了.fdisk-l/dev/sda2也显示错误:如果没有格式化,我该怎么做才能解决这个问题?并且打开文件描述符就是它需要使用才能做到这一点.所以…使用“lsof”并查找已删除的文件.重新启动写入日志文件的服务,你很可能会看到空间可用.

  4. 如何在centos 6.9上安装docker-ce 17?

    我目前正在尝试在centOS6.9服务器上安装docker-ce17,但是,当运行yuminstalldocker-ce时,我收到以下错误:如果我用跳过的标志运行它我仍然得到相同的消息,有没有人知道这方面的方法?

  5. centos – 闲置工作站的异常负载平均值

    我有一个新的工作站,具有不寻常的高负载平均值.机器规格是:>至强cpu>256GB的RAM>4x512GBSSD连接到LSI2108RAID控制器我从livecd安装了CentOS6.564位,配置了分区,网络,用户/组,并安装了一些软件,如开发工具和MATLAB.在启动几分钟后,工作站负载平均值的值介于0.5到0.9之间.但它没有做任何事情.因此我无法理解为什么负载平均值如此之高.你能帮我诊断一下这个问题吗?

  6. centos – Cryptsetup luks – 检查内核是否支持aes-xts-plain64密码

    我在CentOS5上使用cryptsetupluks加密加密了一堆硬盘.一切都很好,直到我将系统升级到CentOS6.现在我再也无法安装磁盘了.使用我的关键短语装载:我收到此错误:在/var/log/messages中:有关如何装载的任何想法?找到解决方案问题是驱动器使用大约512个字符长的交互式关键短语加密.出于某种原因,CentOS6中的新内核模块在由旧版本创建时无法正确读取512个字符的加密密钥.似乎只会影响内核或cryptsetup的不同版本,因为在同一系统上创建和打开时,512字符的密钥将起作用

  7. centos – 大量ssh登录尝试

    22个我今天登录CentOS盒找到以下内容这是过去3天内的11次登录尝试.WTF?请注意,这是我从我的提供商处获得的全新IP,该盒子是全新的.我还没有发布任何关于此框的内容.为什么我会进行如此大量的登录尝试?是某种IP/端口扫描?基本上有4名匪徒,其中2名来自中国,1名来自香港,1名来自Verizon.这只发生在SSH上.HTTP上没有问题.我应该将罪魁祸首子网路由吗?你们有什么建议?

  8. centos – kswap使用100%的CPU,即使有100GB的RAM也可用

    >Linux内核是否应该足够智能,只需从内存中清除旧缓存页而不是启动kswap?

  9. centos – Azure将VM从A2 / 3调整为DS2 v2

    我正在尝试调整前一段时间创建的几个AzureVM,从基本的A3和标准A3到标准的DS2v2.我似乎没有能力调整到这个大小的VM.必须从头开始重建服务器会有点痛苦.如果它有所不同我在VM中运行CentOS,每个都有一个带有应用程序和操作系统的磁盘.任何人都可以告诉我是否可以在不删除磁盘的情况下删除VM,创建新VM然后将磁盘附加到新VM?

  10. centos – 广泛使用RAM时服务器计算速度减慢

    我在非常具体的情况下遇到服务器速度下降的问题.事实是:>1)我使用计算应用WRF>2)我使用双XeonE5-2620v3和128GBRAM(NUMA架构–可能与问题有关!

返回
顶部