文档首页/ 表格存储服务 CloudTable/ 用户指南/ 使用Doris/ 连接Doris集群/ 使用MySQL客户端连接Doris普通集群
更新时间:2025-07-24 GMT+08:00

使用MySQL客户端连接Doris普通集群

用户在弹性云服务器里可以通过手动安装客户端的方法,使用MySQL访问集群。

使用限制

  • Doris集群与弹性云服务器具有相同区域、可用区、VPC。
  • Doris集群与弹性云服务器具有相同安全组。
  • 弹性云服务器安全组中添加本地主机IP地址。

手动安装客户端

  1. 准备Linux弹性云服务器,具体操作请见准备弹性云服务器章节。
  2. 安装客户端,连接集群。

    1. 使用SSH登录工具,通过弹性IP远程登录到Linux弹性云服务器。

      具体登录操作步骤请参见弹性云服务器《用户指南》中的“ SSH密码方式登录”章节。

    2. 登录后执行以下命令解压安装包。
      cd <客户端安装包存放路径>
      tar -xzvf 客户端压缩包名

      操作步骤提到的“<客户端安装包存放路径>”请替换为实际的客户端存放路径。

    3. 进入bin目录。
      cd mysql-5.7.22-linux-glibc2.12-x86_64/bin/
    4. 然后执行下面的命令连接Doris集群。
      ./mysql -uadmin -ppassword -h集群内网地址 -P9030
      • 集群内网地址:集群详情页面中集群访问地址,这里替换成您自己购买的集群的访问地址(FE节点的访问地址,都可以访问集群)。
      • password为您购买集群时设置的密码,如果有特殊符号,特殊符号前面需要\进行转义,如果密码整体用单引号括起来,则特殊字符不需要转义。
      • 端口:FE上的mysql server端口,参见表1
      表1 自定义安全规则组

      方向

      策略

      协议端口/范围

      类型

      目的/源地址

      用途

      出方向

      允许

      全部

      IPv4/IPv6

      0.0.0.0/0

      出方向放行。

      入方向

      允许

      9030

      CloudTable Doris集群所在的安全组。

      FE上的mysql server端口。

      允许

      8030

      FE上的http server端口。

      允许

      8040

      BE上的http server的端口。

      允许

      8050

      FE上的https server端口

Doris入门使用

  1. 创建一个数据库。
    CREATE DATABASE demo;
  2. 创建数据表
    • 使用数据库。
      USE demo;
    • 创建表。
      CREATE TABLE IF NOT EXISTS demo.example_tbl
      (
          `user_id` LARGEINT NOT NULL COMMENT "用户id",
          `date` DATE NOT NULL COMMENT "数据插入日期时间",
          `city` VARCHAR(20) COMMENT "用户所在城市",
          `age` SMALLINT COMMENT "用户年龄",
          `sex` TINYINT COMMENT "用户性别",
          `last_visit_date` DATETIME REPLACE DEFAULT "1970-01-01 00:00:00" COMMENT "用户最后一次访问时间",
          `cost` BIGINT SUM DEFAULT "0" COMMENT "用户总消费",
          `max_dwell_time` INT MAX DEFAULT "0" COMMENT "用户最大停留时间",
          `min_dwell_time` INT MIN DEFAULT "99999" COMMENT "用户最小停留时间"
      )
      AGGREGATE KEY(`user_id`, `date`, `city`, `age`, `sex`)
      DISTRIBUTED BY HASH(`user_id`) BUCKETS 1
      PROPERTIES (
          "replication_allocation" = "tag.location.default: 3"
      );
  3. 插入数据。
    INSERT INTO demo.example_tbl (user_id,date,city,age,sex,last_visit_date,cost,max_dwell_time,min_dwell_time) VALUES('10000','2017-10-01','A','20','0','2017-10-01 07:00:00','35','10','2'),('10001','2017-10-01','A','30','1','2017-10-01 17:05:45','2','22','22'),('10002','2017-10-02','B','20','1','2017-10-02 12:59:12','200','5','5'),('10003','2017-10-02','C','32','0','2017-10-02 11:20:12','30','11','11'),('10004','2017-10-01','D','35','0','2017-10-01 10:00:15','100','3','3'),('10004','2017-10-03','D','35','0','2017-10-03 10:20:22','11','6','6');
  4. 查询数据。
    • 我们上面完成了建表,输数据导入,下面我们就可以体验Doris的数据快速查询分析能力。
      mysql> SELECT * FROM demo.example_tbl;                                                                                                                                                                      +---------+------------+------+------+------+---------------------+------+----------------+----------------+
      | user_id | date       | city | age  | sex  | last_visit_date     | cost | max_dwell_time | min_dwell_time |
      +---------+------------+------+------+------+---------------------+------+----------------+----------------+
      | 10000   | 2017-10-01 | A    |   20 |    0 | 2017-10-01 07:00:00 |   35 |             10 |              2 |
      | 10001   | 2017-10-01 | A    |   30 |    1 | 2017-10-01 17:05:45 |    2 |             22 |             22 |
      | 10002   | 2017-10-02 | B    |   20 |    1 | 2017-10-02 12:59:12 |  200 |              5 |              5 |
      | 10003   | 2017-10-02 | C    |   32 |    0 | 2017-10-02 11:20:12 |   30 |             11 |             11 |
      | 10004   | 2017-10-01 | D    |   35 |    0 | 2017-10-01 10:00:15 |  100 |              3 |              3 |
      | 10004   | 2017-10-03 | D    |   35 |    0 | 2017-10-03 10:20:22 |   11 |              6 |              6 |
      +---------+------------+------+------+------+---------------------+------+----------------+----------------+
      6 rows in set (0.02 sec)
    • 查看指定城市信息。
      mysql> SELECT * FROM demo.example_tbl where city='B';
      +---------+------------+------+------+------+---------------------+------+----------------+----------------+
      | user_id | date       | city | age  | sex  | last_visit_date     | cost | max_dwell_time | min_dwell_time |
      +---------+------------+------+------+------+---------------------+------+----------------+----------------+
      | 10002   | 2017-10-02 | B    |   20 |    1 | 2017-10-02 12:59:12 |  200 |              5 |              5 |
      +---------+------------+------+------+------+---------------------+------+----------------+----------------+
      1 row in set (0.10 sec)
  5. 删除数据。
    1. 删除指定行数据。
      mysql> DELETE FROM demo.example_tbl WHERE user_id = 10003;
      Query OK, 0 rows affected (0.04 sec)
      {'label':'delete_77ed273a-a052-4d64-bac0-23916b698003', 'status':'VISIBLE', 'txnId':'39'}
    2. 删除表。
      mysql> DROP TABLE demo.example_tbl;
      Query OK, 0 rows affected (0.01 sec)