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

devtools/2024/11/15 5:02:06/

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

WSL_wsl2_5">步骤 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>

mysql_service__63">步骤 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
    

mysql_serviceroot_78">步骤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;
    

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

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

    mysql  -u newusername@localhost -p
    

    输入新用户的密码。

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

其它技巧与知识:

mysql_128">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 字段。

mysql__182">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 默认的系统数据库,用于存储服务器运行时的元数据和信息。

mysql_216">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.ppmy.cn/devtools/19858.html

相关文章

MATLAB初学者入门(12)—— 模拟退火算法

模拟退火&#xff08;Simulated Annealing, SA&#xff09;是一种概率性搜索技术&#xff0c;用于寻找给定函数的全局最优解。该算法受到物理学中固体退火过程的启发&#xff0c;通过模拟物质冷却过程中粒子的随机运动&#xff0c;来逐步寻找优化解。它允许在搜索过程中偶尔接受…

日期操作类 + http、https 请求工具类 + 开发环境 忽略 SSL 验证工具类 + 二维码工具类

日期操作类 package com.pay.common.util;import java.text.SimpleDateFormat; import java.util.Date; /*** 日期操作类* 创建者 科帮网* 创建时间 2017年7月31日*/ public class DateUtils {private final static SimpleDateFormat sdfYear new SimpleDateFormat("yyy…

【接口测试】JMeter接口关联测试

‍‍1 前言 我们来学习接口管理测试&#xff0c;这就要使用到JMeter提供的JSON提取器和正则表达式提取器了&#xff0c;下面我们来看看是如何使用的吧。 2 JSON提取器 1、添加JSON提取器 在线程组右键 > 添加 > 后置处理器 > JSON提取器 2、JSON提取器参数说明 N…

CTFshow-PWN-栈溢出(pwn39)

32位的 system(); "/bin/sh" 检查&#xff1a; 32 位程序 使用 ida32 分析 跟进 ctfshow 函数 buf 到 ebp 距离&#xff1a;0x12 代码解释&#xff1a; 声明了一个长度为 14 的字符数组 buf&#xff0c;数组大小为14字节&#xff0c;用来存储用户输入的数据&#…

阿里云物联网平台 | 透传与ICA标准数据格式(Alink JSON)| 定值SDK非动态注册与动态注册 | SOC+4G模组移植方案

文章目录 一、透传与ICA标准数据格式&#xff08;Alink JSON&#xff09;二、定值SDK选非动态注册还是动态注册三、SOC4G模组移植方案 一、透传与ICA标准数据格式&#xff08;Alink JSON&#xff09; 透传和ICA标准数据格式&#xff08;Alink JSON&#xff09;是物联网设备与阿…

基于java,SpringBoot和HTML实验室预约管理系统设计

摘要 本研究旨在设计并实现一个基于Java, Spring Boot和HTML的实验室预约管理系统&#xff0c;以解决实验室资源分配不均、管理混乱和预约流程繁琐等问题。系统采用B/S架构设计&#xff0c;后端使用Spring Boot框架进行开发&#xff0c;前端使用HTML进行页面设计&#xff0c;实…

attempt to compare nil with number -- 黑马点评出现问题

问题情况 : 主要问题 : 调用lua执行redis时&#xff0c;有一个值会接受nil&#xff08;因为redis中没有该数据&#xff09;或者数值&#xff0c;当该值为nil时执行报错&#xff0c;因为会用到将该值与其他数字比较&#xff0c;故报错attempt to compare nil with number 当然…

【数据结构与算法】:手搓顺序表(Python篇)

文章目录 一、顺序表的概念二、顺序表的实现1. 顺序表的创建1.1 扩容1.2 整体建立顺序表 2. 顺序表的基本运算算法2.1 顺序表的添加&#xff08;尾插&#xff09;2.2 指定位置插入2.3 指定位置删除2.4 顺序表的查找2.5 顺序表元素的索引访问2.6 顺序表元素的修改2.7 顺序表长度…