CrackerSW 2018-11-08 08:47 采纳率: 100%
浏览 3894
已采纳

如何通过域名解析的方式访问阿里云服务器上的mysql?

在阿里云上有一台服务器,服务器上安装了mysql服务器,我现在想通过域名的方式访问阿里云上的mysql。没有一点头绪。请前辈们指点一二,小弟感激不尽。

  • 写回答

5条回答 默认 最新

  • 玄尺 2018-11-12 15:21
    关注

    你的需求:
    你是直接在ECS上直接安装mysql server,希望从外网使用域名访问到mysql数据库服务。

    分析:
    1. 如果直接买阿里云DB服务,这个问题就不存在了
    2. 现在这种状态你肯定可以通过IP的方式访问到mysql,也就是说买了独立外网IP,但是你手上没有域名。

    解决手段:
    1. 你可以直接买一个域名,然后绑定你手上的ip,这样是可以解决问题,但是需要单独购买一个域名,确实不划算
    2. 第二种方法不是很正规,但是确实可以允许你使用域名的方式访问mysql,我们使用域名最终还是需要使用DNS转到IP进行访问,所以你可以使用www.xxxxxxx.com域名访问mysql
    2.1 绑定host,在host文件中添加www.xxxxxxx.com -> ip,因为jdk域名解析默认是通过系统的域名解析,所以这样做是可以达到效果的
    2.2 jvm中存在一个DNSCache,你可以使用一些工具,在项目启动时把域名和IP写入cache,并且设置永不过期
    以上两种方式都是采用DNS劫持的方式允许你使用任意域名访问mysql
    给出第二种手段的代码:

    <!-- dns -->
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>dns-cache-manipulator</artifactId>
        <version>1.5.1</version>
    </dependency>
    
    DnsCacheManipulator.setDnsCache("www.hello.com", "192.168.1.1");
    String ip = InetAddress.getByName("www.hello.com").getHostAddress();
    System.out.println(ip);
    

    说白了,如果你手上没有域名,是绝对不能像正常方式使用域名连接数据库的。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥100 谁能在荣耀自带系统MagicOS版本下,隐藏手机桌面图标?
  • ¥15 求SC-LIWC词典!
  • ¥20 有关esp8266连接阿里云
  • ¥15 C# 调用Bartender打印机打印
  • ¥15 我这个代码哪里有问题 acm 平台上显示错误 90%,我自己运行好像没什么问题
  • ¥50 C#编程中使用printDocument类实现文字排版打印问题
  • ¥15 找会编程的帅哥美女 可以用MATLAB里面的simulink编程,用Keil5编也可以。
  • ¥15 已知隐函数其中一个变量τ的具体值,求另一个变量
  • ¥15 r语言Hurst指数
  • ¥15 RT-Thread Studio编译问题