使用脚本搭建MySQL数据库基础环境

数据库的基本概念

数据(Data)

描述事物的符号记录

包括数字,文字,图形。图像,声音,档案记录等。

以记录形式按统一格式进行存储

将不同的记录组织在一起

用来储存具体数据

数据库

表的集合,是储存数据的仓库

以一定的组织方式存储的相互有关的数据集合

数据库管理系统(DBMS)

是实现对数据库资源有效组织,管理和存取的系统软件

数据库系统

是一个人机系统,由硬件,OS,数据库,DBMS,应用软件和数据库用户组成

用户可以通过DBMS或应用程序操作数据库

数据库系统发展史

第一代数据库

20世纪60年代起,第一代数据库系统问世

是层次模型和网状模型的数据库系统

为统一管理和共享数据提供了有力的支撑

第二代数据库

20世纪70年代初,第二代数据库------关系数据库开始出现

20世纪80年代,IBM公司的关系数据库系统DB2问世,开始逐步取代层次与网状模型的数据库,成为行业主流

到目前为止,关系数据库系统仍然占领数据库应用的主要地位

主流数据库

SQL SERVER(微软公司产品)

面向Windows操作系统

简单,易用

Oracle(甲骨文公司产品)

面向所有主流平台

DB2(IBM公司产品)

面向所有主流平台

大型,安全,完善

MySQL(甲骨文公司收购)

开源,免费,体积小

非关系数据库介绍

非关系数据库也被称作NoSQL

存储数据不以关系模型为依据,不需要固定的表格式

非关系型数据库的优点

数据库可高并发读写

对海量数据高效率存储和访问

数据库具有高拓展性和高可用性

常用的非关系数据库:Redis,mongoDB等

MySQL数据库介绍

一款深受欢迎的开源关系型数据库

Oracle旗下产品

遵守GPL协议,可以免费使用与修改

特点

性能卓越,服务稳定

开源无版权限制,成本低

多线程,多用户

基于C/S(客户端/服务器)架构

安全可靠

在这上面需要有一个关于MySQL的一个包mysql-5.7.28-linux-glibc2.12-x86_64.tar.gz

复制代码
#这里是编写脚本

vi  test.sh

#脚本内容
yum -y install gcc vim wget net-tools lrzsz
yum -y install libaio
useradd -M -s /sbin/nologin mysql
sed -i 's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config
setenforce 0
systemctl disable firewalld
systemctl stop firewalld
tar zxf mysql-5.7.28-linux-glibc2.12-x86_64.tar.gz
mv mysql-5.7.28-linux-glibc2.12-x86_64 /usr/local/mysql 
mkdir /usr/local/mysql/data
chown -R mysql.mysql /usr/local/mysql/data
cd /usr/local/mysql/bin
./mysqld --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --initialize
#这里会显示你的密码
cat > /etc/my.cnf << 'EOF'
[client]
socket=/usr/local/mysql/data/mysql.sock
[mysqld]
socket=/usr/local/mysql/data/mysql.sock
bind-address = 0.0.0.0
skip-name-resolve
port = 3306
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
max_connections=2048
character-set-server=utf8
default-storage-engine=INNODB
lower_case_table_names=1
max_allowed_packet=16M
EOF
echo "export PATH=$PATH:/usr/local/mysql/bin">> /etc/profile
. /etc/profile
cp /usr/local/mysql/support-files/mysql.server /etc/rc.d/init.d/mysqld 
chmod +x /etc/rc.d/init.d/mysqld
cat >> /lib/systemd/system/mysqld.service << 'EOF' 
[Unit]
Description=mysqld
After=network.target

[Service]
Type=forking
ExecStart=/etc/rc.d/init.d/mysqld start
ExecReload=/etc/rc.d/init.d/mysqld restart
ExecStop=/etc/rc.d/init.d/mysqld stop

PrivateTmp=true


[Install]
WantedBy=multi-user.target
EOF
systemctl daemon-reload
systemctl enable mysqld
systemctl start mysqld
netstat -tunlp|grep 3306
#这里是进入数据库了,下一步是输入密码
mysql -u root -p

#保存退出后给个权限执行脚本
chmod +x test.sh
./test.sh

#执行完脚本之后可以在MySQL里面更改密码
mysql> set password=password('123456');        #修改密码(在这里面我修改的密码是123456)
然后可以exit退出

这就是一整个脚本编译过程

相关推荐
酉鬼女又兒1 小时前
SQL24 统计每个用户的平均刷题数
数据库·sql·mysql
雷工笔记2 小时前
数据库|SQLServer2025安装教程
数据库·sqlserver
一只自律的鸡2 小时前
【MySQL】第六章 子查询
数据库·mysql
Knight_AL2 小时前
Spring Boot 事件机制详解:原理 + Demo
java·数据库·spring boot
野人李小白2 小时前
DBeaver 界面友好,支持多种数据库,具备强大的 SQL 编辑、可视化查询、数据迁移及插件扩展功能,是开发者首选的数据库管理工具。
数据库·sql
山峰哥2 小时前
SQL索引优化实战:3000字深度解析查询提速密码
大数据·数据库·sql·编辑器·深度优先
观音山保我别报错3 小时前
消息队列项目基础知识总结
linux·服务器·数据库
jghhh013 小时前
MATLAB分形维数计算:1D/2D/3D图形的盒维数实现
数据库·matlab
weixin_462446233 小时前
一键安装 MySQL 5.7(CentOS 7)自动化脚本详解
mysql·centos·自动化
重生之绝世牛码4 小时前
Linux软件安装 —— PostgreSQL高可用集群安装(postgreSQL + repmgr主从复制 + keepalived故障转移)
大数据·linux·运维·数据库·postgresql·软件安装·postgresql高可用