zoukankan      html  css  js  c++  java
  • windows下远程链接虚拟机Linux下MySQL数据库问题处理

           参考解决:https://www.cnblogs.com/blogforly/p/5997553.html

           今天远程连接虚拟机中的MySQL数据库,一直连不上,在网上搜索了一下,发现原因是MySQL对远程用户登陆的授权问题。这里说一下我的解决方法 

      然后在虚拟机中查看网络端口信息:

      #netstat -ntpl

      

      之后查看了防火墙的状态,发现3306端口的数据包都是丢弃状态

      #iptables -vnL

      

      

      这里要清除防火墙中链中的规则(用下面这个命令多半都能解决)

      #iptables -F

           执行此命令后 ,再进行远程连接  应该能成功!

      在这之后,我又远程链接了一下MySQL,出现了以下错误,查了一下,是因为MySQL没有允许远程登陆,所以要授权MySQL远程登陆。

      

      

    这里先说一下MySQL登陆:

      格式: mysql -h主机地址 -u用户名-p用户密码


        1、例1:连接到本机上的MYSQL
        找到mysql的安装目录,一般可以直接键入命令mysql -uroot -p,回车后提示你输密码,输入密码,直接回车即可进入到MYSQL中了,MYSQL的提示符是:mysql>

        2、连接到远程主机上的MySQL
        假设远程主机的IP为:10.0.0.1,用户名为root,密码为123。则键入以下命令:
        mysql -h10.0.0.1 -uroot -p123
       (注:p与123(密码)之间最好不加空格,其它也一样)

        3、退出MySQL命令
       exit (回车)

    最后授权MySQL,允许远程用户登录访问MySQL

      手动增加可以远程访问数据库的用户。

      方法一、本地登入mysql,更改 "mysql" 数据库里的 "user" 表里的 "host" 项,将"localhost"改为"%"

      #mysql -u root -proot
      mysql>use mysql;
      mysql>update user set host = '%' where user = 'root';
      mysql>select host, user from user;


      方法二、直接授权(推荐)

      从任何主机上使用root用户,密码:youpassword(你的root密码)连接到mysql服务器:
      # mysql -u root -proot 
      mysql>GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'youpassword' WITH GRANT OPTION;

      操作完后切记执行以下命令刷新权限 
        FLUSH PRIVILEGES

       这时再通过navicat远程链接MySQL,链接测试,如下图,成功。

      

  • 相关阅读:
    CF500F New Year Shopping [线段树分治,背包]
    P5344 【XR-1】逛森林[倍增优化建图,zkw线段树优化spfa]
    CF452F Permutation [哈希,树状数组]
    [NOI Online #2 提高组]子序列问题
    牛客挑战赛39题解
    #6036. 「雅礼集训 2017 Day4」编码 [前缀优化2sat]
    CF1156E Special Segments of Permutation [分治,set]
    #6198. 谢特 [后缀自动机,01trie合并,启发式合并]
    P4246 [SHOI2008]堵塞的交通 [动态图连通性]
    CF1096G Lucky Tickets [NTT,多项式快速幂]
  • 原文地址:https://www.cnblogs.com/llhhll/p/9256517.html
Copyright © 2011-2022 走看看