首页 > 数据库 >【H2O2|全栈】MySQL的云端部署

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

时间:2024-11-18 12:15:16浏览次数:3  
标签:H2O2 MySQL 字符集 密码 全栈 yum mysql mysqld

目录

前言

开篇语

准备工作

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=0

log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

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

:wq!

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

结束语

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

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

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

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

——放了挺久的【H2O2】

 

标签:H2O2,MySQL,字符集,密码,全栈,yum,mysql,mysqld
From: https://blog.csdn.net/ZC13786305863/article/details/143844637

相关文章

  • MySQL无开通SQL全审计下的故障分析方法
       几年前MySQL数据库出现突然的从库延迟故障和CPU爆高时,如何排查具体原因,可能说已在腾讯云的MySQL库里开启了SQL全审计,记录了全部执行的SQL,再通过下面的方法就可以很容易找到原因:     1,实用QPS和TPS高的高效分析方法   但如果没有开通SQL全审计,如何去找......
  • 深入探索MySQL多表查询:连接查询与子查询的艺术
    深入探索MySQL多表查询:连接查询与子查询的艺术在数据库操作中,多表查询是一项常见且重要的任务。无论是为了获取更全面的数据,还是为了实现复杂的业务逻辑,多表查询都是不可或缺的工具。MySQL提供了两种主要的多表查询方式:连接查询和子查询。本文将深入探讨这两种查询方式的规律、优......
  • Windows10安装MySQL8.0.40
    官网地址https://www.mysql.com/环境查看Windows10MySQL8.0.40下载MySQL打开首页-下载-MySQL社区版本下载本次下载Window10的安装版本,其他系统如Linux,Mac可根据需要自行选择需要登录Oracle账号才能下载,如果没有账号则注册一个登录安装双击下载的软件开始......
  • 28. 使用MySQL之安全管理
    1.访问控制MySQL服务器的安全基础是:用户应该对他们需要的数据具有适当的访问权,既不能多也不能少。换句话说,用户不能对过多的数据具有过多的访问权。考虑以下内容:多数用户只需要对表进行读和写,但少数用户甚至需要能创建和删除表;某些用户需要读表,但可能不需要更新表;你......
  • 红队全栈课程之渗透测试导学
    声明学习视频来自B站up主泷羽sec,如有涉及侵权马上删除文章。在学习的过程中记笔记,分享笔记方便各位师傅学习,以下内容只涉及学习内容,任何其他违法行为与本人及泷羽sec无关,请务必遵守法律法规,切莫逾越法律红线切莫逾越法律红线。B站UP链接:https://space.bilibili.com/3503......
  • 计算机毕业设计在线购物商城超市购物系统日用品商城小商品在线购买网站php+mysql+html
     一.功能介绍用户前台功能:前台主要包括网站首页、今日特卖、限时打折、商品中心、常见问题、我的购物车、登录、注册、商品详情,联系卖家,加入购物车、结算、个人中心等功能模块。今日特卖、限时打折、商品中心模块,用户可以查看全部商品信息,联系卖家、选择商品进行添加购物......
  • php毕业设计购物商城在线购物系统美食购物商城外卖系统点餐系统美食网站php+mysql+htm
    一,功能介绍        前台主要包括网站首页、商品推荐、最新商品、新闻咨询、商品分类、商品资讯、评论、登录、注册、加入购物车、结算、个人中心等功能模块商品推荐、最新商品在商品推荐、最新商品模块,用户可以查看全部商品信息,选择商品进行添加购物车等操作,购物......
  • 基于Java+SSM+JSP+MYSQL实现的宠物领养收养管理系统功能设计与实现六
    一、前言介绍:免费学习:猿来入此1.1项目摘要随着人们生活水平的提高,宠物已经成为越来越多家庭的重要成员。然而,宠物的数量增长也带来了一系列问题,如流浪宠物数量的增加、宠物健康管理的缺失以及宠物领养收养信息的不透明等。这些问题不仅影响了宠物的生存状况,也给社会带来了一定......
  • 基于Java+SSM+JSP+MYSQL实现的宠物领养收养管理系统功能设计与实现五
    一、前言介绍:免费学习:猿来入此1.1项目摘要随着人们生活水平的提高,宠物已经成为越来越多家庭的重要成员。然而,宠物的数量增长也带来了一系列问题,如流浪宠物数量的增加、宠物健康管理的缺失以及宠物领养收养信息的不透明等。这些问题不仅影响了宠物的生存状况,也给社会带来了一定......
  • mysql如何批量删除海量数据
    一、删除大表的部分数据一个表有1亿6000万的数据,有一个自增ID。最大值就是1亿6000万,需要删除大于250万以后的数据,有什么办法可以快速删除?看到mysql文档有一种解决方案:http://dev.mysql.com/doc/refman/5.0/en/delete.htmlIfyouaredeletingmanyrowsfromalargetable,......