关于WSL2下安装的mysql sever服务,如何在host或外部连接使用的问题

快速提示:
在wsl2下,不允许在外部使用root来登录mysql,所以必须使用非root的帐号来登录
所以,如果明白如何做了,下面的步骤就不必看了。
下面是,给小白用户的教程:

步骤 1: 首先,使用 WSL 命令行,并检查wsl2下安装的情况:

你可以直接使用 WSL 终端来管理和查看 MySQL 服务。这包括启动 WSL、连接到 MySQL、启动或停止 MySQL 服务等。

  1. 打开 WSL:
  • 打开命令提示符或 PowerShell,输入 wsl 回车,或直接打开你的 WSL 终端。
c:\windows>wsl
  1. 检查 MySQL 服务状态:
sudo service mysql status

得到类似如下信息:

● mysql.service - MySQL Community ServerLoaded: loaded (/lib/systemd/system/mysql.service; enabled; vendor preset: enabled)Active: active (running) since Tue 2024-04-23 11:46:41 CST; 2h 56min agoProcess: 258229 ExecStartPre=/usr/share/mysql/mysql-systemd-start pre (code=exited, stat>Main PID: 258237 (mysqld)Status: "Server is operational"Tasks: 40 (limit: 9453)Memory: 406.6MCGroup: /system.slice/mysql.service└─258237 /usr/sbin/mysqldApr 23 11:46:41 hdh-macbookpro2 systemd[1]: Starting MySQL Community Server...
Apr 23 11:46:41 hdh-macbookpro2 systemd[1]: Started MySQL Community Server.
lines 1-13/13 (END)

说明mysql server 已正确启动

提示:**启动/停止 MySQL 服务**:
sudo service mysql start   # 启动 MySQL
sudo service mysql stop    # 停止 MySQL
sudo service mysql restart # 重启 MySQL
  1. 尝试在wsl2中,使用mysql 登录 mysql service:
    使用 root 用户登录到你的 MySQL 服务器。
 mysql -u root -p

输入root帐号对应的密码,回车,如果出现下面的信息,说明登录成功

Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 45
Server version: 8.0.36-0ubuntu0.22.04.1 (Ubuntu)Copyright (c) 2000, 2024, Oracle and/or its affiliates.Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql>

步骤 2:更改mysql service 的配置信息,以支持从外部访问:

  1. 修改 MySQL 配置文件,以监听所有地址:

    • 在 WSL 中编辑 MySQL 的配置文件 my.cnf(通常/etc/mysql/mysql.conf.d/mysqld.cnf),找到 bind-address 参数,并设置为 0.0.0.0,对mysqlx-bind-address参数,相同设置为0.0.0.0:
      [mysqld]
      bind-address = 0.0.0.0
      mysqlx-bind-address = 0.0.0.0
      
    • 保存文件并退出编辑器。
  2. 重启 MySQL 服务:

    sudo service mysql restart
    

步骤3: 为mysql service创建一个新的非root用户

创建一个新的 MySQL 用户并允许该用户从 Windows 主机连接到 WSL2 中的 MySQL 实例,需要在 WSL2 的 MySQL 服务中进行操作。以下是在 MySQL 中创建新用户并授权的步骤:

  1. 在 WSL2 中打开终端

  2. 连接到 MySQL
    执行以下命令以使用 root 用户登录到 MySQL。

    mysql -u root -p
    

    输入 root 用户的密码。

  3. 创建新用户
    使用以下 SQL 命令创建一个新用户。将 newusernamenewpassword 分别替换为你希望设定的用户名和密码。
    注意:mysql的密码策略可能要求你,大小写与非字母混合,否则创建失败

    CREATE USER 'newusername'@'%' IDENTIFIED BY 'newpassword';
    

    这里 @'%' 表示新用户可以从任何 IP 地址连接到 MySQL 服务器。

  4. 授予权限
    为新用户授予必要的权限。下面的命令授予所有数据库的所有权限,但在实际情况中,你应根据需要授予适当的权限。

    GRANT ALL PRIVILEGES ON *.* TO 'newusername'@'%' WITH GRANT OPTION;
    

    使用 GRANT 语句可以具体地授予特定的数据库和表的权限。

  5. 刷新权限
    使权限更改立即生效。

    FLUSH PRIVILEGES;
    
  6. 退出 MySQL

    exit;
    

步骤4: 从宿主window中,使用mysql客户端工具连接

  1. 从 Windows 主机连接
    在 Windows 中,打开命令提示符或 PowerShell,使用新创建的用户信息尝试连接到 WSL2 中的 MySQL。假设 WSL2 的 IP 地址为 172.20.10.2,则命令如下:

    mysql  -u newusername@localhost -p
    

    输入新用户的密码。

    正常情况,你已经能正确登录

其它技巧与知识:

1) mysql密码丢失,如何修改

