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.mzph.cn/news/9010.shtml

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

相关文章

[SQL系列] 从头开始学PostgreSQL 事务 锁 子查询

[SQL系列] 从头开始学PostgreSQL 索引 修改 视图_Edward.W的博客-CSDN博客https://blog.csdn.net/u013379032/article/details/131818865 事务 事务是一系列逻辑相关的数据库操作,可以作为一个整体进行操作或者回滚。事务通常会包含一个序列的读或者写操作&#xf…

Flink任务优化分享

Flink任务优化分享 1.背景介绍 线上计算任务在某版本上线之后发现每日的任务时长都需要三个多小时才能完成,计算时间超过了预估时间,通过Dolphinscheduler的每日调度任务看,在数据层 dwd 的数据分段任务存在严重的性能问题,每天…

20230721在WIN10下安装openssl并解密AES-128加密的ts视频切片

20230721在WIN10下安装openssl并解密AES-128加密的ts视频切片 2023/7/21 22:58 1、前言: AES-128加密的ts视频切片【第一个】,打开有时间限制的! https://app1ce7glfm1187.h5.xiaoeknow.com/v2/course/alive/l_64af6130e4b03e4b54da1681?typ…

研发机器配网方案(针对禁止外网电脑的组网方案)

背景:公司是研发型小公司,难免会使用A某D和K某l 等国内免费软件,这两个是业界律师函发得最多的软件。最简单的方案是离网使用,但是离网使用比较麻烦的是要进行文件传输,需要使用U盘拷贝,另外研发型企业一般…

【动态规划上分复盘】这是你熟悉的地下城游戏吗?

欢迎 前言一、动态规划五步曲二、地下城游戏题目分析思路:动态规划具体代码如下 总结 前言 本文讲解关于动态规划思路的两道题目。 一、动态规划五步曲 1.确定状态表示(确定dp数组的含义)2.确定状态转移方程(确定dp的递推公式&a…

Python中pyecharts模块

pyecharts模块 官网:pyecharts官网 pyecharts框架画廊 如果想要做出数据可视化效果图, 可以借助pyecharts模块来完成概况 : Echarts 是个由百度开源的数据可视化,凭借着良好的交互性,精巧的图表设计,得到了众多开发者的认可. 而…

巅峰极客2023 hellosql

随便输一个payload,有waf 这题只有两个回显,分别是太酷啦和nonono,不显示报错、登录成功等各种信息,目前只能想到用时间盲注。 抓包fuzz,194都是被过滤的 不止这些,手工测出来if、sleep、benchmark、*、rp…

办公室安全升级,如何保障人身财产安全?

视频监控,一种常见的安全措施,以监视和记录办公室内的活动。这项技术为企业提供了许多优势,包括保障员工和财产安全、帮助调查犯罪事件、提高业务管理效率以及应对突发事件。 因此,在合理范围内应用视频监控,将为企业提…

SAP从放弃到入门系列之批次派生-Batch Derivation-Part1

文章目录 一、概述二、系统配置三、主数据3.1 分类主数据3.2 派生规则设置3.2.1发送物料3.2.2 接收物料 四、 测试数据(生产订单)五、 最后 Batch Derivation翻译成批次派生(衍生)或批次继承都是问题不大,继承和派生个…

(学习笔记-IP)Ping的工作原理

Ping是基于ICMP协议工作的,ICMP报文封装在IP包里面,它工作在网络层,是IP协议的助手。 ICMP包头的类型字段,大致可分为两大类: 一类是用于诊断的查询消息,也就是查询报文类型一类是通知出错原因的错误消息&…

Spring 的元注解

一、元注解介绍 1.1.源码引入 1.2.元注解介绍 从上面的图片可知,Spring 有四个【负责注解其他注解】的元注解,分别是: Target:标识该注解可以用于标注哪些程序元素,比如类、方法、字段等。 Retention:标…

Zabbix-server监控mysql及httpd服务

目录 一、Zabbix监控mysql数据库 1、为server.Zabbix.com添加服务模板 2、创建mysql服务图形 二、server.zabbix.com服务器操作 编辑chk_mysql.sh脚本 三、server.Zabbix.com测试 四、查看web效果 五、Zabbix监控apache(httpd服务) 安装master 六、…

C++ 提高编程

C 提高编程 主要针对C泛型编程和STL技术 一、 模板 1、 概念 模板就是建立通用的模具,大大提高代码的复用性 模板特点 模板不可以直接使用,它只是一个框架 ​ 模板的通用并不是万能的 2、 函数模板 C 另一种编程思想为泛型编程,主要利用的…

Ubuntu搭建Samba服务-学习记录

文章目录 Ubuntu安装Samba流程Samba配置文件Samba添加账户配置文件修改Samba服务控制设置开机自动启动通过systemctl 启动服务通过 rc.local 启动 Windows访问参考链接 当前文章仅用于记录,在 Ubuntu中安装使用Samba,在Windows访问 系统环境:…

【问题记录】Ubuntu 22.04 环境下,程序报:段错误(核心已转储)怎么使用 core 文件和GDB调试器 解决?

目录 环境 问题情况 解决思路 原因分析 解决方法 番外知识 环境 VMware Workstation 16 Pro (版本:16.1.2 build-17966106)ubuntu-22.04.2-desktop-amd64 问题情况 本人在运行百万并发的服务端程序时,程序运行报&#xff1a…

VLAN---虚拟局域网

VLAN— 虚拟局域网 LAN—局域网 MAN—城域网 WAN—广域网 1.一个VLAN相当于是一个广播域 VLAN—通过路由器和交换机协同工作后,将原本的一个广播域逻辑上,拆 分为多个虚拟的广播域。 VLAN配置: 1.创建VLAN VID—VLAN ID------用来区分和…

浅谈能源管理系统在水泥行业中设计分析

安科瑞 华楠 摘要:水泥企业作为我国产业结构中重要的耗能产业,同时对环境的污染也比较大,因此在水泥企业中建立能源管理系统,对水泥企业的生产过程过程进行全过程的监控和管理,对于降低企业的能源消耗和提高企业的经济…

【Ajax】笔记-Axios与函数发送AJAX请求

Axios 和 Ajax 的区别 1、Axios是一个基于Promise的HTTP库,而Ajax是对原生XHR的封装; 2、Ajax技术实现了局部数据的刷新,而Axios实现了对ajax的封装。 优缺点: ajax: 本身是针对MVC的编程,不符合现在前端MVVM的浪潮 基…

【MySQL】之复合查询

【MySQL】之复合查询 基本查询多表查询笛卡尔积自连接子查询单行子查询多行子查询多列子查询在from子句中使用子查询 合并查询小练习 基本查询 查询工资高于500或岗位为MANAGER的雇员,同时还要满足他们的姓名首字母为大写的J按照部门号升序而雇员的工资降序排序使用…

性能测试Ⅱ(压力测试与负载测试详解)

协议 性能理论:并发编程 ,系统调度,调度算法 监控 压力测试与负载测试的区别是什么? 负载测试 在被测系统上持续不断的增加压力,直到性能指标(响应时间等)超过预定指标或者某种资源(CPU&内存)使用已达到饱和状…