java自学网VIP

Java自学网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 2631|回复: 0

《大规模分布式存储系统》第11章 质量保证、运维及实践【11.2】

[复制链接]
  • TA的每日心情
    开心
    2021-5-25 00:00
  • 签到天数: 1917 天

    [LV.Master]出神入化

    2025

    主题

    3683

    帖子

    6万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    66345

    宣传达人突出贡献优秀版主荣誉管理论坛元老

    发表于 2017-3-15 18:18:57 | 显示全部楼层 |阅读模式
    11.2 使用与运维
    2 r" }/ _# a8 N( DOceanBase不是设计出来的,而是在使用过程中不断进化出来的。因此,系统使
    8 k# @+ n) v. f5 W' _用以及运维的方便性至关重要。0 X( A# h, g! }, ?/ h1 h" r
    OceanBase的使用者是业务系统开发人员,并交由专门的OceanBase DBA来运
    . m9 p- ~3 L/ ^! M; M5 c8 U  S维。为了方便业务使用,OceanBase实现了SQL接口且兼容MySQL协议,从而融入到
    * A- Q2 R& V; y& H' e; eMySQL开源生态圈。MySQL大部分管理工具,例如MySQL客户端,MySQL admin,
    1 ^5 v3 s$ g9 v7 O能够在OceanBase系统中直接使用。另外,OceanBase将系统运维、监控相关的内部; q& K" F$ X. F
    信息存放到内部的系统表中,从而方便运维、监控系统获取。' R7 ]: H" g4 j
    11.2.1 使用
    ' n- [! v$ q( S5 ?6 L- J( fOceanBase早期版本只允许通过Java或者C API接口访问,新版本增加了SQL支8 |7 |; {1 e' A0 D( D; d
    持,且兼容MySQL客户端访问协议。OceanBase推荐用户使用SQL,但老应用仍然可2 h; H" l( n3 P4 {! J0 V
    以使用以前的Java API访问OceanBase。下面介绍几个访问与使用场景。1 z3 e9 d' M/ w, F- {! P
    1.MySQL客户端连接
    ! m8 z7 G' X6 t0 [! P如图11-4所示,使用者采用MySQL客户端连接OceanBase。通过MySQL客户端可
    & U: M6 R' F& g1 A. z; y以查看系统已有的表格、表格schema,执行select、update、insert、delete等SQL语6 E5 f$ l3 ~: Q% D' t
    句,查看系统内部状态,以及发送OceanBase集群运维命令。图中首先通过create' f3 k0 j5 M" s/ {& _; ~7 S* E
    table命令创建一张名称为test的表格,表格包含两列:id和name,其中id为主键。接! n7 {# ?' u% `, `" [
    着,往表格中写入两行记录(1,"alice"),(2,"bob")。最后,通过select语句读
    7 V. Y& t2 Q* K* h4 Q取这两行数据。
    - V& T9 B, u' J& v* J# k图 11-4 采用MySQL客户端连接OceanBase
    8 A9 ~- {3 D8 H  Q3 B2.JDBC访问(JDBC template)* C3 W/ n/ j) K
    Java应用通过标准JDBC访问OceanBase,代码如下所示:% c- B7 ~+ t; X% m
    ObGroupDataSource groupSource=new OBGroupDataSource();
    : Y2 U1 h% }( Y$ M2 JgroupSource.setUserName("user");//设置用户名+ C- L5 o: f3 {3 D# @7 M
    groupSource.setPasswd("pass");//设置密码4 I2 B$ h9 K! P/ g$ i+ K
    groupSource.setDbName("test");//OceanBase不支持db,这里可以填任意值5 J: V! q  m1 y7 u8 t/ [
    groupSouorce.setConfigURL(ob_addr_url);//设置OceanBase集群的地址
      y* O. P2 `2 E9 x* ygroupSource.init();//初始化data source
    - o# J$ q9 r+ Z6 ~! ~% yJdbcTemplate jtp=new JdbcTemplate();; T6 B+ P8 L. h% L) F
    jtp.setDataSource(groupSource);//设置jdbc template依赖的data source) e8 v* V, W  A2 g- y  x( i
    String sql="select 1 from dual";
    4 G: m/ U# d, Eint ret=jtp.queryForInt(sql);//执行SQL查询
    9 T1 Z" Z5 T  I  X3 m# B0 @1 d' W3.Spring集成
    9 U2 m7 n* M" W% I0 O可以通过将OceanBase DataSource集成到Spring中,配置如下:
    1 Y9 j8 Q% ~, W- C- A+ f<bean id="groupDataSource"$ g  m4 \% R7 O- m6 z
    class="com.alipay.oceanbase.ObGroupDataSource"' r0 K" j8 }  [! H
    init-method="init">
    ; _3 @9 l6 n" M& A<property name="username"value="user"/>+ G' R8 c# F& `' `8 Y' _( [
    <property name="passwd"value="pass"/>% e' z' ~8 n+ |& e( f1 m
    <property name="dbName"value="test"/>/ t! _9 _& ~4 w# e5 i( S
    <property name="configURL"value=ob_addr_url/>( S5 x) q6 X- t/ x: P4 r$ i
    </bean>0 Z3 B, U5 _6 `) a2 p6 G
    4.C客户端
    - \0 P# \  d* v  W$ q3 aC应用通过OceanBase C客户端访问OceanBase,使用方式与MySQL C客户端完全" w8 o; P. j* t( k1 E
    一致,代码如下:5 o1 T8 I( d5 x- f3 Y# [
    MYSQL mysql;
    # b2 b3 q* z: o5 Jmysql_init(&mysql); //初始化1 q6 C; Z; ~# c" f8 W( E8 G6 B
    mysql_real_connect(&mysql,ob_url,ob_user,ob_pass,NULL,0,NULL,0); //连接7 H1 i; F% ^+ T& @+ p
    OceanBase数据库
    / Y1 j1 m* R4 k( p0 I5 I) Amysql_real_query(&mysql,sql,strlen(sql)); //执行SQL查询! m; G6 d: m8 }% u
    MYSQL_RES*res=mysql_store_result(&mysql); //获取SQL查询结果集$ Z* x. h3 m, [) }7 l( ?& d9 B
    //处理SQL查询返回的结果集1 h4 H( m% o# w( q0 f
    while(MYSQL_ROW row=mysql_fetch_row(res)) //从结果集读取一行数据- b: y% T8 s. X) c
    {, D" B) S3 z6 z7 ^; R  P
    //处理结果集中的一行结果
    / Y8 ]3 i9 v8 V5 l3 N8 j1 W}# X$ Q7 g9 n8 v( S' s
    mysql_free_result(res); //释放结果集
    " O# w, Y; x; ^# P6 W6 m9 \mysql_close(&mysql); //关闭连接
    . Y" b; }$ w/ [' O3 Z- s; L当然,应用可能会在客户端维护OceanBase连接池,Java应用还可能会使用其他
    1 ^  F6 Z  W: E7 ]! P! V. X* @持久层框架,例如iBatis。由于OceanBase兼容JDBC和MySQL C客户端,使用MySQL, Y$ f9 |: k2 ?: N- t. ?5 T
    的应用无须修改代码就能接入OceanBase。
    0 w# k# D4 a" C/ [/ Z# h11.2.2 运维
    ; _' Y) N8 u6 i0 |' h% K6 F3 `OceanBase内部实现了系统表机制,用于存储监控以及运维相关的信息。内部系; e$ S" \8 y. J' b
    统表包含的内容如下:
    # y- E( Z% a* R+ {# O●数据字典:表格的定义以及表格之间的关系、用户以及权限信息;# U  w: ?% C- @+ N, W+ ~6 _) k
    ●服务器列表:集群中每种角色所在的服务器列表;
    / [( q* p" k2 Q5 r% U% `●配置信息:集群中每台服务器的配置信息;: F* J! u" C# Z5 @
    ●内部状态:每台服务器的读写次数、读写延时、缓存命中率、子表个数、内
    # W9 L: g: ~  V# ]存、磁盘、CPU使用情况、请求关键路径时间消耗,每日合并状态等;
    5 Z( d3 B9 [- A( T基于内部系统表,可以开发各种方便的OceanBase运维功能,如OceanBase数据
    % N! `: Y4 ?- d1 A0 C6 \库会话(Session)管理,读写性能实时监控工具、监控平台等。
    & b( H( O) F+ c图11-5是OceanBase某线上应用平均读取延时的监控图,包括单行读取平均延时
    / M; G  `+ ]3 x- b& G(average_succ_get_time)以及多行扫描平均延时(average_succ_scan_time)两个指2 R! p& r6 }! @  a
    标,且单位均为微秒。监控图包含三种数据:当前数据(currval),昨天数据
    . m9 r3 ]6 _- V$ e; j6 p(lastval)以及上周数据(baseval),便于对比。由于监控、运维工具变化较快,这2 X; E3 r; Y0 w5 j' H& `0 K
    里不做太多介绍。
      p* h- G( j9 b* e$ J图 11-5 OceanBase某线上应用读取延时
    & o0 t' M  p9 ^$ p9 K8 O' o. J# D' Y0 p' G3 T+ q3 w) @- q0 h
    8 ^+ {8 {1 a# n2 T
    & t' e4 Q. v' v% Z6 @
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|Archiver|手机版|小黑屋|Java自学网

    GMT+8, 2024-11-21 21:23 , Processed in 0.665017 second(s), 31 queries .

    Powered by Javazx

    Copyright © 2012-2022, Javazx Cloud.

    快速回复 返回顶部 返回列表