方法一:在wsl下,可以使用 MySQL 客户端免密登录时:

  1. 启动 MySQL 客户端:

    mysql 
    

    如登录成功

  2. 在 MySQL 提示符下,运行 ALTER USER 命令来更改密码:

    ALTER USER 'root'@'localhost' IDENTIFIED BY 'newpassword';
    

    newpassword 替换为您想要的新密码。

  3. 刷新权限并退出:

    FLUSH PRIVILEGES;
    exit;
    

方法二:在wsl下,无法访问当前密码

如果您忘记了当前的 root 密码,您需要以无密码模式启动 MySQL 服务来重置密码。按照以下步骤进行:

  1. 停止正在运行的 MySQL 服务(如果已启动):

    sudo service mysql stop
    
  2. 启动 MySQL 服务,跳过权限表:

    sudo mysqld_safe --skip-grant-tables &
    
  3. 现在您可以登录到 MySQL 服务器而不需要密码:

    mysql -u root
    
  4. 使用以下 SQL 命令重置 root 密码:

    USE mysql;
    UPDATE user SET authentication_string=PASSWORD('newpassword') WHERE User='root';
    FLUSH PRIVILEGES;
    exit;
    
  5. 重启 MySQL 服务:

    sudo service mysql restart
    

请根据您的 MySQL 版本替换相应的密码字段,较新版本的 MySQL 可能使用 authentication_string 而不是 password 字段。

2) 查看mysql 内的所有数据库

在 MySQL 中查看当前所有数据库是一个常见的操作,可以通过 MySQL 命令行界面轻松完成。如果你已经有了对 MySQL 的访问权限,可以按照以下步骤查看所有的数据库列表:

步骤 1: 登录到 MySQL

mysql -u username -p

这里 username 是你的 MySQL 用户名。在运行该命令后,系统会提示你输入密码。确保使用具有足够权限的用户账号登录。

步骤 2: 查看数据库列表

成功登录到 MySQL 后,使用以下 SQL 命令列出所有数据库:

SHOW DATABASES;

此命令会显示 MySQL 服务器上所有的数据库名称。你将能看到类似下面的输出:

+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
| your_database_name |
+--------------------+

这个列表包括所有你有权限查看的数据库。information_schema, mysql, performance_schema, 和 sys 是 MySQL 默认的系统数据库,用于存储服务器运行时的元数据和信息。

3) 查看mysql当前登录帐号

在 Windows Subsystem for Linux (WSL) 中运行的 MySQL 实例中查询当前登录账户的信息可以通过几种方法来完成。通常,我们使用 SQL 命令来查询当前用户的信息。以下是几个查询当前登录账户的 SQL 命令:

方法 1: 使用 USER() 和 CURRENT_USER() 函数

在 MySQL 中,USER()CURRENT_USER() 是两个非常有用的函数,可以帮助你识别当前的用户会话。

  • USER() 函数 返回当前 MySQL 会话的用户名和主机名,格式为 ‘user_name@host_name’。这显示的是用于连接 MySQL 服务器的用户。

  • CURRENT_USER() 函数 返回被授予连接权限的 MySQL 账户。在有些情况下,这可能与 USER() 返回的值不同,尤其是在权限代理的情况下。

打开你的 WSL 终端,连接到 MySQL,并执行以下命令:

SELECT USER() AS user, CURRENT_USER() AS current_user;

这将显示当前会话的登录用户名以及该会话被授权的用户名。

方法 2: 使用系统变量

你还可以查询系统变量来获得当前用户信息:

SELECT @@session.user;

这个命令将返回当前会话的用户名称和主机,类似于 USER() 函数。

示例过程

  1. 打开 WSL 终端
    打开 Windows 的开始菜单,搜索 “WSL” 并打开它。

  2. 连接到 MySQL
    使用下面的命令连接到 MySQL 服务器。替换 <username> 为你的 MySQL 用户名。

    mysql -u <username> -p
    

    系统会提示你输入密码。

  3. 执行查询命令
    在 MySQL 提示符下,输入前面提到的 SQL 查询命令之一。

    SELECT USER() AS user, CURRENT_USER() AS current_user;
    
  4. 查看结果
    MySQL 将返回当前登录的用户信息和被授予权限的用户信息。

