MySQL——Ubuntu20使用deb安装MySQL&远程连接数据库服务器

发布时间:2023年12月22日

MySQL的下载和安装

1. 下载

进入MySQL官网进行下载:MySQL官网下载地址

下载的文件默认放到Home/Downloads目录下

我这里选择了跟 系统版本及CPU架构对应 8.0.26 Ubuntu20.04 x86_64bit 版本进行了下载:mysql-server_8.0.26-1ubuntu20.04_amd64.deb-bundle.tar

在这里插入图片描述

不清楚自己的系统版本和CPU架构的可以通过一下指令查看:

# 查看Linux发布版本。我这里的 版本为 Ubuntu 20.04.6 LTS
lsb_release -a
# No LSB modules are available.
# Distributor ID: Ubuntu
# Description:    Ubuntu 20.04.6 LTS
# Release:        20.04
# Codename:       focal

# 查看内核版本号 和 CPU 架构。我这里的CPU架构为 x86_64
uname -a 
# Linux linyajun-Ubuntu18 5.4.0-150-generic #167~18.04.1-Ubuntu SMP Wed May 24 00:51:42 UTC 2023 x86_64 x86_64 x86_64 GNU/Linux

2. 安装

将下载后的压缩文件进行解压 /usr/local/mysql 目录下,这里需要在/usr/local目录下创建一个名为mysql的目录

将目录切换到 /usr/local:

解压MySQL安装包

sudo tar xvf mysql-server_8.0.26-1ubuntu20.04_amd64.deb-bundle.tar

将解压出来的安装包依次进行安装。由于包之间有依赖关系,一定要按照顺序安装

sudo dpkg -i mysql-common_8.0.26-1ubuntu20.04_amd64.deb
sudo dpkg -i mysql-community-client-plugins_8.0.26-1ubuntu20.04_amd64.deb
sudo dpkg -i libmysqlclient21_8.0.26-1ubuntu20.04_amd64.deb
sudo dpkg -i libmysqlclient-dev_8.0.26-1ubuntu20.04_amd64.deb
sudo dpkg -i mysql-community-client-core_8.0.26-1ubuntu20.04_amd64.deb
sudo dpkg -i mysql-community-client_8.0.26-1ubuntu20.04_amd64.deb
sudo dpkg -i mysql-client_8.0.26-1ubuntu20.04_amd64.deb
sudo dpkg -i mysql-community-server-core_8.0.26-1ubuntu20.04_amd64.deb
sudo dpkg -i mysql-community-server_8.0.26-1ubuntu20.04_amd64.deb
sudo dpkg -i mysql-server_8.0.26-1ubuntu20.04_amd64.deb

安装出错请看这里,没有请忽略

缺少依赖

libaio1(libaio1的deb下载链接,选择系统版本后,在跳转的页面查找下载路径)参考页面:https://pkgs.org/download/libaio1,下载完成之后进行安装。没有缺失请忽略。

sudo dpkg -i ./libaio1_0.3.112-5_amd64.deb

libmecab2 libmecab2的deb下载链接,选择系统版本后,在跳转的页面查找下载路径)参考页面:https://pkgs.org/download/libmecab2,下载完成之后进行安装。没有缺失请忽略。

sudo dpkg -i ./libmecab2_0.996-10build1_amd64.deb

包损坏

注意,在安装 mysql-community-server_8.0.26-1ubuntu20.04_amd64.deb 时会报如下错误,此时,是因为包可能有损坏。没有损坏请忽略。

在这里插入图片描述

尝试使用如下命令修复一下。

sudo apt-get install -f

如果失败,清除MySQL服务器:

sudo apt-get purge mysql-community-server mysql-community-server

然后清理并更新:

 sudo apt-get autoclean && sudo apt-get clean && sudo apt-get update

做一般升级:这里需要等一段时间(10分钟左右)

 sudo apt-get upgrade

继续安装 sudo dpkg -i mysql-community-server_8.0.26-1ubuntu20.04_amd64.deb。出现如下页面,输入root的密码,回车。此处密码为MySQL的root密码(这里密码不要设置太简单)

在这里插入图片描述

安装完成后,继续安装 sudo dpkg -i mysql-server_8.0.26-1ubuntu20.04_amd64.deb

安装完成后验证

查看启动状态,确认是否成功开启 mysql:

service mysql status

执行指令之后等待几秒钟之后…,如果出现了 active (running) 的提示,说明已经启动了:

在这里插入图片描述

如果不是上述的启动状态,则使用一下指令开启 mysql 服务

service mysql start

确认是否启动成功

netstat -tap | grep mysql

在LISTEN状态下,启动成功:

在这里插入图片描述

启动完成后验证MySQL是否安装成功

mysql -u root -p

输入上述设置的密码,成功进入MySQL。

mysql 中文乱码 解决

没有使用中文的需求和烦恼可以忽略

  • 修改配置文件*
vi /etc/mysql/mysql.conf.d/mysqld.cnf

vim打开后,添加命令、修改设置权限(vim编辑器基础使用: i进入编辑 esc退出编辑 :wq保存退出)

# 添加命令,修改编码格式为utf8
character_set_server=utf8

并且,设置授权

# bind-address 后修改为  0.0.0.0
bind-address = 0.0.0.0

修改后的结果如下:

在这里插入图片描述

本地远程连接MySQL服务器

本地还不能远程连接服务器的原因是: 服务器中下载好的MySQL数据库,默认是localhost本地连接

解决思路: 修改数据库的连接权限%

1. 先在服务器中启动MySQL,并以root账户登录

mysql -u root -p;
# 输入root登录密码

2. 查看用户权限——存储用户权限的表在mysql数据库下的user表,所以我们先丝滑地切进去看看怎么个事儿

# 选择使用的数据库
use mysql;
# 查看user表中指定的权限
select host, user from user;

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

可以看出我们这里的root用户还是localhost,只能本地连接,也就是现在还只能在服务器中连接

3. 选择一下,这里可以直接给root允许远程连接,但是不不安全;还可以新建一个用户,这个用户可以给他授权访问

# 给root授权
update user set Host='%' where user='root';
flush privileges;  # 刷新权限

# 新建一个用户
create user 'username'@'%' identified by '123456';
             用户名     所有地址            密码

在这里插入图片描述

4. 给新用户分配他能访问的数据库,表以及能拥有的权限

-- 授予连接访问权限
GRANT ALL PRIVILEGES ON [数据库名].[表名] TO '[用户名]'@'[连接地址]' WITH GRANT OPTION;
-- 授予操作增删改
GRANT SELECT, UPDATE, DELETE, INSERT ON  test.* TO 'username'@'%' WITH GRANT OPTION;
-- 刷新权限
FLUSH PRIVILEGES;

在这里插入图片描述

5. 我们登录新用户看一下

# 登录
mysql -u xy -p

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

6. 我们远程连接测试一下

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

文章来源:https://blog.csdn.net/qq_44689664/article/details/135151036
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。