1. 删除CentOS7.3默认数据库配置文件

  • 查看默认数据库配置文件

[root@localhost ~]# find -H /etc/ | grep my.c
/etc/pki/tls/certs/make-dummy-cert
/etc/pki/tls/certs/renew-dummy-cert
/etc/my.cnf.d
/etc/my.cnf.d/MysqL-clients.cnf
/etc/my.cnf
  • 删除默认数据库配置文件

[root@localhost ~]# rm -rf /etc/my.cnf /etc/my.cnf.d/
  • 再次查看默认数据库配置文件

[root@localhost ~]# find -H /etc/ | grep my.c
/etc/pki/tls/certs/make-dummy-cert
/etc/pki/tls/certs/renew-dummy-cert

到目前为止,系统最小化安装自带的数据库配置文件已经删除干净了!

2. 卸载系统自带mariadb-libs

  • 查询

[root@localhost ~]# rpm -qa|grep mariadb-libs
mariadb-libs-5.5.52-1.el7.x86_64
  • 卸载

[root@localhost ~]# rpm -e mariadb-libs-5.5.52-1.el7.x86_64 --nodeps

安装相关包

[root@localhost ~]# yum -y install libaio 
[root@localhost ~]# yum -y install libaio-devel 
[root@localhost ~]# yum -y install bison 
[root@localhost ~]# yum -y install bison-devel 
[root@localhost ~]# yum -y install zlib-devel 
[root@localhost ~]# yum -y install openssl
[root@localhost ~]# yum -y install openssl-devel 
[root@localhost ~]# yum -y install ncurses 
[root@localhost ~]# yum -y install ncurses-devel
[root@localhost ~]# yum -y install libcurl-devel
[root@localhost ~]# yum -y install libarchive-devel 
[root@localhost ~]# yum -y install boost 
[root@localhost ~]# yum -y install boost-devel 
[root@localhost ~]# yum -y install lsof 
[root@localhost ~]# yum -y install wget
[root@localhost ~]# yum -y install gcc 
[root@localhost ~]# yum -y install gcc-c++
[root@localhost ~]# yum -y install make
[root@localhost ~]# yum -y install cmake
[root@localhost ~]# yum -y install perl
[root@localhost ~]# yum -y install kernel-headers
[root@localhost ~]# yum -y install kernel-devel 
[root@localhost ~]# yum -y install pcre-devel

3. 创建家目录存放软件包目录

[root@localhost ~]# mkdir soft

[root@localhost ~]# cd soft

4. MariaDB官网复制源码包链接地址并下载解压

  • 下载

[root@localhost soft]# wget https://downloads.mariadb.org/interstitial/mariadb-10.2.6/source/mariadb-10.2.6.tar.gz
  • 解压

[root@localhost soft]# tar -zxvf mariadb-10.2.6.tar.gz

5. 创建MariaDB安装目录、数据库存放目录、建立用户和目录

这里提前预定MariaDB的安装目录为/usr/local/MysqL并且数据库目录为/data/MysqL,这里要建立系统用户及组和数据库存放目录,并且将数据库存放目录赋予MysqL用户及组权限,操作如下:

请注意特别说明一下:这里说的数据库目录是指的具体数据库存储文件,而不是安装文件!

  • 创建MysqL系统用户组

[root@localhost soft]# groupadd -r MysqL
  • 创建系统用户MysqL并加入到MysqL系统用户组

[root@localhost soft]# useradd -r -g MysqL -s /sbin/nologin -d /usr/local/MysqL -M MysqL

以下是上面创建系统用户MysqL的各个参数说明:

-r: 添加系统用户( 这里指将要被创建的系统用户MysqL )

-g: 指定要创建的用户所属组( 这里指添加到新系统用户MysqL到MysqL系统用户组 )

-s: 新系统帐户的登录shell( /sbin/nologin 这里设置为将要被创建系统用户MysqL不能用来登录系统 )

-d: 新帐户的主目录( 这里指定将要被创建的系统用户MysqL的家目录为 /usr/local/MysqL )

-M: 不要创建用户的主目录( 也就是说将要被创建的系统用户MysqL不会在 /home 目录下创建 MysqL 家目录 )

  • 创建maria安装目录

[root@localhost soft]# mkdir -p /usr/local/MysqL
  • 创建数据库存放目录

[root@localhost soft]# mkdir -p /data/MysqL
  • 改变数据库存放目录所属用户及组为 MysqL:MysqL