使用这些方法,你可以轻松地在 WSL 上运行的 MySQL 中识别当前登录的用户账户。这对于进行安全审核、监控或仅仅是验证当前会话的权限非常有用。

4) 查看wsl下的ip地址

由于 WSL2 使用与 Windows 主机不同的 IP 地址

ip addr show eth0

5) 查看 网络打开的端口,是否存在3306

  1. 在wsl控制台内查看
    使用 netstat -antp,得到
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name
tcp        0      0 0.0.0.0:3306            0.0.0.0:*               LISTEN      258237/mysqld
tcp        0      0 127.0.0.1:6379          0.0.0.0:*               LISTEN      437/redis-server 12
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      483/sshd: /usr/sbin
tcp        0      0 127.0.0.53:53           0.0.0.0:*               LISTEN      115/systemd-resolve
tcp        0      0 0.0.0.0:33060           0.0.0.0:*               LISTEN      258237/mysqld
tcp        0      0 127.0.0.1:8888          0.0.0.0:*               LISTEN      257510/php
tcp        0      0 127.0.0.1:3306          127.0.0.1:46986         ESTABLISHED 258237/mysqld
tcp        0      0 127.0.0.1:46986         127.0.0.1:3306          ESTABLISHED -
tcp        0      0 127.0.0.1:33060         127.0.0.1:43738         ESTABLISHED 258237/mysqld
tcp        0      0 127.0.0.1:32844         127.0.0.1:3306          ESTABLISHED -
tcp        0      0 127.0.0.1:3306          127.0.0.1:32844         ESTABLISHED 258237/mysqld
tcp        0      0 127.0.0.1:43738         127.0.0.1:33060         ESTABLISHED -
tcp6       0      0 ::1:6379                :::*                    LISTEN      437/redis-server 12
tcp6       0      0 :::80                   :::*                    LISTEN      495/apache2
tcp6       0      0 :::22                   :::*                    LISTEN      483/sshd: /usr/sbin

发现,wsl中,已正确打开了 0.0.0.0:3306 端口,此外,33060也打开了

 2. **在宿主机的控制台内查看**
使用 netstat -atn,得到
活动连接协议  本地地址          外部地址        状态           卸载状态TCP    0.0.0.0:135            0.0.0.0:0              LISTENING       InHost
TCP    0.0.0.0:445            0.0.0.0:0              LISTENING       InHost
TCP    0.0.0.0:3389           0.0.0.0:0              LISTENING       InHost
TCP    0.0.0.0:5040           0.0.0.0:0              LISTENING       InHost
TCP    0.0.0.0:5357           0.0.0.0:0              LISTENING       InHost
TCP    0.0.0.0:54950          0.0.0.0:0              LISTENING       InHost
TCP    127.0.0.1:22           0.0.0.0:0              LISTENING       InHost
TCP    127.0.0.1:3306         0.0.0.0:0              LISTENING       InHost
TCP    127.0.0.1:3306         127.0.0.1:50899        ESTABLISHED     InHost
TCP    127.0.0.1:3306         127.0.0.1:52787        ESTABLISHED     InHost
TCP    127.0.0.1:4000         0.0.0.0:0              LISTENING       InHost
TCP    127.0.0.1:4000         127.0.0.1:64648        ESTABLISHED     InHost
TCP    127.0.0.1:6379         0.0.0.0:0              LISTENING       InHost
TCP    127.0.0.1:8680         0.0.0.0:0              LISTENING       InHost
TCP    127.0.0.1:33060        0.0.0.0:0              LISTENING       InHost
TCP    127.0.0.1:33060        127.0.0.1:52760        ESTABLISHED     InHost
TCP    127.0.0.1:49214        127.0.0.1:49215        ESTABLISHED     InHost
TCP    127.0.0.1:64648        127.0.0.1:4000         ESTABLISHED     InHost
TCP    127.0.0.1:65123        0.0.0.0:0              LISTENING       InHost
TCP    172.22.240.1:139       0.0.0.0:0              LISTENING       InHost
TCP    172.24.16.1:139        0.0.0.0:0              LISTENING       InHost
TCP    192.168.167.29:139     0.0.0.0:0              LISTENING       InHost
TCP    192.168.167.29:52611   157.148.61.140:80      ESTABLISHED     InHost
TCP    192.168.167.29:52742   210.61.249.41:443      CLOSE_WAIT      InHost
TCP    192.168.167.29:60676   183.47.121.90:80       CLOSE_WAIT      InHost
TCP    0.0.0.0:49215          0.0.0.0:0              BOUND           InHost

