MariaDB安装与配置

MariaDB安装与配置 

本文是基于CentOS7.2系统来进行mariadb的安装与配置,安装前请关闭selinux和在iptables规则中开放3306端口,在此次我们直接清空了iptables规则。

Iptables –F
vim /etc/selinux/config
    #SELINUX=enforcing ##注释掉此项##
    #SELINUXTYPE=targeted ##注释掉此项##
    SELINUX=disabled ##添加此项##

一、MariaDB的安装

1、使用yum安装mariadb

添加mariadb的yum源,这里使用阿里源:

get http://mirrors.aliyun.com/repo/Centos-7.repo  /etc/yum.repos.d/
yum install MariaDB-server MariaDB-client ##安装mariadb服务器端、客户端##
vim /etc/my.cnf.d/server.cnf    ##mariadb服务器端配置文件##
    [mysqld]        ##以下项是优化项目可根据需要选择##
    innodb_file_per_table=ON    ##使用独立表空间模式(建议使用)##
    skip_name_resolve=ON    ##禁止域名反向解析(可选)##
systemctl start mariadb.service     ##启动mariadb服务
systemctl enable mariadb.service    ##设置为开机启动##
mysql_secure_installation           ##安装完成后安全初始化,添加root密码,删除匿名登录账户,禁止远程使用root用户登录,删除测试数据库和使用##  
mysql –uroot –hlocalhost –p’PASSWORD  ##登陆数据库##’

2、用二进制压缩包安装MariaDB

MariaDB二进制压缩包命名格式形如:mariadb-版本名-操作系统名.tar.gz,请确认从此外下载为您的机器下载正确的版本。

官方下载点:https://downloads.mariadb.org/,这里我们将使用mariadb5.5版本.

请将二进制包解压到某目录,然后进行mysqlinstalldb安装脚本。

我们将MariaDB安装到目录/usr/local/mysql中(这是许多平台中的默认的安装目录),当然安装其他任意目录中也是可行的。

我们为其建立一个软链接,这样做可以方便地改变软链接而使用不同目录中不同版本的MariaDB。

注意: 对于MariaDB 5.1.32 只要将行”./scripts/mysqlinstalldb –user=mysql”改成”./bin/mysqlinstalldb –user=mysql”就行了。

确保你使用了正确的my.cnf文件

MariaDB在’/etc/my.cnf’位置寻找配置文件(有些系统中是’/etc/mysql/my.cnf’或’~/.my.cnf’)。如果你的系统中有旧的my.cnf文件(系统中曾安装MariaDB或MySQL带来的),你要注意用二进制.tar包安装了MariaDB后,用了旧的配置文件。正常的解决方法是不使用目录中的配置文件,而使用二进制包中的配制文件。具体的做法是:在你的根目录中建立在个.my.cnf配置文件,然后通过选项’–defaults-file=~/.my.cnf’配置mysqlinstalldb、mysqld_safe和mysql(命令行工具)只使用你自建的配置文件。要注意的是,此选项必须是命令的第一个选项。

用root帐户将MariaDB安装在/usr/local/mysql

如果有系统的root使用权限,你可能使用“mysql”用户(组)来安装MariaDB(以保持与MySQL的兼容性):

groupadd mysql
useradd -g mysql mysql
cd /usr/local
tar -zxvpf /path-to/mariadb-VERSION-OS.tar.gz
ln -s mariadb-VERSION-OS mysql
cd mysql
./scripts/mysql_install_db --user=mysql
chown -R root .
chown -R mysql data

建议使用指令ln -s创建一个软链接,从而为安装多个不的MariaDB版本进行测试、升级、降级等提供方便。

如果你是用MariaDB替代,你不用关闭MySQL,你只要调用mysqlinstalldb指令,MariaDB会通过你原来的/etc/my.cnf文件(路径会随你的系统而有所不同)中找到数据目录。

你现在需用如下方式执行mysqld指令:

./bin/mysqld_safe --user=mysql &
or
./bin/mysqld_safe --defaults-file=~/.my.cnf --user=mysql &

修改你的$PATH以便你调用mysql、mysqldump等进行连接测试。

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

你或更愿意通过修改.bashrc或.bash_profile文件来永久保存设置

用root帐户将MariaDB安装在任意目录

下面的操作将目录/usr/local更改到你选择的目录:

