Linux——MySQL数据库部署及自建数据库mysql-yum仓库

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 我们耳熟能详的软件,包括游戏、淘宝各类软件APP,都会用到数据库,数据库存储的数据包括:用户的账号密码,用户的金额余额,以及购物的记录收藏记录,以及游戏的装备信息,等级信息等,只要是信息都会存储在数据库中。

前言


数据库能做什么?

 我们耳熟能详的软件,包括游戏、淘宝各类软件APP,都会用到数据库,数据库存储的数据包括:用户的账号密码,用户的金额余额,以及购物的记录收藏记录,以及游戏的装备信息,等级信息等,只要是信息都会存储在数据库中。


数据库的安装部署


1、环境准备

关闭防火墙:

停止防火墙:systemctl    stop   firewalld

关闭防火墙开机自启:systemctl    disable     firewalld

关闭selinux:setenforce    0

关闭selinux开机自启:vim   /etc/selinux/config          修改:SELINUX=disabled

2、安装MySQL


2.1下载需要的RPM包

这里介绍的是RPM安装MySQL,centos8,centos9建议RPM安装MySQL。

首先在国内镜像网站下载需要的RPM包(Index of /mysql-repo/yum/mysql-8.0-community/el/9/x86_64/)。


通过wget命令进行下载需要的RPM包:

wget   http://mirrors.ustc.edu.cn/mysql-repo/yum/mysql-8.0-community/el/9/x86_64/mysql-community-server-8.0.33-1.el9.x86_64.rpm

wget   http://mirrors.ustc.edu.cn/mysql-repo/yum/mysql-8.0-community/el/9/x86_64/mysql-community-libs-8.0.33-1.el9.x86_64.rpm

wget   http://mirrors.ustc.edu.cn/mysql-repo/yum/mysql-8.0-community/el/9/x86_64/mysql-community-icu-data-files-8.0.33-1.el9.x86_64.rpm

wget   http://mirrors.ustc.edu.cn/mysql-repo/yum/mysql-8.0-community/el/9/x86_64/mysql-community-common-8.0.33-1.el9.x86_64.rpm

wget   http://mirrors.ustc.edu.cn/mysql-repo/yum/mysql-8.0-community/el/9/x86_64/mysql-community-client-plugins-8.0.33-1.el9.x86_64.rpm

wget   http://mirrors.ustc.edu.cn/mysql-repo/yum/mysql-8.0-community/el/9/x86_64/mysql-community-client-8.0.33-1.el9.x86_64.rpm


通过ls查看当前目录内容,可以看到这些我们需要的RPM包已经下载完成。


b56f8516b03f4b8cb11e69f281d4e858.png


也可以通过下载MySQL的仓库进行安装。

wget     http://mirrors.ustc.edu.cn/mysql-repo/yum/mysql-8.0-community/el/9/x86_64/mysql80-community-release-el9-1.noarch.rpm

yum  install  -y   mysql80-community-release-el9-1.noarch.rpm

yum   install  -y   mysql-community-server

2.2、安装相关软件以及MySQL服务

安装相关软件:yum install -y net-tools.x86_64 libaio  perl.x86_64

安装MySQL服务:yum install -y *.rpm  安装当前目录下的所有rpm包。

因为在root的家目录下我只有刚刚下载的MySQL的RPM包所有使用这个命令一键安装,如果仅仅安装mysql-community-server,会提示报错缺少相关程序。


2.3、启动MySQL服务

启动mysql服务:systemctl   start  mysqld

设置mysql服务开机自启:systemctl enable mysqld

查看mysql服务状态:systemctl status mysqld


ae47f059f439467cbf8b738332981cc2.png


2.4、查看默认mysql密码并用登录mysql

mysql服务启动后,会生成一个默认密码,这个密码会记录在MySQL的日志中,可以通过grep来过滤查看mysql日志。

查看默认mysql密码:grep 'password' /var/log/mysqld.log

在localhost后面不管出现什么字符,都是密码的内容。


f158c5ffa4c2460681f31802c7f380cc.png


通过复制该密码登录数据库。

mysql     -uroot    -p'kks&F_*WU9tf'

注意:-u后面紧跟账号,-p后面紧跟密码


50ffde5ca6324af4979cf32fb3d238ad.png

看到这个页面就代表登录成功


2.5、更改数据库管理员登录密码

数据库部署完成后不能够每次都去查默认的密码区登录数据库,这个时候需要更改成为我们自己的密码。

mysqladmin   -uroot  -p'kks&F_*WU9tf'     password   '需要更改的密码'

注意:-p后面紧跟密码,password后面要加空格再输入需要更改的密码,这里的密码要有大小写字母、特殊符号、数字。


9720ea680be9492a93e45b5ba77f0fb3.png


这个提示是警告提示不是错误提示就代表成功,可以用修改后的密码登录数据库了。


自建mysql-yum仓库

因为在网上下载包会比较慢,我们可以自建一个mysql的yum仓库供其他客户端进行本地下载,速度就想对比较快。


服务器端操作


1、下载安装ftp

yum   install  -y   vsftpd


2、准备ftp目录

mkdir   /var/ftp/mysql80


3、下载mysql仓库

上面介绍的

wget     http://mirrors.ustc.edu.cn/mysql-repo/yum/mysql-8.0-community/el/9/x86_64/mysql80-community-release-el9-1.noarch.rpm

yum  install  -y   mysql80-community-release-el9-1.noarch.rpm

4、仅下载不安装mysql

yum    install    -y    --downloadonly     mysql-community-server

