Linux系统安装部署MySQL完整教程(图文详解)

前言:最近网上翻阅了大量关于Linux安装部署MySQL的教程,在自己部署的时候总是存在一些小问题,例如:版本冲突,配置失败和启动失败等等,功夫不负有心人,最后还是安装部署成功了,所以本篇博客记录了我是如何完整一步步的安装部署MySQL起来的,每一行代码都进行了严格的测试,其中的坑博主已经替大家全部踩完了,完整详细的步骤都在这篇博客中了,特此分享!

目录

一、准备MySQL安装包

二、安装MySQL

三、创建用户组和用户

四、配置MySQL

五、初始化MySQL

六、启动MySQL 

七、登录并修改初始密码

八、修改访问权限

九、放行端口号

十、Navicat访问MySQL

十二、设置开机自启

十三、总结


一、准备MySQL安装包

这是官网:https://dev.mysql.com/downloads/mysql/5.7.html

进去以后,系统选择Linux - Generic,最后选择64位的点击Download

选择直接下载即可

注:这边之所以选择的是5.7版本,是因为之前选择了最新版部署总是存在初始化失败的问题,所以我还是选择了更加稳定的版本。 

二、安装MySQL

这边我把自己的华为云服务器预先重装了系统,就是为了一步步干净完整的阐述搭建流程。

1、在根目录下新建一个mysql文件夹(图方便)

mkdir mysql

2、进入该目录

cd /mysql

3、将下载好的压缩包上传到Linux服务器上(Xftp)

​ 

4、解压

tar zxvf mysql-5.7.43-linux-glibc2.12-x86_64.tar.gz

5、解压完成以后,重命名一下解压后的目录名称,实在是太长了

mv mysql-5.7.43-linux-glibc2.12-x86_64/ mysql-5.7

三、创建用户组和用户

1、创建名为mysql的用户组

groupadd mysql

 2、添加用户htt到mysql用户组

useradd -r -g mysql htt

四、配置MySQL

1、进入到刚才解压的MySQL目录下

cd /mysql/mysql-5.7

2、创建一个名为data的目录

mkdir data

3、给用户组中的htt用户赋予data目录的权限

chown htt:mysql -R /mysql/mysql-5.7/data/

4、配置my.cnf文件

vim /etc/my.cnf

5、删除my.cnf文件中所有内容,复制如下内容

[mysqld]
bind-address=0.0.0.0
port=3306
user=htt
basedir=/mysql/mysql-5.7
datadir=/mysql/mysql-5.7/data
socket=/tmp/mysql.sock
log-error=/mysql/mysql-5.7/data/mysql.err
pid-file=/mysql/mysql-5.7/data/mysql.pid
max_connections=10000
max_user_connections=2000
wait_timeout=200
character_set_server=utf8mb4
symbolic-links=0
explicit_defaults_for_timestamp=true
lower_case_table_names=1

命令详解

参数解释
bind-address=0.0.0.0设置MySQL绑定监听的IP地址,0.0.0.0表示监听所有IP,允许远程连接。
port=3306设置MySQL服务的端口号,默认是3306
user=htt指定运行mysqld进程的系统用户为htt
basedir=/mysql/mysql-5.7设置MySQL的安装基目录
datadir=/mysql/mysql-5.7/data设置MySQL的数据文件目录
socket=/tmp/mysql.sock设置本地连接时使用的Unix socket文件路径
log-error=/mysql/mysql-5.7/data/mysql.err
设置错误日志文件路径
pid-file=/mysql/mysql-5.7/data/mysql.pid设置存放进程PID的文件路径
max_connections=10000设置最大连接数,包括TCP和socket连接
max_user_connections=2000设置单个用户最大并发连接数
wait_timeout=200设置空闲连接超时时间,单位秒
character_set_server=utf8mb4设置服务器默认字符集
symbolic-links=0禁用symbolic link符号链接支持
explicit_defaults_for_timestamp设置timestamp列默认值声明方式
lower_case_table_names=1表名区分大小写,设置为1表示不区分

注: 记得改成自己的目录

6、 按i键进入编辑模式,粘贴进去

7、按Esc键退出编辑模式,输入:wq保存并退出vim编辑器即可

五、初始化MySQL

1、先进入安装目录的bin目录下

cd /mysql/mysql-5.7/bin

2、初始化MySQL的数据目录

./mysqld --defaults-file=/etc/my.cnf --basedir=/mysql/mysql-5.7 --datadir=/mysql/mysql-5.7/data --user=htt --initialize

命令详解

参数详解
./mysqld启动mysqld服务器程序
--defaults-file=/etc/my.cnf指定配置文件路径为/etc/my.cnf
--basedir=/mysql/mysql-5.7指定MySQL的安装目录
--datadir=/mysql/mysql-5.7/data指定数据目录路径
--user=htt以htt用户身份启动
--initialize初始化数据目录,创建必要的系统表等

执行以后控制台报了如下错误:

./mysqld: error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory 

执行如下命令,安装一下即可:

yum -y install libaio

3、再次执行刚才的命令,然后执行命令查看日志当中的初始密码