同样发现,在host主机中,已正确打开了 127.0.0.1:3306 端口,此外,33060也打开了

  1. 在宿主机使用 telnet 检查mysql端口打开的情况

在cmd下,

telnet localhost 3306

得到,以下信息

[8.0.36-0ubuntu0.22.04.1.0b.93P0l7DsPVNLcaching_sha2_password

说明端口是打开的,否则,检查 宿主机与wsl2内的防火墙是否正确添加。

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

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

相关文章

0元实现网站HTTP升级到HTTPS(免费https证书)

HTTPS就是在HTTP的基础上加入了SSL&#xff0c;将一个使用HTTP的网站免费升级到HTTPS主要包括以下几个步骤&#xff1a; 1 获取SSL证书 永久免费的https证书申请通道https://www.joyssl.com/certificate/select/free.html?nid16 免费的SSL证书同样能实现HTTPS&#xff0c;国…

uniapp同步开发h5+小程序双平台踩坑记录

最近做项目的需求是先发布h5&#xff0c;后续再开发上线微信小程序版&#xff0c;自然我选择了uniapp多平台打包&#xff0c;过程中也踩了一些坑。本篇文章记录了使用uniapp开发h5的注意事项&#xff0c;及打包成小程序需要兼容改动的内容。 1.需要在pages.json注册页面路由 在…

SpringBoot内容协商机制(就是接受数据的类型如json,xml)

目录 一、基于请求头的内容协商机制 二、基于请求参数的内容协商机制 一、基于请求头的内容协商机制 如果我们的Java服务为浏览器和安卓手机同时提供服务&#xff0c;浏览器期望接受的请求是JSON格式&#xff0c;安卓客户端期望接收的请求是XML格式&#xff0c;这个时候是否需…

C++中的智能指针

C中的智能指针 文章目录 C中的智能指针1.为什么需要智能指针&#xff1f;2.智能指针的类型2.1 std::shared_ptr2.2 std::unique_ptr2.3 std::weak_ptr Reference 笔者在学习ROS2的过程中&#xff0c;遇到了std::make_shared这种用法&#xff0c;一眼看不懂&#xff0c;才发现笔…

vue2使用过滤器实现菜单栏文字动态显示

文章目录 前言一、过滤器filters1.data数据2.beforeCreate 二、菜单栏文字动态显示 前言 左侧菜单栏有缩进&#xff0c;所以不同级别的菜单名可显示的文字数不同。顶部菜单栏是下拉框&#xff0c;所以文字是固定的 一、过滤器filters 由于filters不能使用this为undefined&…

Java 网络编程之TCP(三):基于NIO实现服务端,BIO实现客户端

前面的文章&#xff0c;我们讲述了BIO的概念&#xff0c;以及编程模型&#xff0c;由于BIO中服务器端的一些阻塞的点&#xff0c;导致服务端对于每一个客户端连接&#xff0c;都要开辟一个线程来处理&#xff0c;导致资源浪费&#xff0c;效率低。 为此&#xff0c;Linux 内核…

【CV】opencv特征匹配算法

特征匹配是计算机视觉领域中的一项关键任务&#xff0c;它用于在不同图像中寻找相似的特征点&#xff0c;并将它们进行匹配。这些特征点可以是图像中的角点、边缘、斑点等&#xff0c;在不同的图像中可能因为旋转、缩放、光照变化等因素发生变化。 在OpenCV中&#xff0c;提供…

华为数通HCIA ——企业网络架构以及产品线

一.学习目标&#xff1a;精讲网络技术&#xff0c;可以独立搭建和维护中小企业网络&#xff01; 模拟器&#xff08;华为方向请安装ENSP&#xff0c;Ensp-Lite已有安装包&#xff0c;号称功能更加完善-这意味着要耗费更多的系统资源但是仅对华为内部伙伴申请后方可使用&#x…

VS2022配置和搭建QT

一、下载QT 可以去QT官网下载:https://www.qt.io/product/development-tools。 直接安装。 二、安装qt插件 直接在vs插件市场搜索就行。 安装的时候根据提示&#xff0c;关闭vs自动安装 再次进去vs提示你选择qt版本&#xff0c;psth里边找到安装版本的qmake.exe就行 配…

卡尔曼滤波器(一):卡尔曼滤波器简介

观看MATLAB技术讲座笔记&#xff0c;该技术讲座视频来自bilibili账号&#xff1a;MATLAB中国。 一、什么是卡尔曼滤波器 卡尔曼滤波器是一种优化估计算法&#xff0c;是一种设计最优状态观测器的方法&#xff0c;其功能为&#xff1a; 估算只能被间接测量的变量&#xff1b;通…

https加密证书

网站要出去安全模式访问&#xff0c;加强网络安全就需要使用HTTPS加密证书。 本文主要介绍什么是HTTPS加密证书&#xff0c;如何申请HTTPS加密证书&#xff0c;如何安装HTTPS加密证书等问题展开讨论。 什么是HTTPS加密证书&#xff1f; HTTPS加密证书的行业产品用语叫作SSL证…

互联网大佬座位排排坐:马化腾第一,雷军第二

关注卢松松&#xff0c;会经常给你分享一些我的经验和观点。 这是马化腾、雷军、张朝阳、周鸿祎的座位&#xff0c;我觉得是按照互联网地位排序的。 马化腾坐头把交椅&#xff0c;这个没毛病&#xff0c;有他在的地方&#xff0c;其他几位都得喊声“大哥”。雷军坐第二把交椅…

Go语言常见错误 | 工程组织不合理 (工程结构和包的组织)

编写程序的过程中,组织代码的方式,不仅影响到代码的质量,也决定了团队的协作效率。在使用Golang进行项目开发时,工程组织不合理(包括工程结构和包的组织)是个常见的问题。下文将详述这个问题,并提供改善的方案。 工程结构不合理 Golang项目的工程结构对于代码的模块性…

ApplicationListener监听器

在spring-context 5.3.26中来看一下它的定义&#xff1a; package org.springframework.context;import java.util.EventListener; import java.util.function.Consumer;FunctionalInterface public interface ApplicationListener<E extends ApplicationEvent> extends…

[论文笔记] megatron训练参数:dataloader_type

在深度学习中&#xff0c;dataloader_type参数通常控制着数据的加载、处理和输入到模型的方式。不同的dataloader可能会按照不同的策略处理数据集&#xff0c;这可以显著影响模型训练和评估的效果。具体来说&#xff0c;single和cyclic类型通常如此区别&#xff1a; Single Dat…

关键绩效指标(KPI):明确目标及跟踪进展

在企业管理中&#xff0c;关键绩效指标&#xff08;KPI&#xff09;是一种重要的工具&#xff0c;用于明确目标并跟踪进展。通过设定和监控这些指标&#xff0c;企业能够确保员工、团队和整个组织都朝着既定的目标努力。本文将详细探讨关键绩效指标的重要性、设定方法以及如何有…

缓解工作压力的小窍门:保持健康与创新

目录 1 前言2 工作与休息的平衡3 保持心理健康4 社交与网络建设5 结语 1 前言 作为程序员&#xff0c;我们常常承受着高度的工作压力和持续的创新挑战。为了保持高效和健康&#xff0c;我们需要采取一些方法来缓解工作压力&#xff0c;同时促进个人的心理和身体健康。 2 工作…

大模型的原理与特点,奇异值分解(SVD);低秩近似

目录 一、大模型的原理与特点 二、一个基本架构,三种形式: Parameter-Efficient Fine-Tuning

5. Tailwind CSS 响应式设计的实现

Tailwind CSS 是一个功能类优先的 CSS 框架&#xff0c;它允许开发者通过使用响应式工具类来构建自适应的用户界面。这些工具类可以在不同的断点处有条件地应用&#xff0c;使得在不离开 HTML 的情况下构建复杂的响应式界面变得轻而易举。 基本概念 响应式设计在 Tailwind CS…

Python dlib(HOG+SVM)人脸识别总结

Python dlib(HOG+SVM)人脸识别总结 面部标志检测 dlib 68点(HOG+SVM),194点人脸识别模型,包括口(外嘴唇,内嘴唇),鼻,眉毛(左右眉),眼睛(左右眼),下鄂 5点面部标志检测器(左眼2点,右眼2点,鼻子1点)面部对齐更高效 眨眼检测 ear 眨眼瞬间达到0 疲劳驾驶检测…