java自学网VIP

Java自学网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 2730|回复: 0

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

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

    [LV.Master]出神入化

    2078

    主题

    3736

    帖子

    6万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    66680

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

    发表于 2017-3-15 18:18:57 | 显示全部楼层 |阅读模式
    11.2 使用与运维" c: e& y/ K* K0 x7 p1 a
    OceanBase不是设计出来的,而是在使用过程中不断进化出来的。因此,系统使
    6 C  r: B9 w) G, _- R用以及运维的方便性至关重要。
    - y9 j* {) s: s8 x' k& N* @7 n" uOceanBase的使用者是业务系统开发人员,并交由专门的OceanBase DBA来运4 Z$ i/ ?$ y& ~3 E+ ^2 k, h
    维。为了方便业务使用,OceanBase实现了SQL接口且兼容MySQL协议,从而融入到
    " f/ h: X+ U8 R8 vMySQL开源生态圈。MySQL大部分管理工具,例如MySQL客户端,MySQL admin,3 m9 B* T3 k& H5 L6 s0 \* h  Q2 w. T
    能够在OceanBase系统中直接使用。另外,OceanBase将系统运维、监控相关的内部, e' Y: r8 Z* h8 Z( W) o
    信息存放到内部的系统表中,从而方便运维、监控系统获取。
    " n. n6 U. M% P7 \8 e& q9 M8 \11.2.1 使用
    ' r7 u6 j* e8 H3 W+ sOceanBase早期版本只允许通过Java或者C API接口访问,新版本增加了SQL支
    , \/ {+ c" O+ ]- {; [. }* }持,且兼容MySQL客户端访问协议。OceanBase推荐用户使用SQL,但老应用仍然可/ v" I( b0 f  A. L
    以使用以前的Java API访问OceanBase。下面介绍几个访问与使用场景。
    ! J' @8 l, Y; u6 @3 |* w9 L1.MySQL客户端连接
    ) j5 g" j4 \  M' l5 q- s如图11-4所示,使用者采用MySQL客户端连接OceanBase。通过MySQL客户端可
    ( Z" o* Q6 e. y( r2 z: ^以查看系统已有的表格、表格schema,执行select、update、insert、delete等SQL语: s7 X1 K6 }' _  k' z# P; `9 m7 v
    句,查看系统内部状态,以及发送OceanBase集群运维命令。图中首先通过create
    % v8 ^$ }" ~! k3 l/ otable命令创建一张名称为test的表格,表格包含两列:id和name,其中id为主键。接
    % f1 T! D2 Z3 c( y0 [* K! c: h; W7 p着,往表格中写入两行记录(1,"alice"),(2,"bob")。最后,通过select语句读& V: P  \! M0 m# k9 M/ U
    取这两行数据。& h) P6 K) h6 H
    图 11-4 采用MySQL客户端连接OceanBase; r5 I) \! m  ^4 ]2 Z7 o
    2.JDBC访问(JDBC template)
    & x+ B! U% I: _/ u, w% kJava应用通过标准JDBC访问OceanBase,代码如下所示:
    5 r  a. L3 p/ U+ c% e$ y: nObGroupDataSource groupSource=new OBGroupDataSource();
    2 @8 l, o  U' B8 I3 d5 tgroupSource.setUserName("user");//设置用户名
    ; y9 s9 E6 y. M5 ?groupSource.setPasswd("pass");//设置密码
    ) `. [4 w; M% }8 X8 f$ \) GgroupSource.setDbName("test");//OceanBase不支持db,这里可以填任意值
    * O% d& M& }7 a5 M1 S+ H4 AgroupSouorce.setConfigURL(ob_addr_url);//设置OceanBase集群的地址# v9 i! U9 C) I" f' V2 @5 Q
    groupSource.init();//初始化data source
    5 E6 X9 q* ]" l- g- g3 |, RJdbcTemplate jtp=new JdbcTemplate();
    ! j) ]# \$ T4 P9 m& ljtp.setDataSource(groupSource);//设置jdbc template依赖的data source
    " a  r) ]' D. g; A6 ?4 x* x5 @String sql="select 1 from dual";
    ( ^$ x- z5 n0 r' V2 c- ?) Nint ret=jtp.queryForInt(sql);//执行SQL查询
    - C! s! \  K# H/ O7 }3 c+ d! G3.Spring集成
    / H, Y# s' [5 n: g% k可以通过将OceanBase DataSource集成到Spring中,配置如下:1 m; v: ^, {& I- Q" H7 v* l
    <bean id="groupDataSource"9 |$ }/ x# c9 V" O
    class="com.alipay.oceanbase.ObGroupDataSource"0 s3 K( S; Q5 ]
    init-method="init">$ x$ N3 x3 J# c$ r) q
    <property name="username"value="user"/>
    $ F4 \2 O& x! j. a( P3 T<property name="passwd"value="pass"/>
    5 i1 O1 K$ J0 f<property name="dbName"value="test"/>, ]9 Z% _& i1 I" o; i+ R2 ?
    <property name="configURL"value=ob_addr_url/>
    : @. }* o: {% }</bean>+ [- T! B: L# T: e, N
    4.C客户端9 K) F+ t5 V1 Z! \$ u' `' m) x) i1 D
    C应用通过OceanBase C客户端访问OceanBase,使用方式与MySQL C客户端完全
    * L$ p2 P# n8 S4 Q( O一致,代码如下:
    $ y1 X4 W) w8 ^* }( ^& GMYSQL mysql;
    5 t: A  `7 }, i3 ^0 zmysql_init(&mysql); //初始化5 O% m  |+ T) ]3 Z; j8 R
    mysql_real_connect(&mysql,ob_url,ob_user,ob_pass,NULL,0,NULL,0); //连接5 ]8 J1 d% a7 B# v8 v% w& X: |
    OceanBase数据库/ D% D/ h, @: r7 S4 _
    mysql_real_query(&mysql,sql,strlen(sql)); //执行SQL查询; L% ?6 p# M! o
    MYSQL_RES*res=mysql_store_result(&mysql); //获取SQL查询结果集7 e' [: b3 E/ S+ q+ t/ h
    //处理SQL查询返回的结果集
    & c* r8 q: \# X, X( p8 twhile(MYSQL_ROW row=mysql_fetch_row(res)) //从结果集读取一行数据
    $ d  D$ c0 O( s7 o' n{6 c, c* a- ]/ C( [. {
    //处理结果集中的一行结果
    $ \. h* z2 s) m3 E1 n$ u+ ^}4 a1 u( k: c% Z
    mysql_free_result(res); //释放结果集/ i& O- C1 P0 X& x# R2 v
    mysql_close(&mysql); //关闭连接
    + e6 Q2 W% k( ^0 {4 p& q9 M2 `当然,应用可能会在客户端维护OceanBase连接池,Java应用还可能会使用其他
    9 J: J4 \$ m/ [! {2 x% V& e持久层框架,例如iBatis。由于OceanBase兼容JDBC和MySQL C客户端,使用MySQL
    7 k6 b+ c2 l) Y, X# g的应用无须修改代码就能接入OceanBase。, i. a- _! r: Y) L* B2 g
    11.2.2 运维
    0 K6 C8 z* F" d7 C/ e4 y/ u+ k" JOceanBase内部实现了系统表机制,用于存储监控以及运维相关的信息。内部系8 G9 \. g( ^1 w$ P9 m( e7 T
    统表包含的内容如下:
    6 i0 f% x0 i, f) U2 Q3 n●数据字典:表格的定义以及表格之间的关系、用户以及权限信息;
    ) C8 y$ F. X" b' o9 W2 R! J( z* {8 A●服务器列表:集群中每种角色所在的服务器列表;$ `) @' x, f5 h$ F( M- q) g/ Z
    ●配置信息:集群中每台服务器的配置信息;
    1 R5 [/ \  k7 Y7 h●内部状态:每台服务器的读写次数、读写延时、缓存命中率、子表个数、内9 ~6 v  t. O4 N/ b/ x
    存、磁盘、CPU使用情况、请求关键路径时间消耗,每日合并状态等;$ q  u) W4 e1 W. R0 ^6 M
    基于内部系统表,可以开发各种方便的OceanBase运维功能,如OceanBase数据0 S# R9 @( ]' c) X0 v
    库会话(Session)管理,读写性能实时监控工具、监控平台等。
    " ~& q! _4 L% x5 e' m; k图11-5是OceanBase某线上应用平均读取延时的监控图,包括单行读取平均延时
    ' B1 `/ p0 T& P3 O- J: J  r  r8 J(average_succ_get_time)以及多行扫描平均延时(average_succ_scan_time)两个指
    9 ?( Y1 P& R) m7 W; i; X3 k标,且单位均为微秒。监控图包含三种数据:当前数据(currval),昨天数据
    % \- R! E$ E6 }(lastval)以及上周数据(baseval),便于对比。由于监控、运维工具变化较快,这
    7 p' C1 m* x3 F& N: M  n1 P里不做太多介绍。
    . J+ m1 H, N; u  r. K图 11-5 OceanBase某线上应用读取延时7 U% g/ O- K; R& h* i! v1 d8 U

    3 o4 M/ _$ \: u2 O7 |& @( c% f1 O+ B- a. U
    0 {* W- r" d" J2 u  L0 H$ ?" U, z' d
    回复

    使用道具 举报

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

    本版积分规则

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

    GMT+8, 2025-3-13 23:41 , Processed in 0.211544 second(s), 33 queries .

    Powered by Javazx

    Copyright © 2012-2022, Javazx Cloud.

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