进阶篇之linux环境下安装MySQL数据库


Posted in MySQL onApril 09, 2022

1.概述

对于mysql二进制安装,优点是可以安装到任何路径下,灵活性好,一台服务器可以安装多个mysql。缺点是已经编译过,性能不如源码编译得好,不能灵活定制编译参数。如果用户即不想安装最简单却不够灵活的RPM包,又不想安装复杂费时的源码包,那么已编译好的二进制包将是最好的选择,下面让我们来介绍如何在linux系统下安装mysql服务端。

2.前期准备

2.1下载mysql二进制安装包

mysql官网:https://dev.mysql.com/downloads/mysql

进阶篇之linux环境下安装MySQL数据库
因为我下载的是mysql-8.0.23-linux-glibc2.12-x86_64.tar版本,如果有最新版本,则下载最新版本就好了。

2.2导入mysql二进制安装包

通过Xftp工具把安装包传输到linux系统package目录去:
进阶篇之linux环境下安装MySQL数据库

3.mysql部署

●解压mysql安装包

--切换到安装目录
cd /app
--解压xz压缩文件
tar -xvf /app/package/mysql-8.0.23-linux-glibc2.12-x86_64.tar.xz

●修改mysql文件夹名称

--把mysql-8.0.23-linux-glibc2.12-x86_64修改为mysql文件夹名称
mv /app/mysql-8.0.23-linux-glibc2.12-x86_64 /app/mysql

●创建data目录

--在mysql根目录下创建data目录,用于存放数据
mkdir /app/mysql/data

●创建mysql用户组和mysql用户

--创建mysql用户组和mysql用户
groupadd mysql
useradd -g mysql mysql

●修改mysql目录权限

--修改mysql目录权限
chown -R mysql.mysql /app/mysql/

●初始化数据库

--先切换到mysql安装目录
cd /app/mysql
--初始化数据库
bin/mysqld --initialize --user=mysql --basedir=/app/mysql --datadir=/app/mysql/data

进阶篇之linux环境下安装MySQL数据库
●配置mysql

--先切换到mysql.support-files目录
cd /app/mysql/support-files
--在mysql/support-files创建文件my-default.cnf
touch my-default.cnf
--复制配置文件到/etc/my.cnf
cp -a ./my-default.cnf /etc/my.cnf
--编辑my.cnf
vim /etc/my.cnf

my.cnf输入如下配置内容:

[client]
port=3306
socket=/tmp/mysql.sock

[mysqld]
port=3306
user=mysql
socket=/tmp/mysql.sock
basedir=/app/mysql
datadir=/app/mysql/data

●配置环境变量

--编辑profile文件
vim /etc/profile
--配置mysql环境变量
PATH=/data/mysql/bin:/data/mysql/lib:$PATH
export PATH
--使mysql环境变量生效
source /etc/profile
--看环境变量是否生效
echo $PATH

●启动mysql

cd /app/mysql/bin
systemctl start mysqld
or
service mysql start

启动mysql时候可能会遇到如下错误:
●Failed to start mysqld.service: Unit not found.
进阶篇之linux环境下安装MySQL数据库
or
Starting MySQL.Logging to '/app/mysql/data/dengwu.err'.
... ERROR! The server quit without updating PID file (/app/mysql/data/dengwu.pid).
进阶篇之linux环境下安装MySQL数据库
解决方法如下:

--需要安装mariadb-server
yum install -y mariadb-server
--然后启动mariadb服务
systemctl start mariadb.service
--需要的可以添加mariadb服务开机启动
systemctl enable mariadb.service

●Job for mariadb.service failed because the control process exited with error code. See "systemctl status mariadb.service" and "journalctl -xe" for details.
进阶篇之linux环境下安装MySQL数据库
解决方法如下:

chown -R mysql.mysql /app/mysql/

●Starting MySQL... ERROR! The server quit without updating PID file (/app/mysql/data/dengwu.pid).
解决方法如下:

--查看mysql进程
ps -ef|grep mysqld
--杀死mysql进程
kill -9 mysql进程ID

然后重新启动下mysql:
进阶篇之linux环境下安装MySQL数据库

4.修改mysql密码

root用户第一次登录mysql,因为初始密码我们并不知道,一般情况下我们都会重新设置一个新的密码,具体操作如下:

--编辑my.cnf
vim /etc/my.cnf

输入如下命令行:

default_authentication_plugin=mysql_native_password

如果忘记了密码再加上:

--跳过密码验证(等设置了密码就去掉)
skip-grant-tables

然后登录mysql:

--登录mysql
mysql -u root -p

然后输入命令查看mysql用户组:

--查看mysql用户表
select user,host,authentication_string from mysql.user;

进阶篇之linux环境下安装MySQL数据库
看看root用户没有开启远程连接权限,如果没有则执行如下命令:

--修改root用户可以远程连接
update mysql.user set host='%' where user='root';

开启远程连接权限后,再来修改root用户密码:

--如果host是localhost则@字符后面是localhost,反之则是%,以host结果为准
--修改加密规则
alter user 'root'@'%' identified by 'qwer1234' password expire never;
--更新一下用户的密码
alter user 'root'@'%' identified with mysql_native_password by 'qwer1234';
--刷新权限
flush privileges;
--修改root用户密码
alter user 'root'@'%' identified by 'qwer1234';

