【H2O2|全栈】MySQL的云端部署

目录

前言

开篇语

准备工作

MySQL移除

为什么需要移除?

移除操作

Yum仓库

yum简介

rpm安装

yum库安装

MySQL安装

使用yum安装

开机自启动

检查运行状态

MySQL配置

初始密码

​编辑登录

修改root密码

退出MySQL

字符集配置

重启数据库

结束语


前言

开篇语

本篇属于云端部署系列知识,为了将我们的全栈项目部署至服务器,我们需要在云端linux下实现MySQL的安装与部署。

本篇涉及运维相关的知识,我们在进行前端开发时需要进行了解。

准备工作

软件:【参考版本】Xshell7,Xftp7

服务器:腾讯云/阿里云

语言:Linux

版本信息:MySQL5.7,CentOS

服务器端口放通:3306,8080

MySQL移除

为什么需要移除?

在进行MySQL配置时,如果此前已经有出现问题的MySQL配置,比如未卸载干净的数据库和不兼容的版本(太新或太旧),则最好先将此前的MySQL移除。

移除操作

在Xshell或服务器(腾讯云为OrcaTerm)中,利用yum移除MySQL——

# 移除Mysql
yum remove mysql-server mysql-client

注意,在进行该操作之前,我们需要配置yum仓库。 

Yum仓库

yum简介

yum是包管理器,也就像一个软件下载安装管理的客户端,类似于手机里面的应用商店。

因为Linux下的软件包可能会存在着某种依赖关系(比如安装一个包需要附加安装其他包才能运行),那么此时使用yum便能够很好的解决这种依赖关系。

关于yum更加详尽的介绍,可以参考其他博主的文章,此处就不展开了。

rpm安装

rpm,全名 RedHat Package Managerment,是由Red Hat公司提出,被众多Linux发行版本所采用,是一种数据库记录的方式来将所需要的软件安装到到Linux系统的一套软件管理机制。

关于rpm的介绍,可以参考其他博主的文章,此处不详述。

安装代码如下——

# 安装rpm
sudo yum install rpm

由于MySQL并不在CentOS的官方仓库中,所以我们需要先导入MySQL的秘钥,然后再进行yum仓库配置。

安装完成之后,利用rpm更新MySQL秘钥——

# 更新密钥
rpm --import https://repo.mysql.com/RPM-GPG-KEY-mysql-2022

yum库安装

使用rpm安装MySQL的yum库——

# 安装Mysql yum库
rpm -Uvh http://repo.mysql.com//mysql57-community-release-el7-7.noarch.rpm

MySQL安装

使用yum安装

由于不需要考虑软件包之间的依赖问题,我们直接使用yum命令安装MySQL即可——

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

开机自启动

我们希望MySQL在开机的时候就处于运行状态,所以先将MySQL启动,然后为其配置开机自启——

# 启动
systemctl start mysqld
# 开机自启
systemctl enable mysqld

检查运行状态

MySQL安装完成后,会自动配置mysqld服务,可以被systemctl所管理。

使用下面的代码来检查MySQL运行状态——

# 检查运行状态
systemctl status mysqld

当出现下面的字样时,则说明MySQL处于正常运行状态——

MySQL配置

在本步骤中,主要配置管理员用户root的密码以及配置允许远程登录的权限。

初始密码

MySQL的初始密码通常保存在/var/log/mysqld.log文件中,想要获取该密码,我们可以使用grep命令过滤出含有密码的语句——

# 通过grep命令,在/var/log/mysqld.log文件中,过滤temporary password关键字,得到初始密码
grep 'temporary password' /var/log/mysqld.log

比如,下面的红色框中的就是初始密码(每个人不一样)——

登录

使用下面的命令,进入输入密码的命令行——

# 准备输入密码
mysql -uroot -p 

-u,登陆的用户,MySQL数据库的管理员用户同Linux一样,是root,因此这里是-uroot。

-p,表示使用密码登陆。

在出现的提示输入密码处,将我们之前的初始密码复制粘贴过来——

注意,密码是不显示的,不要认为是卡了就重复输入。

当出现下面的命令行提示时,说明MySQL就可以正常使用了。

修改root密码

显然,初始密码还是有些太复杂了,我们可以通过下面的代码,进行对初始密码的修改——

# 在MySQL控制台进行密码修改操作
ALTER USER 'root'@'localhost' IDENTIFIED BY '你的密码';

密码需要符合:大于8位,有大写字母,有特殊符号,不能是连续的简单语句如123,abc。

如果我们需要设置简单、好记的密码,则在设置密码之前还需要进行下面的操作(实际开发中不建议用,这里只是为了方便)——