cat /mysql/mysql-5.7/data/mysql.err

红框是初始密码,一会登录MySQL会用到

NYURXh_Wx5o!

六、启动MySQL 

1、进入support-files目录下

cd /mysql/mysql-5.7/support-files

2、 运行mysql.server来启动MySQL服务

sudo ./mysql.server start

启动成功!

七、登录并修改初始密码

1、进入MySQL的bin目录

cd /mysql/mysql-5.7/bin

2、登录MySQL

./mysql -u root -p

3、把刚才的NYURXh_Wx5o!粘贴进来,然后敲回车

这样就登录进来了!

4、修改初始密码为root

SET PASSWORD = PASSWORD('root');

  

5、将root用户的密码过期策略设置为永不过期

ALTER USER 'root'@'localhost' PASSWORD EXPIRE NEVER;

6、刷新

FLUSH PRIVILEGES;

这样就可以了!

八、修改访问权限

1、访问mysql库

use mysql

2、打开root用户的远程访问权限,允许任何主机使用root用户连接MySQL数据库

update user set host = '%' where user = 'root';

3、刷新

FLUSH PRIVILEGES;

这样就修改完成了! 

九、放行端口号

我这边购买的是华为云服务器,需要在安全组放行MySQL的3306端口,否则无法访问! 

十、Navicat访问MySQL

输入服务器ip、端口号、账号和密码,连接成功!

这样就安装部署成功啦!

十二、设置开机自启

1、将MySQL的服务脚本创建一个符号链接到系统服务脚本目录下,文件名为mysql

ln -s /mysql/mysql-5.7/support-files/mysql.server /etc/init.d/mysql

命令详解

参数解释
ln -s创建一个符号链接
/mysql/mysql-5.7/support-files/mysql.serverMySQL数据库自带的服务脚本,用于控制MySQL服务器的启动和停止
/etc/init.d/mysql系统服务脚本存放的位置

2、将MySQL的客户端程序mysql创建一个符号链接到系统命令目录/usr/bin下

ln -s /mysql/mysql-5.7/bin/mysql /usr/bin/mysql

命令详解 

参数解释
ln -s创建一个符号链接
/usr/bin/mysql在系统命令目录下创建mysql符号链接
/mysql/mysql-5.7/bin/mysqlMySQL客户端程序mysql的原始路径

3、重启MySQL

service mysql restart

4、给/etc/init.d/mysql文件添加可执行权限

chmod +x /etc/init.d/mysql

5、将mysql服务添加为开机自动启动的服务

chkconfig --add mysql

6、查看服务列表

chkconfig --list

2-5级别显示为on,表示开机自动启动 

这样就设置好了! 

十三、总结

以上就是对于如何使用Linux安装部署MySQL的完整过程了,如有问题,欢迎评论区讨论! 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Ubuntu 网络配置指导手册

一、前言 从Ubuntu 17.10 Artful开始,Netplan取代ifupdown成为默认的配置实用程序,网络管理改成 netplan 方式处理,不在再采用从/etc/network/interfaces 里固定 IP 的配置 ,配置写在 /etc/netplan/01-network-manager-all.yaml 或…

文本预处理——文本处理的基本方法

