javazx 发表于 2017-3-15 18:18:57

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

11.2 使用与运维
OceanBase不是设计出来的,而是在使用过程中不断进化出来的。因此,系统使
用以及运维的方便性至关重要。
OceanBase的使用者是业务系统开发人员,并交由专门的OceanBase DBA来运
维。为了方便业务使用,OceanBase实现了SQL接口且兼容MySQL协议,从而融入到
MySQL开源生态圈。MySQL大部分管理工具,例如MySQL客户端,MySQL admin,
能够在OceanBase系统中直接使用。另外,OceanBase将系统运维、监控相关的内部
信息存放到内部的系统表中,从而方便运维、监控系统获取。
11.2.1 使用
OceanBase早期版本只允许通过Java或者C API接口访问,新版本增加了SQL支
持,且兼容MySQL客户端访问协议。OceanBase推荐用户使用SQL,但老应用仍然可
以使用以前的Java API访问OceanBase。下面介绍几个访问与使用场景。
1.MySQL客户端连接
如图11-4所示,使用者采用MySQL客户端连接OceanBase。通过MySQL客户端可
以查看系统已有的表格、表格schema,执行select、update、insert、delete等SQL语
句,查看系统内部状态,以及发送OceanBase集群运维命令。图中首先通过create
table命令创建一张名称为test的表格,表格包含两列:id和name,其中id为主键。接
着,往表格中写入两行记录(1,"alice"),(2,"bob")。最后,通过select语句读
取这两行数据。
图 11-4 采用MySQL客户端连接OceanBase
2.JDBC访问(JDBC template)
Java应用通过标准JDBC访问OceanBase,代码如下所示:
ObGroupDataSource groupSource=new OBGroupDataSource();
groupSource.setUserName("user");//设置用户名
groupSource.setPasswd("pass");//设置密码
groupSource.setDbName("test");//OceanBase不支持db,这里可以填任意值
groupSouorce.setConfigURL(ob_addr_url);//设置OceanBase集群的地址
groupSource.init();//初始化data source
JdbcTemplate jtp=new JdbcTemplate();
jtp.setDataSource(groupSource);//设置jdbc template依赖的data source
String sql="select 1 from dual";
int ret=jtp.queryForInt(sql);//执行SQL查询
3.Spring集成
可以通过将OceanBase DataSource集成到Spring中,配置如下:
<bean id="groupDataSource"
class="com.alipay.oceanbase.ObGroupDataSource"
init-method="init">
<property name="username"value="user"/>
<property name="passwd"value="pass"/>
<property name="dbName"value="test"/>
<property name="configURL"value=ob_addr_url/>
</bean>
4.C客户端
C应用通过OceanBase C客户端访问OceanBase,使用方式与MySQL C客户端完全
一致,代码如下:
MYSQL mysql;
mysql_init(&mysql); //初始化
mysql_real_connect(&mysql,ob_url,ob_user,ob_pass,NULL,0,NULL,0); //连接
OceanBase数据库
mysql_real_query(&mysql,sql,strlen(sql)); //执行SQL查询
MYSQL_RES*res=mysql_store_result(&mysql); //获取SQL查询结果集
//处理SQL查询返回的结果集
while(MYSQL_ROW row=mysql_fetch_row(res)) //从结果集读取一行数据
{
//处理结果集中的一行结果
}
mysql_free_result(res); //释放结果集
mysql_close(&mysql); //关闭连接
当然,应用可能会在客户端维护OceanBase连接池,Java应用还可能会使用其他
持久层框架,例如iBatis。由于OceanBase兼容JDBC和MySQL C客户端,使用MySQL
的应用无须修改代码就能接入OceanBase。
11.2.2 运维
OceanBase内部实现了系统表机制,用于存储监控以及运维相关的信息。内部系
统表包含的内容如下:
●数据字典:表格的定义以及表格之间的关系、用户以及权限信息;
●服务器列表:集群中每种角色所在的服务器列表;
●配置信息:集群中每台服务器的配置信息;
●内部状态:每台服务器的读写次数、读写延时、缓存命中率、子表个数、内
存、磁盘、CPU使用情况、请求关键路径时间消耗,每日合并状态等;
基于内部系统表,可以开发各种方便的OceanBase运维功能,如OceanBase数据
库会话(Session)管理,读写性能实时监控工具、监控平台等。
图11-5是OceanBase某线上应用平均读取延时的监控图,包括单行读取平均延时
(average_succ_get_time)以及多行扫描平均延时(average_succ_scan_time)两个指
标,且单位均为微秒。监控图包含三种数据:当前数据(currval),昨天数据
(lastval)以及上周数据(baseval),便于对比。由于监控、运维工具变化较快,这
里不做太多介绍。
图 11-5 OceanBase某线上应用读取延时



页: [1]
查看完整版本: 《大规模分布式存储系统》第11章 质量保证、运维及实践【11.2】