# 如果你想设置简单密码,需要降低Mysql的密码安全级别
set global validate_password_policy=LOW; # 密码安全级别低
set global validate_password_length=4;	 # 密码长度最低4位即可

退出MySQL

在mysql控制台,使用exit命令退出MySQL——

exit;

字符集配置

数据库字符集未设定的情况下,导入数据会因为字符集的问题而导致导入失败,所以在数据导入前,需要重新设置数据库字符集配置。

退出MySQL后,使用vi命令打开mysql的配置文件——

vi /etc/my.cnf

点击i进入编辑模式,为字符集文件增添下面的配置——

[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8[mysqld]
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB

完整结构如下——

# For advice on how to change settings please see
# http://dev.mysql.com/doc/refman/5.7/en/server-configuration-defaults.html
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8[mysqld]
#
# Remove leading # and set to the amount of RAM for the most important data
# cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.
# innodb_buffer_pool_size = 128M
#
# Remove leading # to turn on a very important data integrity option: logging
# changes to the binary log between backups.
# log_bin
#
# Remove leading # to set options mainly useful for reporting servers.
# The server defaults are faster for transactions and fast SELECTs.
# Adjust sizes as needed, experiment to find the optimal values.
# join_buffer_size = 128M
# sort_buffer_size = 2M
# read_rnd_buffer_size = 2M
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

点击Esc退出编辑模式,输入下面的命令保存并退出——

:wq!

重启数据库

在完成设置前, 我们还需要重启数据库,确保我们的设置得到应用。

在根目录下,输入下面的指令实现数据库的重启——

systemctl restart mysqld

至此,我们完成了MySQL的云端配置。 

结束语

本期内容到此结束。关于本系列的其他博客,可以查看我的云端部署专栏。

在全栈领域,博主也只不过是一个普通的萌新而已。本系列的博客主要是记录一下自己学习的一些经历,然后把自己领悟到的一些东西总结一下,分享给大家。

文章全篇的操作过程都是笔者亲自操作完成的,一些定义性的文字加入了笔者自己的很多理解在里面,所以仅供参考。如果有说的不对的地方,还请谅解。

==期待与你在下一期博客中再次相遇==

——放了挺久的【H2O2】

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/60050.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

DAY30|贪心算法Part04|LeetCode:452. 用最少数量的箭引爆气球、435. 无重叠区间、763.划分字母区间

目录 LeetCode:452. 用最少数量的箭引爆气球 基本思路 C代码 LeetCode:435. 无重叠区间 基本思路 C代码 LeetCode:763.划分字母区间 基本思路 C代码 LeetCode:452. 用最少数量的箭引爆气球 力扣代码链接 文字讲解:LeetCode:452. 用最少数量的箭引爆气球 视…

Enterprise Architect 16 下载、安装与无限30天操作

文章目录 Enterprise Architect 16 简介(一)支持多种建模语言和标准(二)强大的版本控制、协作和文档管理功能(三)增强的技术和用户体验(四)高级功能和扩展性 一,下载软件…

31.3 XOR压缩和相关的prometheus源码解读

本节重点介绍 : xor 压缩value原理xor压缩过程讲解xor压缩prometheus源码解读xor 压缩效果 xor 压缩value原理 原理:时序数据库相邻点变化不大,采用异或压缩float64的前缀和后缀0个数 xor压缩过程讲解 第一个值使用原始点存储计算和前面的值的xor 如果XOR值为0&…

解决 IDEA 修改代码重启不生效的问题

前言 在使用 IntelliJ IDEA 进行 Java 项目开发时,有时会遇到一个令人头疼的问题:修改了代码后,重启服务却发现更改没有生效。通常情况下,解决这个问题需要通过 Maven 的 clean 和 compile 命令来强制重新编译,但这显…

java 根据 pdf 模板带图片文字生成pdf文件

在现代应用开发中,自动生成包含动态内容的 PDF 文档在电子发票、合同生成、表单填充等场景中有着广泛的应用。本文将介绍如何使用 iText 库动态填充 PDF 模板字段,并在指定位置插入签名和公章图片。 项目需求 假设我们有一个 PDF 模板文件,包含表单字段,如用户姓名、地址…

MTK主板定制_联发科主板_MTK8766/MTK8768/MTK8788安卓主板方案

主流市场上的MTK主板通常采用联发科的多种芯片平台,如MT8766、MT6765、MT6762、MT8768和MT8788等。这些芯片基于64位Cortex-A73/A53架构,提供四核或八核配置,主频可达2.1GHz,赋予设备卓越的计算与处理能力。芯片采用12纳米制程工艺…

Windows仿macOS?看这一篇就够了

如果你有任何关于Windows仿macOS的问题,可加入942644281 (QQ群) Date9.20更新:增加功能按键左移部分Date9.16更新:增加了大多数资源的网盘链接Date9.15更新:增加StartAllBack,资源管理器调整部…

无法下载element-admin的依赖无法运行

目录 无法下载element-admin的依赖偷懒方法完美方法 运行element-admin错误 之前在下载element-admin时遇到了多多少少的问题 无法下载element-admin的依赖 偷懒方法 开始是从github下载源码后安装依赖时在与tui-editor相关的依赖时就会卡死,然后报错&#xff0c…

基于Java Springboot幼儿园管理系统

一、作品包含 源码数据库设计文档万字PPT全套环境和工具资源部署教程 二、项目技术 前端技术:Html、Css、Js、Vue、Element-ui 数据库:MySQL 后端技术:Java、Spring Boot、MyBatis 三、运行环境 开发工具:IDEA/eclipse 数据…

新一代API开发工具,让API调试更快 更简单

新一代API开发工具 代理调试 请求测试一站式解决方案 Reqable Fiddler Charles Postman, 让API调试更快 🚀 更简单 👌 直接上下载地址 根据系统,下载对应的版本即可 https://reqable.com/zh-CN/download/

Python | Leetcode Python题解之第564题寻找最近的回文数

题目: 题解: class Solution:def nearestPalindromic(self, n: str) -> str:m len(n)candidates [10 ** (m - 1) - 1, 10 ** m 1]selfPrefix int(n[:(m 1) // 2])for x in range(selfPrefix - 1, selfPrefix 2):y x if m % 2 0 else x // 10…

爬虫——数据解析与提取

第二节:数据解析与提取 在网络爬虫开发中,获取网页内容(HTML)是第一步,但从这些内容中提取有用的数据,才是爬虫的核心部分。HTML文档通常结构复杂且充满冗余信息,因此我们需要使用高效的解析工…

使用 Ant Design Vue 自定渲染函数customRender实现单元格合并功能rowSpan

使用 Ant Design Vue 自定渲染函数customRender实现单元格合并功能rowSpan 背景 在使用Ant Design Vue 开发数据表格时,我们常常会遇到需要合并单元格的需求。 比如,某些字段的值可能会在多行中重复出现,而我们希望将这些重复的单元格合并为…

RabbitMQ教程:发布/订阅模式(Publish/Subscribe)(三)

文章目录 RabbitMQ教程:发布/订阅模式(Publish/Subscribe)(三)一、引言二、简介三、准备工作3.1 说明3.2 生成项目 四、实战4.1 交换机(Exchanges)4.2 临时队列(Temporary Queues&am…

CANoe发送和接收CAN DataBase(DBC文件)数据

目录 1、接收CAN数据,DBC解析数据内容 2、发送DBC定义的CAN报文 CANoe是一款强大的网络仿真和开发工具,它支持发送和接收基于CAN DataBase(DBC文件)的数据。 1、接收CAN数据,DBC解析数据内容 要使用CANoe接收CAN数…

【第六课】Rust所有权系统(二)

目录 前言 借用和引用 借用规则 切片和迭代器 总结 前言 上节课介绍了Rust中的所有权系统,简单回顾一下,rust的内存系统系统,每一块内存都有一个主人,主人对这块内存有着读写和释放的权限,当主人离开作用域之后&am…

ISUP协议视频平台EasyCVR私有化部署视频平台如何实现RTMP推流将大疆无人机的视频画面回传?

在现代视频监控和流媒体技术领域,EasyCVR视频融合云平台以其卓越的性能和灵活性,成为了跨区域、网络化视频监控综合管理的理想选择。作为TSINGSEE青犀视频“云边端”架构体系中的核心组件,私有化部署视频平台EasyCVR不仅能够实现视频数据的集…

排序算法 -归并排序

文章目录 1. 归并排序(Merge Sort)1.1 简介1.2 归并排序的步骤1.3 归并排序c 语言实现代码说明 1.4 时间复杂度1.5 空间复杂度1.6 动画 1. 归并排序(Merge Sort) 1.1 简介 归并排序(Merge Sort)是一种基于…

unity 一个物体随键盘上下左右旋转和前进的脚本

注意:脚本挂在gamaobject 上面 ,操作对象的目标 this.gameObject 为操作对象 using System.Collections; using System.Collections.Generic; using UnityEngine;public class changePosition : MonoBehaviour {//操作对象的目标 this.gameObject 为操…

视频里的音频怎么提取出来成单独文件?音频提取照着这些方法做

在数字时代,视频与音频的分离与重组已成为日常需求之一。无论是出于制作背景音乐、保存讲座内容,还是编辑播客素材,提取视频中的音频并将其保存为单独文件都显得尤为重要。视频里的音频怎么提取出来成单独文件?本文将详细介绍几种…