MySQL部署系列-centos离线安装MySQL

MySQL部署系列-centos离线安装MySQL

文章目录

  • MySQL部署系列-centos离线安装MySQL
    • 1. 查看是否已经安装 Mysql
    • 3. 下载官方 Mysql 包
    • 3. 下载之后上传到服务器
    • 4. 创建用户组
    • 5. 创建数据目录并赋予权限
    • 6. 修改配置文件 `vim /etc/my.cnf`
    • 7. 初始化数据库(数据库安装)
    • 8. 加入到系统服务并启动mysql
    • 9. 允许外部访问
    • 10. 参考和感谢

1. 查看是否已经安装 Mysql

rpm -qa | grep mysql

如果没有什么返回信息,说明没有安装 Mysql,如果已安装就需要卸载

3. 下载官方 Mysql 包

MySQL官网社区版本下载传送门

特别说明:

  • MySQL有两个大版本,分别是5.x.x系列和8.x.x系列
  • MySQL升级,建议选择相同系列版本中最新的版本

3. 下载之后上传到服务器

个人喜欢放置在/opt/software目录下

解压至 /usr/local/mysql 目录下

# 解压文件至/usr/local/目录
tar -zxvf mysql-5.7.44-linux-glibc2.12-x86_64.tar.gz
# 移动至/usr/local/mysql下
mv mysql-5.7.44-linux-glibc2.12-x86_64 /usr/local/mysql

4. 创建用户组

在安装MySQL时创建mysql用户和mysql用户组是为了提高系统安全性以及限制MySQL服务的运行权限。通常情况下,MySQL服务运行时以mysql用户的身份来进行,这样可以降低系统受到MySQL服务影响的风险。

创建mysql用户和mysql用户组的目的包括:

  1. 隔离权限: 通过将MySQL服务限制在只能以mysql用户的身份来运行,可以降低系统其他部分受到影响的可能性。即使MySQL服务出现安全问题或漏洞,也只会影响到mysql用户及其所属的文件和目录。

  2. 安全审计: 在操作系统中创建mysql用户和mysql用户组,可以更好地跟踪MySQL服务的活动、日志和文件权限。这有助于加强对MySQL服务的监控和安全审计。

  3. 最小权限原则: 创建专门的mysql用户和mysql用户组,并为其分配最小化的权限,有助于按照最小权限原则来管理MySQL服务,降低服务被滥用或遭受攻击的风险。

# 创建用户组
groupadd mysql    
# -r 选项:表示创建一个系统用户,系统用户通常用于运行系统服务和应用程序,其UID会被限制在不同的范围内,提供更高的安全性。
# -g mysql 选项:表示将该用户添加到mysql用户组中,这样用户将拥有mysql用户组的权限。
# mysql:是要创建的用户的用户名。
useradd -r -g mysql mysql

分配用户组

# 将文件的所有属性改为 mysql 用户
chown -R mysql /usr/local/mysql/ 
# 将组属性改为 mysql 组
chgrp -R mysql /usr/local/mysql/ 

5. 创建数据目录并赋予权限

#数据目录
mkdir -p /data/mysql 
#赋予权限
chown mysql:mysql -R /data/mysql

6. 修改配置文件 vim /etc/my.cnf

[mysqld]
bind-address=0.0.0.0
port=3306
user=mysql
basedir=/usr/local/mysql
datadir=/data/mysql
socket=/tmp/mysql.sock
log-error=/data/mysql/mysql.err
pid-file=/data/mysql/mysql.pid
#character config
character_set_server=utf8mb4
symbolic-links=0
explicit_defaults_for_timestamp=true

7. 初始化数据库(数据库安装)

参数解释:

  • --basedir 为mysql解压目录
  • –datadir 为mysql数据存放目录。(注意安装路径是否一致)
  • --defaults-file 配置文件
cd /usr/local/mysql/bin/
./mysqld --defaults-file=/etc/my.cnf --basedir=/usr/local/mysql/ --datadir=/data/mysql/ --user=mysql --initialize

查看初始密码

cat /data/mysql/mysql.err

记录初始密码,后面要使用

8. 加入到系统服务并启动mysql

#加入系统服务
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql
#启动mysql服务
service mysql start

登录mysql,一定要开启服务后才能登陆

/usr/local/mysql/bin/mysql -u root -p

输入上述记录的临时密码,登录成功后会提示你重置密码

# 修改密码,SQL语句后面的分号不能丢(xxxx就是root账号的密码)
ALTER USER 'root'@'localhost' IDENTIFIED BY 'xxxx';
#刷新 
FLUSH PRIVILEGES;     