[root@localhost soft]# chown -R MysqL:MysqL /data/MysqL

执行编译安装

> 进入到解压后的源码包文件夹

[root@localhost soft]# cd mariadb-10.2.6

> 输入编译参数

cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/MysqL \
 -DMysqL_DATADIR=/data/MysqL \
 -DSYSconfdIR=/etc \
 -DWITHOUT_TOKUDB=1 \
 -DWITH_INNOBASE_STORAGE_ENGINE=1 \
 -DWITH_ARCHIVE_STPRAGE_ENGINE=1 \
 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
 -DWIYH_READLINE=1 \
 -DWIYH_SSL=system \
 -DVITH_ZLIB=system \
 -DWITH_LOBWRAP=0 \
 -DMysqL_UNIX_ADDR=/tmp/MysqL.sock \
 -DDEFAULT_CHARSET=utf8 \
 -DDEFAULT_COLLATION=utf8_general_ci

> 如果编译失败请删除CMakeCache.txt

[root@localhost soft]# rm -f CMakeCache.txt

> 让指令重新执行,否则每次读取这个文件,命令修改正确也是报错

> cmake没问题,可以编译并且安装了: make && make install 时间会有点长根据个人机器吧,你可以干别的事情去!

[root@localhost soft]# make && make install

> 执行完成也就是安装完成了,不过请注意,这只是安装了,并没有启动,启动不成功等于没安装,不能用也是徒劳无功不是?

6. 配置MariaDB

> 进入到 MariaDB 安装目录

[root@localhost ~]# cd /usr/local/MysqL/

> 使用 `MysqL` 用户执行脚本,安装数据库到数据库存放目录

[root@localhost MysqL]# scripts/MysqL_install_db --user=MysqL --datadir=/data/MysqL

> 输出以下信息:
Installing MariaDB/MysqL system tables in '/data/MysqL' ...
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 MariaDB root USER !
To do so,start the server,then issue the following commands:

'./bin/MysqLadmin' -u root password 'new-password'
'./bin/MysqLadmin' -u root -h localhost.localdomain password 'new-password'

Alternatively you can run:
'./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 MariaDB KNowledgebase at http://mariadb.com/kb or the
MysqL manual for more instructions.

You can start the MariaDB daemon with:
cd '.' ; ./bin/MysqLd_safe --datadir='/data/maria'

You can test the MariaDB daemon with MysqL-test-run.pl
cd './MysqL-test' ; perl MysqL-test-run.pl

Please report any problems at http://mariadb.org/jira

The latest information about MariaDB is available at http://mariadb.org/.
You can find additional information about the MysqL part at:
http://dev.MysqL.com
Consider joining MariaDB's strong and vibrant community:
https://mariadb.org/get-involved/

6. 复制MariaDB配置文件到/etc目录

> 进行到 MariaDB 安装目录

[root@localhost ~]# cd /usr/local/MysqL/

> 拷贝support-files目录下的文件my-large.cnf到/etc目录并重命名为my.cnf

[root@localhost MysqL]# cp support-files/my-large.cnf /etc/my.cnf

7. 创建启动脚本

[root@localhost MysqL]# cp support-files/MysqL.server /etc/rc.d/init.d/MysqLd

8. 启动MysqLd服务

[root@localhost MysqL]# /etc/rc.d/init.d/MysqLd start

9. 配置环境变量,以便在任何目录下输入MysqL

> 打开并新建文件

[root@localhost MysqL]# vim /etc/profile.d/MysqL.sh

> 输入以下内容

export PATH=$PATH:/usr/local/MysqL/bin/

> 保存并退出

:wq

> 为脚本赋于可执行权限

[root@localhost MysqL]# chmod 0777 /etc/profile.d/MysqL.sh

> 进行MysqL.sh脚本所在目录,并执行脚本,以立即生效环境变量

[root@localhost MysqL]# source /etc/profile.d/MysqL.sh

10. 初始化MariaDB

> 运行MariaDB初始化脚本

[root@localhost MysqL]# ./bin/MysqL_secure_installation

> 以下提示:

Enter current password for root (enter for none):     输入当前root密码(没有输入)

Set root password? [Y/n]     设置root密码?(是/否)

New password:    输入新root密码

Re-enter new password:        确认输入root密码

Password updated successfully!         密码更新成功

By default,a MariaDB installation has an anonymous user,allowing anyone
to log into MariaDB without having to have a user account created for
them.  This is intended only for testing,and to make the installation
go a bit smoother.  You should remove them before moving into a
production environment.

