返回顶部

MySQL简介及安装

mysql 官方文档

  • https://downloads.mysql.com/archives/community/

MySQL 介绍和安装

1、什么是数据?

  • 数据:文字、图片、视频。。。人类认知的数据表现方式

  • 计算机:二进制、16进制的机器语言

  • 基于数据的重要性和复杂性的不同,我们可能有不同的管理方式。

哪些数据是适合存储到数据库的呢?

  • 重要性比较高的

  • 关系较复杂的数据

DBMS 数据库管理系统种类

  • RDBMS : Oracle ,MySQL ,PG,MSSQL

  • NoSQL : MongoDB ,Redis ,ES

  • NEWSQL (分布式): TiDB,Spanner ,AliSQL(RDS+DRDS) ,OB ,PolarDB

MySQL 企业版本GA(稳定发布版)选择

  • 5.6 : 5.6.34 5.6.36 5.6.38(2017913) 5.6.40

  • 5.7 : 5.7.18 ,20(2017913) ,24 ,(上课版本:5726)

  • 8.0 : 8014, 8015 ,8016

二进制版本安装

下载并上传软件至/server/tools

mkdir -p /server/tools
cd /server/tools/
yum install -y lrzsz
tar xf mysql-5.7.26-linux-glibc2.12-x86_64.tar.gz 
mkdir /application
mv mysql-5.7.26-linux-glibc2.12-x86_64  /application/mysql

用户的创建处理原始环境

rpm -qa |grep mariadb
yum remove mariadb-libs-5.5.60-1.el7_5.x86_64 -y
useradd -s /sbin/nologin mysql

设置环境变量

vim /etc/profile
export PATH=/application/mysql/bin:$PATH
source /etc/profile
mysql -V

创建数据路径并授权

添加一块新磁盘模拟数据盘

格式化并挂载磁盘

mkfs.xfs /dev/sdb
mkdir /data
# 查看磁盘的uuid
blkid
vim /etc/fstab 
UUID="18c98f72-ea42-4629-ba17-e65c8237a0ff" /data xfs defaults 0 0
mount -a
df -h

授权

chown -R mysql.mysql /application/*
chown -R mysql.mysql /data

初始化数据(创建系统数据)

版本初始化命令

/application/mysql/scripts/mysql_install_d

5.7 版本

mkdir /data/mysql/data -p
chown -R mysql.mysql /data
mysqld --initialize --user=mysql --basedir=/application/mysql --datadir=/data/mysql/data 

说明:

  • --initialize 参数:

  • 1. 对于密码复杂度进行定制:12位,4种

  • 2. 密码过期时间:180

  • 3. 给root@localhost用户设置临时密码

报错:

mysqld: error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory

解决:

  • yum install -y libaio-devel
  • yum -y install numactl
mysqld --initialize --user=mysql --basedir=/application/mysql --datadir=/data/mysql/data

5.7默认生成一个临时密码,还有过期限制,一般生产不用,直接删掉,使用一下命令

--initialize-insecure 参数:

无限制,无临时密码

\rm -rf /data/mysql/data/*
mysqld --initialize-insecure --user=mysql --basedir=/application/mysql --datadir=/data/mysql/data

 初始化完成生产的数据

配置文件的准备

cat >/etc/my.cnf <<EOF
[mysqld]
user=mysql
basedir=/application/mysql
datadir=/data/mysql/data
socket=/tmp/mysql.sock
server_id=6
port=3306
[mysql]
socket=/tmp/mysql.sock
EOF

启动数据库

1. sys-v 

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

2. systemd

注意: sysv方式启动过的话,需要先提前关闭,才能以下方式登录

cat >/etc/systemd/system/mysqld.service <<EOF
[Unit]
Description=MySQL Server
Documentation=man:mysqld(8)
Documentation=http://dev.mysql.com/doc/refman/en/using-systemd.html
After=network.target
After=syslog.target
[Install]
WantedBy=multi-user.target
[Service]
User=mysql
Group=mysql
ExecStart=/application/mysql/bin/mysqld --defaults-file=/etc/my.cnf
LimitNOFILE = 5000
EOF

systemd管理  

systemctl  start/stop/restart/status   mysqld

如何分析处理MySQL数据库无法启动

without updating PID 类似错误

5.1 without updating PID 类似错误 
查看日志:
在哪?
/data/mysql/data/主机名.err
[ERROR] 上下文
可能情况:
/etc/my.cnf 路径不对等
/tmp/mysql.sock文件修改过 或 删除过
数据目录权限不是mysql
参数改错了

管理员密码的设定(root@localhost)

# 一路回车
mysqladmin -uroot -p password 123 

使用密码登录

mysql -uroot -p123

管理员用户密码忘记了?

  • --skip-grant-tables #跳过授权表

  • --skip-networking #跳过远程登录

关闭数据库

/etc/init.d/mysqld stop

启动数据库到维护模式

mysqld_safe --skip-grant-tables --skip-networking &

登录并修改密码

mysql> alter user root@'localhost' identified by '1';
ERROR 1290 (HY000): The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement
mysql> flush privileges;
mysql> alter user root@'localhost' identified by '1';
Query OK, 0 rows affected (0.01 sec)

关闭数据库,正常启动验证

  

posted @ 2020-02-23 21:12  Crazymagic  阅读(220)  评论(0编辑  收藏  举报