000_MySql & MariaDB 安装

Wesley13
• 阅读 938

MySql & MariaDB 安装

1. MySql 安装(二进制)

1.1 下载MySQL

https://cdn.mysql.com//Downloads/MySQL-5.6/mysql-5.6.39-linux-glibc2.12-x86_64.tar.gz

1.2 解压、移动目录位置

tar -zxf mysql-5.6.39-linux-glibc2.12-x86_64.tar.gz

mv mysql-5.6.39-linux-glibc2.12-x86_64 /mnt/installer/mysql

1.3 创建用户

useradd -s /sbin/nologin mysql

1.4 修改数据目录权限

cd /mnt/installer/mysql

chown -R mysql.data

1.5 初始化配置

./scripts/mysql_install_db --user=mysql --datadir=/mnt/installer/mysql/data

  • 报错: FATAL ERROR: please install the following Perl modules before executing ./scripts/mysql_install_db: Data::Dumper

  • 解决:yum -y install autoconf

1.6 拷贝配置文件和服务

cp support-files/my-default.cnf /etc/my.cnf

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

1.7 编辑服务文件

vim /etc/init.d/mysqld
#### 修改配置文件以下参数
basedir=/mnt/installer/mysql
datadir=/mnt/installer/mysql/data

1.8 添加开机启动/启动mysql

chkconfig --add mysqld

chkconfig mysqld on

service mysqld start

1.9 更改环境变量

#### 编辑环境变量文件
vim /etc/profile.d/path.sh
#### 添加MySQL路径
#!/bin/bash
export PATH=$PATH:/mnt/installer/mysql/bin
#### 生效环境变量
source /etc/profile.d/path.sh

2. MariaDB 安装 (YUM)

在CentOS 7.0安装MariaDB的数据库,在这里记录下安装过程,以便以后查看。

2.1 安装MariaDB

  • 安装命令 yum -y install mariadb mariadb-server
  • 启动MariaDB systemctl start mariadb
  • 设置开机启动 systemctl enable mariadb

2.2 初始化MariaDB

mysql_secure_installation

Enter current password for root (enter for none):<–        //初次运行直接回车
……
Set root password? [Y/n] <–         //是否设置root用户密码
New password: <–         //设置root用户的密码
Re-enter new password: <–         //再输入一次你设置的密码
……
Remove anonymous users? [Y/n] <–         //是否删除匿名用户
Disallow root login remotely? [Y/n] <–        //是否禁止root远程登录
Remove test database and access to it? [Y/n] <–         //是否删除test数据库
Reload privilege tables now? [Y/n] <–         //是否重新加载权限表

初始化MariaDB完成,接下来测试登录 进入数据库mysql -uroot -p "password"

2.3 配置MariaDB的字符集

  • 修改配置文件

vi /etc/my.cnf

在[mysqld]标签下添加

init_connect='SET collation_connection = utf8_unicode_ci'
init_connect='SET NAMES utf8'
collation-server=utf8_unicode_ci
skip-character-set-client-handshake

vi /etc/my.cnf.d/client.cnf

在[client]中添加

…………
default-character-set=utf8`
…………

vi /etc/my.cnf.d/mysql-clients.cnf

在[mysql]中添加

…………
default-character-set=utf8`
…………

重启mariadb :systemctl restart mariadb

2.4 查看MariaDB字符集

mysql> show variables like "%character%";show variables like "%collation%";

显示为

+--------------------------+----------------------------+
| Variable_name            | Value                      |
+--------------------------+----------------------------+
| character_set_client     | utf8                       |
| character_set_connection | utf8                       |
| character_set_database   | utf8                       |
| character_set_filesystem | binary                     |
| character_set_results    | utf8                       |
| character_set_server     | utf8                       |
| character_set_system     | utf8                       |
| character_sets_dir       | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
8 rows in set (0.00 sec)

+----------------------+-----------------+
| Variable_name        | Value           |
+----------------------+-----------------+
| collation_connection | utf8_unicode_ci |
| collation_database   | utf8_unicode_ci |
| collation_server     | utf8_unicode_ci |
+----------------------+-----------------+
3 rows in set (0.00 sec)

字符集配置完成。

2.5 添加用户,设置权限

  • 创建用户命令 mysql>create user username@localhost identified by 'password';
  • 直接创建用户并授权的命令 mysql>grant all on *.* to username@localhost indentified by 'password';
  • 授予外网登陆权限 mysql>grant all privileges on *.* to username@'%' identified by 'password';
  • 授予权限并且可以授权 mysql>grant all privileges on *.* to username@'hostname' identified by 'password' with grant option;

简单的用户和权限配置基本就这样了,其中只授予部分权限把 其中 all privileges或者all改为select,insert,update,delete,create,drop,index,alter,grant,references,reload,shutdown,process,file其中一部分。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Android蓝牙连接汽车OBD设备
//设备连接public class BluetoothConnect implements Runnable {    private static final UUID CONNECT_UUID  UUID.fromString("0000110100001000800000805F9B34FB");
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这