文章目录
- 前言
- 一、数据库
-
- [1.1 回顾web服务流程](#1.1 回顾web服务流程)
- [1.2 数据库的概念](#1.2 数据库的概念)
- [1.3 数据库管理系统(DBMS)](#1.3 数据库管理系统(DBMS))
- [1.4 数据库系统](#1.4 数据库系统)
- 二、数据库的分类
-
- [2.1 按时间分类](#2.1 按时间分类)
- [2.2 按存储方式分](#2.2 按存储方式分)
- 三、安装mysql
-
- [3.1 关闭防火墙和网络增强服务](#3.1 关闭防火墙和网络增强服务)
- [3.2 解压mysql安装包与对应的依赖库boost安装包](#3.2 解压mysql安装包与对应的依赖库boost安装包)
- [3.3 安装编译安装的依赖包](#3.3 安装编译安装的依赖包)
- [3.4 创建mysql系统用户](#3.4 创建mysql系统用户)
- [3.5 mysql编译安装](#3.5 mysql编译安装)
- [3.6 配置mysql权限](#3.6 配置mysql权限)
- [3.7 修改配置文件](#3.7 修改配置文件)
- [3.8 设置环境变量](#3.8 设置环境变量)
- [3.9 数据库初始化](#3.9 数据库初始化)
- [3.10 启动mysql服务](#3.10 启动mysql服务)
- [3.11 账号密码管理](#3.11 账号密码管理)
- 总结
前言
本文讲述了myql以及安装操作
一、数据库
1.1 回顾web服务流程

1、用户在浏览器输入域名
2、DNS解析将域名解析成为IP地址
3、浏览器与web服务器建立连接(通过三次握手)
4、浏览器向web服务器发起http请求连接
5、若为静态页面,web服务器直接处理请求并回给客户端,形成静态页面
6、若为动态页面,web服务器则要发送给应用服务器,应用服务器在数据库中找数据,最后回给用户,形成动态页面
1.2 数据库的概念
在上述流程讲解中,本文提到了数据库这一名词,那么数据库的概念就好理解了,数据库就相当与一个图书馆,存放着很多书,这些书以书架的形式存放,那么,数据存放在数据库中则以表的形式。
MySQL 服务 → 数据库 → 表 → 行(记录) + 列(字段)
表结构= 行(记录) + 列(字段)
特点:
1、记录由字段组成,字段由字符或数字组成
2、可供不同用户共享
3、具有较小的冗余度和较高的数据独立性
数据库就是表的集合,是按照一定组织方式存储的相关数据集合
1.3 数据库管理系统(DBMS)
定义:操作和管理数据库的软件。
主要功能:
1.建库与维护(建表、转储与恢复、重组、性能监视)
2.数据定义(数据结构、存储结构、保密模式)
3.数据操作(查询、统计、更新)
4.运行管理(并发控制、存取控制、维护)
5.通信(与其他软件交互,如 Access 和 Office 组件)
1.4 数据库系统
组成:操作系统(如Windows、linux)、硬件、应用软件、用户、数据库、DBMS
DBA(数据库管理员):负责备份恢复、维护、用户管理。
数据库应用软件:Navicat、人事管理系统、财务系统、图书管理等。
DBMS 工作模式:
1.接收请求
2.转换为底层指令
3.执行数据库操作
4.获取结果
5.格式化结果
6.返回给用户
二、数据库的分类
2.1 按时间分类
第一阶段(层次型/网状型)
IMS(IBM,1969)
第二阶段(关系型)
关系模型(1970)
一位叫 E.F. Codd的 IBM 研究员提出了"关系模型(Relational Model)"。
核心思想:
把数据放在 二维表(行、列)里,而不是像层次型或网状型那样用复杂的指针去连接。
用数学集合和关系代数来描述和操作数据(比如选择、投影、连接)。
这样数据就更直观、更容易查询和维护。
代表产品
System R(IBM 开发):第一个真正实现关系模型的实验性数据库系统。
Ingres(加州大学伯克利):另一个早期的关系型数据库系统,后来衍生出了 PostgreSQL。
意义
关系型数据库的出现,让 SQL(结构化查询语言)成为主流。
现在常见的 MySQL、Oracle、SQL Server 都是关系型数据库的后代。
2.3 第三阶段(新型数据库)
特点:面向对象、开放性、多平台
SQL + NoSQL 混合使用
新兴数据库:MariaDB、PostgreSQL、时序数据库
2.2 按存储方式分
关系型数据库
数据模型:E-R 模型(实体-关系)
行(记录) = 实体
列(字段) = 属性
特点 关系型数据库 非关系型数据库
数据结构 表(二维表) KV、文档、列式、图形
优点 结构清晰,SQL通用,支持复杂查询 格式灵活,速度快,高并发
缺点 表结构固定,I/O 瓶颈 无SQL、事务差、复杂查询弱
代表产品 MySQL、Oracle、PostgreSQL Redis、MongoDB、HBase
表与表之间存在关系(1对1,1对多,多对多)
主键:唯一、非空,类比学号/身份证号。
常见产品:MySQL、Oracle、SQL Server、DB2、PostgreSQL 等。
非关系型数据库(NoSQL)
定义:Not Only SQL,存储方式不限于表,可存储键值对、文档、列式数据等。
典型产品:Redis、Memcached、MongoDB、HBase。
应用场景:高并发、缓存、大数据实时计算。
优点
1.格式灵活(Key-Value、文档、图片等)
2.速度快(基于内存存储)
3.高扩展性
4.成本低(开源,部署简单)
缺点
1.不支持 SQL
2.缺少事务处理
3.复杂查询支持不足
4.大部分数据在内存,成本较高
对比 Redis 和 Memcached
相同点:都存储热点数据,内存运行,速度快。
不同点:Redis 支持持久化,数据可落盘;Memcached 纯内存,断电丢失。
三、安装mysql
3.1 关闭防火墙和网络增强服务
systemctl disable firewalld --now ------------------------关闭防火墙
vim /etc/selinux/config ------------------------编辑网络增强服务

3.2 解压mysql安装包与对应的依赖库boost安装包
tar zxvf mysql-5.7.17.tar.gz -C /opt------------------------------解压mysql安装包到opt下
tar zxvf boost_1_59_0.tar.gz -C /usr/local ------------------------解压boost安装包到/usr/lcoal下


3.3 安装编译安装的依赖包
yum install -y gcc gcc-c++ ncurses ncurses-devel bison cmake

3.4 创建mysql系统用户
useradd -s /sbin/nologin ------------------------创建系统用户mysql

3.5 mysql编译安装
cd /opt/mysqll-5.7.17 ------------------------切换目录
cmake
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock
-DSYSCONFDIR=/etc
-DSYSTEMD_PID_DIR=/usr/local/mysql
-DDEFAULT_CHARSET=utf8
-DDEFAULT_COLLATION=utf8_general_ci
-DWITH_EXTRA_CHARSETS=all
-DWITH_INNOBASE_STORAGE_ENGINE=1
-DWITH_ARCHIVE_STORAGE_ENGINE=1
-DWITH_BLACKHOLE_STORAGE_ENGINE=1
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1
-DMYSQL_DATADIR=/usr/local/mysql/data
-DWITH_BOOST=/usr/local/boost
-DWITH_SYSTEMD=1
make -j 4 && make install ------------------------用4个内核进行编译安装

3.6 配置mysql权限
chown -R mysql:mysql /usr/local/mysql/
chown mysql:mysql /etc/my.cnf ---------------------更改mysql配置文件的属主属组

3.7 修改配置文件
vim /etc/my.cnf ------------------------编辑mysql配置文件

3.8 设置环境变量
echo "PATH=$PATH:/usr/local/mysql/bin" >> /etc/profile ------------------追加
source /etc/profile ------------------------刷新/etc/profile文件
3.9 数据库初始化
cd /usr/local/mysql/bin/
./mysqld
--initialize-insecure
--user=mysql
--basedir=/usr/local/mysql
--datadir=/usr/local/mysql/data

3.10 启动mysql服务
cp /usr/local/mysql/usr/lib/systmed/system/mysql.service /usr/lib/systemd/system ------------------------------------将mysql服务移到system下
systemctl deamon-reload ------------------------------加载systemctl
systemctl enable mysql.server --now ------------------------启动mysql服务

3.11 账号密码管理
mysqladmin -u root -p password 123321 ------------------创建登录用户,用户名为root,密码为123321
mysql -u root -p ------------------------登录mysql数据库(密码需要输入)

输入 show Databases; 尝试进入数据库

总结
本文讲述了myql以及安装操作,希望本文能对您有所帮助,谢谢观看😜