这里下载成功后就是我们上面RPM安装的时候那六个包。


5、将下载好的RPM包复制到刚刚创建的ftp目录去

如果是按照第四步做的。这些包在 /var/cache/dnf/mysql80-community-22d3d3ecd3d92106/packages/*里,也可以通过find命令去查找。

我是用刚刚RPM安装的时候的包:

cp   -rf    ./*.rpm    /var/ftp/mysql80/

ls   /var/ftp/mysql80/     查看ftp目录下面的复制情况  


f6fc7af06255446c9399d9ff06cb29d0.png


6、创建依赖

createrepo  /var/ftp/mysql80/                创建依赖


830a840624a8478cbe069cdc0b0f6829.png


这里提示没有找到createrepo命令。


查找createrepo命令需要的安装包

yum provides createrepo


463dddbf3fe34f018d5e881214f8168f.png


 安装createrepo_c

yum install -y createrepo_c

再次使用createrepo命令进行创建依赖

createrepo  /var/ftp/mysql80/


fe23119dcc5e48a1bbef6fbadf4069ad.png


创建成功!


7、启动ftp服务

在启动之前需要对ftp开启允许匿名访问的配置

vim  /etc/vsftpd/vsftpd.conf                anonymous_enable=YES

启动ftp服务

systemctl  start   vsftpd

设置开机vaftpd自启

systemctl  enable    vsftpd

查看vsftpd状态

systemctl  status  vsftpd


8888851e3497450ead8ff8f3860fcd60.png

0fe264723966464c90024c4d20258e22.png


客户机操作(换一台新的虚拟机,关闭防火墙)


1、自建yum仓库

vim /etc/yum.repos.d/mysql80.repo


d59003269b40402f913b600b5d66bc58.png


2、安装mysql

yum  makecache        刷新yum仓库

yum install -y mysql-community-server        安装mysql

发现这次下载的mysql是从自建的yum仓库下载的安装包,速度很快。


fe128f06ef564908a8cac2a5f344198f.png


3、测试启动mysql服务,并修改默认密码,登录mysql

[root@localhost ~]# systemctl start mysqld.service

[root@localhost ~]# systemctl enable mysqld

[root@localhost ~]# systemctl status mysqld.service

查看默认密码

[root@localhost ~]# grep 'password' /var/log/mysqld.log

2023-06-12T05:57:27.580412Z 6 [Note] [MY-010454] [Server] A temporary password is generated for root@localhost: mUZNuXb>8z5+

修改密码

[root@localhost ~]# mysqladmin  -uroot  -p'mUZNuXb>8z5+'   password   'Sure.520'

mysqladmin: [Warning] Using a password on the command line interface can be insecure.

Warning: Since password will be sent to server in plain text, use ssl connection to ensure password safety.


84e5df963b494e419c3e0c4d7cfdecdc.png


使用修改后的密码登录mysql。


2c5e8ab48a8f492883962db5f4631424.png


到这部署mysql服务器就介绍完了。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
8天前
|
关系型数据库 MySQL 数据库连接
数据库连接工具连接mysql提示:“Host ‘172.23.0.1‘ is not allowed to connect to this MySQL server“
docker-compose部署mysql8服务后,连接时提示不允许连接问题解决
|
2月前
|
消息中间件 Java Kafka
【手把手教你Linux环境下快速搭建Kafka集群】内含脚本分发教程,实现一键部署多个Kafka节点
本文介绍了Kafka集群的搭建过程,涵盖从虚拟机安装到集群测试的详细步骤。首先规划了集群架构,包括三台Kafka Broker节点,并说明了分布式环境下的服务进程配置。接着,通过VMware导入模板机并克隆出三台虚拟机(kafka-broker1、kafka-broker2、kafka-broker3),分别设置IP地址和主机名。随后,依次安装JDK、ZooKeeper和Kafka,并配置相应的环境变量与启动脚本,确保各组件能正常运行。最后,通过编写启停脚本简化集群的操作流程,并对集群进行测试,验证其功能完整性。整个过程强调了自动化脚本的应用,提高了部署效率。
【手把手教你Linux环境下快速搭建Kafka集群】内含脚本分发教程,实现一键部署多个Kafka节点
|
2月前
|
关系型数据库 MySQL Linux
Linux下mysql数据库的导入与导出以及查看端口
本文详细介绍了在Linux下如何导入和导出MySQL数据库,以及查看MySQL运行端口的方法。通过这些操作,用户可以轻松进行数据库的备份与恢复,以及确认MySQL服务的运行状态和端口。掌握这些技能,对于日常数据库管理和维护非常重要。
108 8
|
2月前
|
Ubuntu 网络协议 Linux
快速部署WSL(Windows Subsystem for Linux)
WSL提供了一种轻量级的方法,使开发者能够在Windows上无缝运行Linux环境。通过本文介绍的步骤,可以快速安装、配置和使用WSL,以满足开发和测试的需求。
127 8
|
12天前
|
缓存 关系型数据库 MySQL
【深入了解MySQL】优化查询性能与数据库设计的深度总结
本文详细介绍了MySQL查询优化和数据库设计技巧,涵盖基础优化、高级技巧及性能监控。
116 0
|
2月前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
65 3
|
2月前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
89 3
|
2月前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE 'log_%';`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
97 2
|
2月前
|
SQL 关系型数据库 MySQL
数据库数据恢复—Mysql数据库表记录丢失的数据恢复方案
Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何数据或只有部分数据。 2、客户端无法查询到完整的信息。
|
2月前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
299 15