重启mysql

# 退出 
quit
# 重启服务
service mysql restart
# 再次登陆 
/usr/local/mysql/bin/mysql -u root -p
# 回车输入刚刚修改的密码

到此mysql已经安装完成了,下面是常见的mysql命令

# 停止mysql服务
service mysqld stop# 重启mysql服务
service mysqld restart# 查看mysql服务是否启动
service mysqld status

9. 允许外部访问

使用客户端工具连接mysql时提示,这是因为root账号默认只有localhost才能连接

"Host 'xxx' is not allowed to connect to this MySQL server"

解决方法:登录mysql服务,修改root账号访问规则

#选择访问mysql库
use mysql  
#使root能再任何host访问
update user set host = '%' where user = 'root';      
#刷新 
FLUSH PRIVILEGES;       

10. 参考和感谢

CentOS离线安装MySQL

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

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

相关文章

【3dmax笔记】035: 车削修改器

一、车削修改器介绍 车削:图形通过绕轴旋转来创建三维效果。 开放的样条线,车削之后是面片。闭合的样条线,车削之后,是实体。 一、车削修改器实例 绘制高脚杯,首先在前视图绘制如下二维图形。 添加一个车削的修改器…

(六)JSP教程——out对象

out对象是在JSP中经常使用到的对象,它本质上是一个输出流,前面已经多次使用,我们经常使用它的print()和println()方法,这些方法主要用于实现客户端数据的输出。通过out对象也可以直接向客户端发送一个由程序动态生成的HTML文件。 …

关于YOLO8学习(三)训练自定义的数据集

前文 关于YOLO8学习(一)环境搭建,官方检测模型部署到手机 关于YOLO8学习(二)数据集收集,处理 简介 本文将会讲解: (1)如何通过PyCharm,进行训练数据,实现人脸检测 开发环境 win10、python 3.11、cmake、pytorch2.0.1+cu117、pycharm、ultralytics==8.0.134 要特…

牛客NC97 字符串出现次数的TopK问题【中等 哈希+优先级队列 Java/Go】

题目 题目链接: https://www.nowcoder.com/practice/fd711bdfa0e840b381d7e1b82183b3ee 核心 哈希,优先级队列Java代码 import java.util.*;public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返…

[力扣]——387.字符串中的第一个唯一字符

. - 力扣&#xff08;LeetCode&#xff09; class Solution {public int firstUniqChar(String s) {int[] count new int[256];// 统计每个字符出现的次数for(int i 0; i < s.length(); i){count[s.charAt(i)];}// 找第一个只出现一次的字符for(int i 0; i < s.lengt…

QT--day3

1、mywidget.h #ifndef MYWIDGET_H #define MYWIDGET_H #include <QWidget> #include<QIcon> //图标类 #include<QLabel> //标签类 #include<QMovie> //动图类 #include<QLineEdit> //行编辑器类 #include<QPushButton> //按钮类 #include…

protobuf在配置文件管理上的应用

TextFormat::ParseFromString 是 Google Protocol Buffers&#xff08;通常简称为 Protobuf&#xff09;库中的一个函数&#xff0c;用于从文本格式解析消息。Protobuf 是一种用于序列化结构化数据的库&#xff0c;它允许你定义数据的结构&#xff0c;然后自动生成源代码来处理…

【stm-4】PWM驱动LED呼吸灯 PWM驱动舵机PWM驱动直流电机

1.PWM驱动LED呼吸灯 void TIM_OC1Init(TIM_TypeDef* TIMx, TIM_OCInitTypeDef* TIM_OCInitStruct); //结构体初始化输出比较单元 void TIM_OC2Init(TIM_TypeDef* TIMx, TIM_OCInitTypeDef* TIM_OCInitStruct); void TIM_OC3Init(TIM_TypeDef* TIMx, TIM_OCInitTypeDef*…

学习笔记:IEEE 1003.13-2003(POSIX实时与嵌入式规范)

一、文档 在线参考&#xff1a; IEEE 1003.13-2003 免费下载Draft 版本&#xff08;pdf&#xff09;&#xff1a;IEEE Std. 1003.13 二、概念 1、POSIX标准 可移植操作系统接口&#xff08;英语&#xff1a;Portable Operating System Interface&#xff0c;缩写为POSIX&a…

Bugku Crypto 部分题目简单题解

