CrackerSW
2018-11-08 08:47
采纳率: 100%
浏览 3.6k

如何通过域名解析的方式访问阿里云服务器上的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);
    

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

    已采纳该答案
    打赏 评论
  • cnlqm 2018-11-08 08:53

    首先域名要备案,然后把域名解析到该服务器

    jdbc.url=jdbc:mysql://域名:数据库端口/数据库名?useUnicode=true&characterEncoding=utf-8

    注:这个端口要在安全组里开放

    打赏 评论
  • 幸福丶如此 2018-11-08 08:55

    因为阿里云数据库服务器一般是内网环境的,如果享用域名访问,需要在服务器本地配置hosts解析,将 给的一长串地址和域名做一个对应关系

    打赏 评论
  • 呵呵哥 2018-11-08 09:58

    直接买阿里云的mysql数据库 别人都是配置好的 也不用担心

    打赏 评论
  • gammey 2018-11-09 03:30

    你要用什么协议访问?

    打赏 评论

相关推荐 更多相似问题