cd /usr/local
gunzip < /path-to/mariadb-VERSION-OS.tar.gz | tar xf -
ln -s mariadb-VERSION-OS mysql
cd mysql
./scripts/mysql_install_db --defaults-file=~/.my.cnf

如果你用不来上面的gunzip命令,如有 gnu tar的话,你也可这样:

tar xfz /path-to/mariadb-VERSION-OS.tar.gz

你需用下面的指令启动mysqld:

./bin/mysqld_safe --defaults-file=~/.my.cnf &

自动启动mysqld

你可将文件mysql.server拷贝到合适的位置使mysqld(MariaDB服务器)自动进行。

cp support-files/mysql.server /etc/init.d/mysql.server

具体的位置取决于你的系统,mysql.server文件中含有怎样使用与优化它的相关指导。

安装后的工作

到了这一点后,请记住为所有不可信来源的连接设置正确的密码来减小安全风险!也可以考虑用mysql.server使在系统启动时自动启动MariaDB。

二、MariaDB的配置

Mariadb使用的是ini风格的配置文件,为多个程序同时提供配置; mariadb读取多处的多个配置文件,而且会以指定的次序的进行; 查看读取顺序的命令:

my_print_defaults
Default options are read from the following files in the given order:
/etc/mysql/my.cnf /etc/my.cnf ~/.my.cnf

/etc/my.cnf 是由mariadb-libs生成的

/etc/my.cnf.d/server.cnf是由 mariadb-server生成

/etc/my.cnf.d/client.cnf是由mariadb生成

不同的配置文件中出现同一参数且拥有不同值时,后读取将为最终生效值。

修改默认读取的配置文件(mysqld_safe命令):

--defaults-file=file_name

于读取的默认配置文件之外再加载一个文件:

--defaults-extra-file=path

配置文件格式:ini风格的配置文件,能够为mysql的各种应用程序提供配置信息:

[mysqld]
[mysqld_safe]
[mysqld_multi]
[server]
[mysql]
[mysqldump]
[client]
    ...
配置参数格式:
    PARAMETER = VALUE
    PARAMETER写法:
            innodb_file_per_table (建议使用)
            innodb-file-per-table

三、MariaDB的程序文件及命令:

服务端程序:mysqldsafe, mysqldmulti 客户端程序:mysql, mysqldump, mysqladmin 工具程序:myisampack, …

1、mysql:交互式CLI工具;命令化运行;

mysql [options] db_name

常用选项:

--host=host_name, -h host_name:服务端地址;
--user=user_name, -u user_name:用户名;
--password[=password], -p[password]:用户密码; 
--port=port_num, -P port_num:服务端端口; 
--protocol={TCP|SOCKET|PIPE|MEMORY}:本地通信:基于本地回环地址进行请求,将基于本地通信协议;
        Linux:SOCKET
        Windows:PIPE,MEMORY
    非本地通信:使用非本地回环地址进行的请求; TCP协议;
--socket=path, -S path
--database=db_name, -D db_name:
--compress, -C:数据压缩传输
--execute=statement, -e statement:非交互模式执行SQL语句;
--vertical, -E:查询结果纵向显示;

命令:

客户端命令:于客户端执行;

服务端命令:SQL语句,需要一次性完整地发往服务端;语句必须有结束符;

