zoukankan      html  css  js  c++  java
  • Navicate 连接阿里云MySQL(两种方式及原理讲解)

    一、直连方式(通过3306端口)

    1.概述

    开启服务器的3306端口,添加MySQL远程访问用户,可以实现直接连接远程MySQL的功能,效果就是直接将localhost换成服务器公网IP就能访问。

    2. 环境准备

    本地:Navicat

    服务器:阿里云ECS、安装好JDK、MySQL

    3.操作及讲解

    (1)开放服务器安全组中3306端口

    打开云服务器的3306端口是存在一定的安全风险的,默认安全组是不允许外部访问3306端口的。

    登录阿里云–》控制台–》找到自己的云服务器ECS–》进去后点击实例ID

    在这里插入图片描述

    点击本实例安全组–》选择配置规则–》添加一条配置信息
    在这里插入图片描述

    (2)添加MySQL远程访问用户

    在安装好的MySQL数据库中存在一个mysql库,库里面有一个user表,该表存储了mysql的用户信息,默认情况下是这样的[外链在这里插入图片描述

    只允许本地通过root账户登录(不关注另外两个),我们现在添加一个能够远程访问的用户既Host为%的用户。

    通过shell工具连接服务器,登录mysql运行以下命令

    GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;
    flush privileges; 
    

    添加一个能够冲任意IP登录的账号,账号为root,密码为123456。第二句为刷新权限,不刷新不管用。

    (3)通过本地Navicat连接远程MySQL数据库

    上面我们配置好了安全组访问控制,配置了MySQL远程登录用户,接下来我们就可以直接远程访问MySQL了。

    在这里插入图片描述

    连接名:随意

    主机:服务器IP地址

    端口:3306

    用户名:root

    密码:123456

    对比本地数据库只更改了一个IP地址就能够连接了。项目也可以直接将连接信息中localhost更改成IP地址直接访问云端的数据库。

    二、使用SSH通道

    1.概述

    开放3306端口存在一定的安全风险,项目和数据库存放于一个服务器,不需要通过公网IP访问,开发时本地又需要连接数据库,可以使用SSH通道连接的方式连接数据库,既本地通过服务器账号密码连接服务器,然后连接MySQL,对于MySQL来说这就是一个本地的访问连接。

    2.环境准备

    本地:Navicat

    服务器:阿里云ECS、安装好JDK、MySQL

    3.操作及讲解

    本方法不需要开发安全组端口,不需要为MySQL添加远程访问用户。使用SSH通道使用服务器登录账号连接MySQL。

    (1)配置SSH连接

    在这里插入图片描述

    连接时选中SSH选项,选中使用SSH通道

    主机:服务器公网IP

    端口:22(SSH连接端口,阿里云安全组默认放开)

    用户名:登录服务器系统的用户名(注意不是MySQL的)

    密码:登录服务器系统的密码(注意不是MySQL的)

    以上行为相当于shell连接上了服务器

    (2)配置数据库连接信息

    在这里插入图片描述

    常规操作,

    主机名:随意。

    主机:localhost

    端口:3306

    用户名:mysql用户名

    密码:mysql密码

    因为已经SSH连接了服务器,此处相当于本地连接MySQL。

    在这里插入图片描述

    Navicat给的这个图很形象,Navicat连接服务器,再在内部直接连接数据库

    如果对你有帮助,不要忘了点个赞呦,有问题可以提问,博主每天都会来逛逛的。

  • 相关阅读:
    java中的String.format使用
    白话解析平安笔试题:多线程交替打印
    centos7 yum install redis
    CentOS7 linux下yum安装redis以及使用
    开源规则流引擎实践
    java中System.err.print和System.out.print区别
    drools -规则语法
    小明历险记:规则引擎drools教程一
    规则引擎drools封装
    C#中Encoding.Unicode与Encoding.UTF8的区别
  • 原文地址:https://www.cnblogs.com/zhangguangxiang/p/14232505.html
Copyright © 2011-2022 走看看