抄错的字符 题目描述&#xff1a; 老师让小明抄写一段话&#xff0c;结果粗心的小明把部分数字抄成了字母&#xff0c;还因为强迫症把所有字母都换成大写。你能帮小明恢复并解开答案吗&#xff1a; QWIHBLGZZXJSXZNVBZW 观察疑似base64解码&#xff0c;尝试使用cyberchef解码…

Springboot+vue项目人事管理系统

开发语言&#xff1a;Java 开发工具:IDEA /Eclipse 数据库:MYSQL5.7 应用服务:Tomcat7/Tomcat8 使用框架:springbootvue JDK版本&#xff1a;jdk1.8 文末获取源码 系统主要分为管理员和普通用户和员工三部分&#xff0c;主要功能包括个人中心&#xff0c;普通用户管理&…

JavaScript异步编程——04-同源和跨域

同源和跨域 同源 同源策略是浏览器的一种安全策略&#xff0c;所谓同源是指&#xff0c;域名&#xff0c;协议&#xff0c;端口完全相同。 跨域问题的解决方案 从我自己的网站访问别人网站的内容&#xff0c;就叫跨域。 出于安全性考虑&#xff0c;浏览器不允许ajax跨域获取…

VBA中类的解读及应用第十二讲:限制复选选择(上)

《VBA中类的解读及应用》教程【10165646】是我推出的第五套教程&#xff0c;目前已经是第一版修订了。这套教程定位于最高级&#xff0c;是学完初级&#xff0c;中级后的教程。 类&#xff0c;是非常抽象的&#xff0c;更具研究的价值。随着我们学习、应用VBA的深入&#xff0…

【数据链路层】以太网基础知识

文章目录 数据链路层初认识以太网 Ethernet 来历以太网发展史和地位以太网分类数据链路层的分层设计 数据链路层初认识 我们可以先打开抓包工具&#xff0c;随便查看某个协议包。会发现所有抓到的包数据链路层基本上都是以太网封装。 因为现在所接触到的网络都是以太网这种网…

阿里云SLB监听虚拟服务器组时,既有部署在k8s容器里的应用,又有部署在ecs机器上的应用,k8s应用无法连接部署在ecs机器上的应用

一、背景 阿里云SLB可以添加多个监听端口&#xff0c;包括http和tcp&#xff0c;但是当被添加的后端应用&#xff0c;既有部署在k8s里&#xff0c;也有部署在ecs机器里。同一个slb下&#xff0c;这种混合方式的监听&#xff0c;会导致部署在k8s应用中的应用无法连接后者&#…

Pytharm2020安装详细教程

Pytharm2020版提取链接链接&#xff1a; https://pan.baidu.com/s/1eDvwYmUJ4l7kIBXewtN4EA?pwd1111 提取码&#xff1a;1111 演示版本为2019版&#xff0c;链接包为2020版pytharm。 1.双击exe文件页面会提示更改选项&#xff0c;点击“是”。 2.点击下一步next 自…

(1)探索 SpringAI - 基本概述

人工智能简介 A system is ability to correctly interpret external data, to learn from such data, and to use those learnings to achieve specific goals and tasks through flexible adaptation. 翻译&#xff1a;系统正确解释外部数据的能力&#xff0c;从这些数据中学…

《武林秘籍》——闪侠惠递如何让消费者寄快递更安心!

现如今&#xff0c;网上下单寄快递的便利性让众多人享受到了电商物流飞速发展带来的红利性。今天小编直接介绍一款寄快递特别省钱的利器&#xff0c;就是利用闪侠惠递来寄快递。闪侠惠递寄快递&#xff0c;真正的实现了便宜寄快递发物流的便捷性&#xff0c;开创了低价发快递的…

Baidu Comate智能编码助手:提升软件生产力的高效工具使用教程

目录 一、前言 二、Comate助手概览 三、核心功能详解 智能推荐与自动补全 生成单元测试 代码注释生成 四、使用场景与优势 五、总结与展望 一、前言 随着信息技术的飞速发展&#xff0c;编程已经成为许多行业不可或缺的一部分。然而&#xff0c;编程过程中的繁琐和重复…

【linux软件基础知识】-死锁问题

死锁问题 当两个或多个线程由于每个线程都在等待另一个线程持有的资源而无法继续时,就会发生死锁 如下图所示, 在线程 1 中,代码持有了 L1 上的锁,然后尝试获取 L2 上的锁。 在线程 2 中,代码持有了 L2 上的锁,然后尝试获取 L1 上的锁。 在这种情况下,线程 1 已获取 L…