进阶篇之linux环境下安装MySQL数据库

如果防火墙开启了,则需要加入允许mysql端口访问权限,具体命令如下:

--允许访问
firewall-cmd --permanent --zone=public --add-port=3306/tcp
--重新加载
firewall-cmd --reload
--查看是否开通访问权限
firewall-cmd --permanent --zone=public --query-port=3306/tcp

然后重新启动mysql:

--重新启动mysql
service mysql restart;

5.配置mysql阿里云安全组策略

登录阿里云->安全组规则->访问规则->入方向->手动添加如下策略:
进阶篇之linux环境下安装MySQL数据库
使用Navicat连接成功:
进阶篇之linux环境下安装MySQL数据库

MySQL 相关文章推荐
数据库的高级查询六:表连接查询:外连接(左外连接,右外连接,UNION关键字,连接中ON与WHERE的不同)
Apr 05 MySQL
MySQL 百万级数据的4种查询优化方式
Jun 07 MySQL
MySQL系列之六 用户与授权
Jul 02 MySQL
一篇文章带你深入了解Mysql触发器
Aug 02 MySQL
MySQL令人大跌眼镜的隐式转换
Aug 23 MySQL
一条 SQL 语句执行过程
Mar 17 MySQL
MySQL中rank() over、dense_rank() over、row_number() over用法介绍
Mar 23 MySQL
Nebula Graph解决风控业务实践
Mar 31 MySQL
MySQL创建管理KEY分区
Apr 13 MySQL
MySQL创建管理子分区
Apr 13 MySQL
MySQL事务的ACID特性以及并发问题方案
Jul 15 MySQL
详解MySQL的内连接和外连接
May 08 MySQL
MySQL的存储函数与存储过程的区别解析
Apr 08 #MySQL
MySQL数据库查询进阶之多表查询详解
MySQL中一条SQL查询语句是如何执行的
解决MySQL Varchar 类型尾部空格的问题
Apr 06 #MySQL
mysql的单列多值存储实例详解
Apr 05 #MySQL
详细聊一聊mysql的树形结构存储以及查询
mysql查询结果实现多列拼接查询
Apr 03 #MySQL
You might like
php冒泡排序、快速排序、快速查找、二维数组去重实例分享
2014/04/24 PHP
PHP魔术方法__GET、__SET使用实例
2014/11/25 PHP
php使用Imagick生成图片的方法
2015/07/31 PHP
PHP使用finfo_file()函数检测上传图片类型的实现方法
2017/04/18 PHP
thinkPHP3.2.3实现阿里大于短信验证的方法
2018/06/06 PHP
php更新cookie内容的详细方法
2019/09/30 PHP
javascript 解析url的search方法
2010/02/09 Javascript
javascript XMLHttpRequest对象全面剖析
2010/04/24 Javascript
Js setInterval与setTimeout(定时执行与循环执行)的代码(可以传入参数)
2010/06/11 Javascript
JSON中双引号的轮回使用过程中一定要小心
2014/03/05 Javascript
一个JavaScript用逗号分割字符串实例
2014/09/22 Javascript
js控制多图左右滚动切换效果代码分享
2015/08/26 Javascript
JavaScript的代码编写格式规范指南
2015/12/07 Javascript
浅谈Javascript中的12种DOM节点类型
2016/08/19 Javascript
JS中静态页面实现微信分享功能
2017/02/06 Javascript
JavaScript mixin实现多继承的方法详解
2017/03/30 Javascript
快速搭建React的环境步骤详解
2017/11/06 Javascript
[37:35]DOTA2上海特级锦标赛A组资格赛#1 Secret VS MVP.Phx第二局
2016/02/25 DOTA
删除目录下相同文件的python代码(逐级优化)
2012/05/25 Python
Python multiprocessing模块中的Pipe管道使用实例
2015/04/11 Python
Python 常用string函数详解
2016/05/30 Python
Windows中安装使用Virtualenv来创建独立Python环境
2016/05/31 Python
python Pygame的具体使用讲解
2017/11/03 Python
Python使用requests及BeautifulSoup构建爬虫实例代码
2018/01/24 Python
Django中STATIC_ROOT和STATIC_URL及STATICFILES_DIRS浅析
2018/05/08 Python
CSS3的resize属性使用初探
2015/09/27 HTML / CSS
利用html5的websocket实现websocket聊天室
2013/12/12 HTML / CSS
美国最大的旗帜经销商:Carrot-Top
2018/02/26 全球购物
Sneaker Studio捷克:购买运动鞋
2018/07/08 全球购物
请说出你所知道的线程同步的方法
2013/04/19 面试题
求高于平均分的学生学号及成绩
2016/09/01 面试题
遇到的Mysql的面试题
2014/06/29 面试题
电视购物广告词
2014/03/19 职场文书
警察群众路线整改措施
2014/09/26 职场文书
身份证丢失证明
2015/06/19 职场文书
Nginx 安装SSL证书完成HTTPS部署
2022/04/28 Servers