默认情况下,MariaDB安装有一个匿名用户,允许任何人登录MariaDB而他们无需创建用户帐户。
这个目的是只用于测试,安装去更平缓一些。
你应该进入前删除它们生产环境。

Remove anonymous users? [Y/n]         删除匿名用户?(是/否)

normally,root should only be allowed to connect from 'localhost'.  This
ensures that someone cannot guess at the root password from the network.

通常情况下,root只应允许从localhost连接。
这确保其他用户无法从网络猜测root密码。

disallow root login remotely? [Y/n]     不允许root登录远程?(是/否)

By default,MariaDB comes with a database named 'test' that anyone can
access.  This is also intended only for testing,and should be removed
before moving into a production environment.

默认情况下,MariaDB提供了一个名为“测试”的数据库,任何人都可以访问。
这也只用于测试,在进入生产环境之前应该被删除。

Reloading the privilege tables will ensure that all changes made so far
will take effect immediately.

重新加载权限表将确保所有到目前为止所做的更改将立即生效。

Reload privilege tables Now? [Y/n]      现在重新加载权限表(是/否)

All done!  If you've completed all of the above steps,your MariaDB
installation should Now be secure.

全部完成!如果你已经完成了以上步骤,MariaDB安装现在应该安全。

Thanks for using MariaDB!

感谢使用MariaDB!

编译安装MariaDB后所有配置操作

[root@localhost ~]# cd /usr/local/MysqL/
[root@localhost MysqL]# scripts/MysqL_install_db --user=MysqL --datadir=/data/MysqL/
Installing MariaDB/MysqL system tables in '/data/MysqL/' ...
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 MariaDB root USER !
To do so,then issue the following commands:

'./bin/MysqLadmin' -u root password 'new-password'
'./bin/MysqLadmin' -u root -h localhost.localdomain password 'new-password'

Alternatively you can run:
'./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 MariaDB KNowledgebase at http://mariadb.com/kb or the
MysqL manual for more instructions.

You can start the MariaDB daemon with:
cd '.' ; ./bin/MysqLd_safe --datadir='/data/MysqL/'

You can test the MariaDB daemon with MysqL-test-run.pl
cd './MysqL-test' ; perl MysqL-test-run.pl

Please report any problems at http://mariadb.org/jira

The latest information about MariaDB is available at http://mariadb.org/.
You can find additional information about the MysqL part at:
http://dev.MysqL.com
Consider joining MariaDB's strong and vibrant community:
https://mariadb.org/get-involved/

[root@localhost MysqL]# cp support-files/my-large.cnf /etc/my.cnf
[root@localhost MysqL]# cp support-files/MysqL.server /etc/rc.d/init.d/MysqLd
[root@localhost MysqL]# /etc/rc.d/init.d/MysqLd start
Reloading systemd:                                         [  OK  ]
Starting MysqLd (via systemctl):                           [  OK  ]
[root@localhost MysqL]# touch /etc/profile.d/MysqL.sh
[root@localhost MysqL]# echo 'export PATH=$PATH:/usr/local/MysqL/bin/' > /etc/profile.d/MysqL.sh 
[root@localhost MysqL]# chmod 0777 /etc/profile.d/MysqL.sh 
[root@localhost MysqL]# source /etc/profile.d/MysqL.sh 
[root@localhost MysqL]# MysqL
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 10
Server version: 10.2.6-MariaDB-log Source distribution

copyright (c) 2000,2017,Oracle,MariaDB Corporation Ab and others.

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

MariaDB [(none)]>

希望本文对你的工作和学习有所帮助

如果觉得还不错怎么感谢我呢? 妈呀! 点赞啊!

Good Luck! from warnerwu at 2017.06.24 PM

Todo:

Modify correction in 2017.07.13 PM for the first time

CentOS7.3编译安装MariaDB10.2.6的更多相关文章

  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 – 友好的NSDate格式

    我需要在我的应用程序中显示帖子的日期给用户,现在我用这种格式:“5月25日星期五”.如何格式化NSDate以阅读“2小时前”的内容?使其更加用户友好.解决方法NSDateFormatter不能做这样的事情;你将需要建立自己的规则.我想像:所以这是打印’x分钟前’或’x小时前’从日期起24小时,通常是一天.

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

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

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

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

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

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

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

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

随机推荐

  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架构–可能与问题有关!

返回
顶部