?         (\?) Synonym for `help'. ##使用帮助##
clear     (\c) Clear the current input statement.##清除已输入的##
connect   (\r) Reconnect to the server. Optional arguments are db and host.
delimiter (\d) Set statement delimiter.##设置语句分隔符##
edit      (\e) Edit command with $EDITOR.
ego       (\G) Send command to mysql server, display result vertically.
exit      (\q) Exit mysql. Same as quit.##退出##
go        (\g) Send command to mysql server.#发送命令到mysql服务器#
help      (\h) Display this help.##显示帮助##
nopager   (\n) Disable pager, print to stdout.
notee     (\t) Don't write into outfile.##不写入输出文件##
pager   (\P) Set PAGER [to_pager]. Print the query results via PAGER.
print     (\p) Print current command.##打印现在的命令##
prompt    (\R) Change your mysql prompt.
quit      (\q) Quit mysql.  ##退出##
rehash    (\#) Rebuild completion hash.##重新hash##
source    (\.) Execute an SQL script file. Takes a file name as an argument. ##执行一个SQL脚本文件
status    (\s) Get status information from the server.##从服务器获取状态信息##
system    (\!) Execute a system shell command.
tee     (\T) Set outfile [to_outfile]. Append everything into given outfile.
use       (\u) Use another database. ##使用其他数据库##
charset   (\C) Switch to another charset. Might be needed for processing binlog with multi-byte charsets.##切换到另一个字符集##
warnings  (\W) Show warnings after every statement.
nowarning (\w) Don't show warnings after every statement.
mysql命令的使用帮助:
man mysql
mysql  --help  --verbose

sql脚本运行:

mysql [options] [DATABASE] < /PATH/FROM/SOME_SQL_SCRIPT

mysqld服务器程序:工作特性的定义方式: 命令行选项 配置文件参数

服务器参数/变量:设定MySQL的运行特性;

mysql> SHOW [GLOBAL | SESSION] VARIABLES [like_or_where];

状态(统计)参数/变量:保存MySQL运行过程中的统计数据或状态数据;

mysql> SHOW [GLOBAL | SESSION] STATUS [like_or_where];

显示单个变量设定值的方法:

mysql> SELECT @@[global.|session.]system_var_name   
    %:匹配任意长度的任意字符;
    _:匹配任意单个字符;

变量/参数级别: 全局:为所有会话设定默认; 会话:跟单个会话相关;会话建立会从全局继承;

服务器变量的调整方式: 运行时修改: global:仅对修改后新建立的会话有效; session:仅对当前会话有效,且立即生效; 通过配置文件修改: 重启后生效;

运行时修改服务器变量值操作方法:

mysql> HELP SET
SET [GLOBAL | SESSION] system_var_name = expr
SET [@@global. | @@session. | @@]system_var_name = expr

安装完成后的安全初始化:

mysql_secure_installation

运行前常修改的参数:

innodb_file_per_table=ON  ##开始独立表空间模式##
skip_name_resolve=ON    ##禁止域名反向解析##
sql_safe_updates=ON     ##开启安全更新模式,不可在配置文件中直接定义##
...

原创文章,作者:征(_少,如若转载,请注明出处:http://www.178linux.com/69312

(0)
征(_少征(_少
上一篇 2017-02-18 19:55
下一篇 2017-02-18 21:24

相关推荐

  • linux根下的文件

    /boot:系统启动时要加载引导的静态文件,内核和ramdisk及grub等 /bin:系统自身启动和运行时可能用到的核心二进制程序,不能关联至独立分区。 /sbin:管理类基本命令,不能关联至独立分区,系统启动便会用到的程序。 /lib:基本共享库文件,以及内核模块文件 /lib64:专用于x86_64系统上的辅助共享库文件存放位置 /etc:大多数应用程…

    Linux干货 2017-03-30
  • LVM——如何让你的磁盘空间可大可小

    逻辑卷管理器(LVM) 允许对卷进行方便操作的抽象层,包括重新设定文件系统的大小 允许在多个物理设备间重新组织文件系统          将设备指定为物理卷          用一个或者多个物理卷来创…

    Linux干货 2016-08-29
  • free / buffer与cache

           前几天看到有些伙伴傻傻分不清楚buffer与cache的用处,后来发现我也不能很清楚的说出来buffer与cache在不同的地方有什么不同之处,这里就总结了一些关于buffer于cache的区别,如有不完善的地方,请大家指出来。        说到buffer与ca…

    2017-07-17
  • Linux学习 Grep详则。

    grep 功能说明:查找文件里符合条件的字符串。 语  法:grep [-abcEFGhHilLnqrsvVwxy][-A<显示列数>][-B<显示列数>][-C<显示列数>][-d<进行动作>][-e<范本样式>][-f<范本文件>][–help][范本样式][文件或目录&…

    Linux干货 2017-07-24
  • 马哥教育N22期第八周作业

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。 设备 功能 使用场景 区别 网桥 根据MAC地址来转发帧,本地通信只限本网段内, 相当于中继器,线路比较长保证信号不变形的传输 工作在物理层,相当于一个物理接口 集线器 接收到的数据包进行广播转发,所有端口都能收到此数据,通过MAC确认是不是发给自己的包进行回应 广播形式转发数据…

    Linux干货 2016-11-14
  • SElinux 管理

    SELinux: Secure Enhanced Linux(安全强化的linux) SElinux安全上下文是由五个元素组成的: ①User:指示登录系统的用户类型,如root,user_u,system_u,多数本地进程都属于自由(unconfined)进程 ②Role:定义文件,进程和用户的用途:文件:object_r,进程和用户:syste…

    Linux干货 2016-09-26