目录 什么是分词jieba分词特性精确模式分词全模式分词搜索引擎模式分词使用用户自定义词典 命名实体识别词性标注 什么是分词 jieba分词特性 精确模式分词 import jieba content工信处女干事每月经过下属科室都要亲口交代24口交换机等技术性器件的安装工作 print(jieba.lcut(co…

一文了解Python中的while循环语句

目录 🥩循环语句是什么 🥩while循环 🥩遍历猜数字 🥩while循环嵌套 🥩while循环嵌套案例 🦐博客主页:大虾好吃吗的博客 🦐专栏地址:Python从入门到精通专栏 循环语句是什…

SpringBoot创建和使用

1.Spring Boot的优点 快速集成框架,Spring Boot提供了启动添加依赖的功能,用于秒级成各种框架。内置运行容器,无需配备Tomcat等Web容器,直接运行和部署程序。快速部署项目,无需外部容器即可启动并运行项目。可以完全抛…

概率论和随机过程的学习和整理--番外15,如何计算N合1的合成数量问题?

目录 1 目标问题:多阶2合1的合成问题 1.1 原始问题 1.2 合成问题要注意,合成的数量 1.3 合成问题不能用马尔科夫链来解决 2 方案1:用合成公式合成多次能解决吗? --不能,解决不了递归的问题 3 方案2,…

idea2021.安装pojie教程

1、下载ideaIU-2021.3应用包,点击finish 2、先关闭idea窗口,等会激活了脚本再运行打开。 3、双击运行install-current-user.vbs,等待一会会提示运行成功。 4、运行后,在文件中会多出一条配置 5、打开运行idea,输入激活码&#x…

如何使用curl下载github代码

首先通过chrome打开想要下载的源文件 如图,有那个下载图标时表示不需要鉴权即可下载,一般仓库都会开放只读权限,所以很大概率都有 比如我想下载这个crc32.c文件 那么我就需要知道它在哪个IP中,按下F12打开网络,点击下载…

pytorch安装GPU版本 (Cuda12.1)教程

使用本教程前,默认您已经安装并配置好了python3以上版本 1. 去官网下载匹配的Cuda Cuda下载地址 当前最高版本的Cuda是12.1 我安装的就是这个版本 小提示:自定义安装可以只选择安装Cuda Runtime。Nvidia全家桶不必全部安装。把全家桶全部安装完直接系统…

ChatGPT助力校招----面试问题分享(十二)

1 ChatGPT每日一题:运算放大器与比较器的区别 问题:运算放大器与比较器的区别 ChatGPT:运算放大器和比较器都是电子电路中常用的模拟电路元件,但它们的设计和应用略有不同。下面是两者的主要区别: 功能不同&#xf…

Java集合之List

ArrayLsit集合 ArrayList集合的特点 ArrayList集合的一些方法 ①.add(Object element) 向列表的尾部添加指定的元素。 ②.size() 返回列表中的元素个数。 ③.get(int index) 返回列表中指定位置的元素,index从0开始。 public class Test {public static void m…

【Vue】day03-VueCli(脚手架)

day03 一、今日目标 1.生命周期 生命周期介绍 生命周期的四个阶段 生命周期钩子 声明周期案例 2.综合案例-小黑记账清单 列表渲染 添加/删除 饼图渲染 3.工程化开发入门 工程化开发和脚手架 项目运行流程 组件化 组件注册 4.综合案例-小兔仙首页 拆分模块-局部…

有名管道(FIFO)的学习笔记

文章目录 有名管道介绍有名管道的使用创建 注意事项 有名管道介绍 有名管道的使用 创建 命令, mkfifo name函数,int mkfifo(const char *pathname, mode_t mode); 设置错误号; 向管道中写数据👇: 从管道读数据&am…

前端Web实战:从零打造一个类Visio的流程图拓扑图绘图工具

前言 大家好,本系列从Web前端实战的角度,给大家分享介绍如何从零打造一个自己专属的绘图工具,实现流程图、拓扑图、脑图等类Visio的绘图工具。 你将收获 免费好用、专属自己的绘图工具前端项目实战学习如何从0搭建一个前端项目等基础框架项…

log4j--动态打印日志文件到指定文件夹

文章目录 log4j--动态打印日志文件到指定文件夹1、添加Maven依赖2、配置文件 log4j.properties3、编写日志打印工具类 LogUtil4、工具类调用 log4j–动态打印日志文件到指定文件夹 1、添加Maven依赖 <!-- log4j日志相关坐标 --><dependency><groupId>org.s…

API Testing 一个基于 YAML 文件的开源接口测试工具

目录 前言&#xff1a; 如何使用&#xff1f; 本地模式 服务端模式 文件格式 后续计划 前言&#xff1a; API Testing 是一个基于 YAML 文件的开源接口测试工具&#xff0c;它可以帮助开发者快速地进行接口测试。 在选择工具时&#xff0c;可以从很多方面进行考量、对比…

【Matlab】基于遗传算法优化 BP 神经网络的数据回归预测(Excel可直接替换数据)

【Matlab】基于遗传算法优化 BP 神经网络的数据回归预测&#xff08;Excel可直接替换数据&#xff09; 1.模型原理2.文件结构3.Excel数据4.分块代码4.1 arithXover.m4.2 delta.m4.3 ga.m4.4 gabpEval.m4.5 initializega.m4.6 maxGenTerm.m4.7 nonUnifMutation.m4.8 normGeomSel…

Pytorch:利用torchvision调用各种网络的预训练模型,完成CIFAR10数据集的各种分类任务

2023.7.19 cifar10百科&#xff1a; [ 数据集 ] CIFAR-10 数据集介绍_cifar10_Horizon Max的博客-CSDN博客 torchvision各种预训练模型的调用方法&#xff1a; pytorch最全预训练模型下载与调用_pytorch预训练模型下载_Jorbol的博客-CSDN博客 CIFAR10数据集下载并转换为图片&am…

vue中export和export default的使用

<script> export default {name: HelloWorld } $(function () {alert(引入成功) }) </script> 1、export的使用 比喻index.js要使用test.js中的数据&#xff0c;首先在test.js文件中进行导出操作 代码如下&#xff1a; export function list() {alert("list…

【表达式引擎】简单高效的轻量级Java表达式引擎:Aviator

简单高效的轻量级表达式引擎&#xff1a;Aviator 前言 Aviator 是一个高性能、、轻量级的表达式引擎&#xff0c;支持表达式动态求值。其设计目标为轻量级和高性能&#xff0c;相比于 Groovy 和 JRuby 的笨重&#xff0c;Aviator 就显得更加的小巧。与其他的轻量级表达式引擎不…

Python实战项目——物流行业数据分析(二)

今天我们对物流行业数据进行简单分析&#xff0c;数据来源&#xff1a;某企业销售的6种商品所对应的送货及用户反馈数据 解决问题&#xff1a; 1、配送服务是否存在问题 2、是否存在尚有潜力的销售区域 3、商品是否存在质量问题 分析过程&#xff1a; 依旧先进行数据处理 一…
最新文章