Oceanus 正在参加 2021 年度 OSC 中国开源项目评选,请投票支持!
Oceanus 在 2021 年度 OSC 中国开源项目评选 中已获得 {{ projectVoteCount }} 票,请投票支持!
2021 年度 OSC 中国开源项目评选 正在火热进行中,快来投票支持你喜欢的开源项目!
2021 年度 OSC 中国开源项目评选 >>> 中场回顾
Oceanus 获得 2021 年度 OSC 中国开源项目评选「最佳人气项目」 !

软件简介

Oceanus 是 58 同城数据库中间件。

关于DB中间件

在DB存储需求中,尽管业务不同,技术难点还是类似的,开源世界有很多DB中间件,解决方案也以通用方案为主,满足业务需要为前提,支持各种类型的需求。

Oceanus致力于打造一个功能简单、可依赖、易于上手、易于扩展、易于集成的解决方案,甚至是平台化系统。拥抱开源,提供各类插件机制集成其他开源项目,新手可以在几分钟内上手编程,分库分表逻辑不再与业务紧密耦合,扩容有标准模式,减少意外错误的发生。

Oceanus内部名词定义

  • datanode:数据源节点。为一个数据源命名,配置链接属性、报警实现

  • namenode:数据源的簇。为一组数据源命名,指定这组数据源的负载方式、访问模式、权重

  • table:映射表。匹配解析sql中的table名称,命中table标签的name属性值后,会执行约定的路由逻辑

  • bean:实体。由其他标签引用,实体类必须有无参的构造函数

  • tracker:监控埋点。涉及到计算和IO的功能点都有监控点,自定义一个埋点实现类,当功能耗时超出预期时会执行其中的回调函数,便于监控和优化系统

为什么说Oceanus是非常易用的

Oceanus在设计时非常注重使用者的评价,配置结构近乎于和使用者交流约定业务规则,便于不同的人看同一套配置,互相理解流程。当配置文件编写 完成后,编码就变得更加简单,只调用Oceanus客户端的几个方法就可以实现数据库操作,不再关心HA、报警、负载均衡、性能监控等问题。良好的用户视 觉减少了分库分表在业务场景中的耦合度,对于编码者就像只对一个table操作,Oceanus负责进行sql解析、路由、sql重写。

如提交:    select * from user;

改写成:    select * from user0;
           select * from user1;
           select * from user2;
           select * from user3;

分发给不同的库(或者同库)执行,用户视觉如图:github

开源集成

“接地气,拥抱开源” 是Oceanus的设计原则之一,可以很好的集成到mybatis和hibernate中,只要引用其中的插件,编写Oceanus配置文件,然后改写各 自的DataSource实现或ConnectionProvider即可做到集成。这样既用到了熟悉的ORM,又借助Oceanus实现了分库分表等功 能。

待开发

不得不说Oceanus在设计上非常灵活,使得每一个细小的功能点都有极高的切入价值,比如Cache机制、全局的ID生成规则、资源可视化监控等等,把其中某一个点做得足够好,都会为整体产品带来质的提升,简化实际生产环境中的配套系统研发维护成本。

展开阅读全文

代码

的 Gitee 指数为
超过 的项目

评论 (5)

加载中
打分: 力荐
推荐下 client 级别分表分库数据库中间件 Sharding-JDBC,支持 MySQL Oracle SQLServer PostgreSQL 很靠谱的数据库中间件。 代码结构有层次,编码规范。 有兴趣了解,可以看我博客:http://www.yunai.me/categories/Sharding-JDBC/?oschina&43
2017/08/06 18:24
回复
举报
这种中间件设计思路就不对,很难用 Oceanus
2015/03/04 09:24
回复
举报
看看 Oceanus
2015/03/04 10:12
回复
举报
这个的设计思路貌似跟阿里的cobar是一样的 Oceanus
2015/03/05 15:25
回复
举报
mark #Oceanus#
2016/03/28 22:42
回复
举报
更多评论
暂无内容
发表于软件架构专区
2020/07/13 18:56

7月13日 Oceanus上线倒计时5天

本文分享自微信公众号 - Conflux中文社区(Conflux-Chain)。 如有侵权,请联系 support@oschina.cn 删除。 本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

0
0
发表于网络技术专区
2020/07/14 18:22

7月14日 Oceanus上线倒计时4天

本文分享自微信公众号 - Conflux中文社区(Conflux-Chain)。 如有侵权,请联系 support@oschina.cn 删除。 本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

0
0
发表于区块链专区
2020/07/15 18:27

7月15日 Oceanus上线倒计时3天

本文分享自微信公众号 - Conflux中文社区(Conflux-Chain)。 如有侵权,请联系 support@oschina.cn 删除。 本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

0
0
发表于网络技术专区
2020/07/17 18:40

7月17日 Oceanus上线倒计时1天

本文分享自微信公众号 - Conflux中文社区(Conflux-Chain)。 如有侵权,请联系 support@oschina.cn 删除。 本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

0
0
发表于网络技术专区
2020/07/16 19:10

7月16日 Oceanus上线倒计时2天

本文分享自微信公众号 - Conflux中文社区(Conflux-Chain)。 如有侵权,请联系 support@oschina.cn 删除。 本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

0
0
发表了博客
2018/09/07 15:00

Oceanus:美团HTTP流量定制化路由的实践

背景简述 Oceanus是美团基础架构部研发的统一HTTP服务治理框架,基于Nginx和ngx_lua扩展,主要提供服务注册与发现、动态负载均衡、可视化管理、定制化路由、安全反扒、session ID复用、熔断降级、一键截流和性能统计等功能。本文主要讲述Oceanus如何通过策略抽象、查询、渲染和分组动态更新,实现HTTP请求的定制化路由。 随着公司业务的高速发展,路由场景也越来越复杂。比如: 团购秒杀要灵活控制压测流量,实现线上服务单节点...

0
0
发表了博客
2018/09/07 14:21

Oceanus:美团HTTP流量定制化路由的实践

# 背景简述 Oceanus是美团基础架构部研发的统一HTTP服务治理框架,基于Nginx和ngx_lua扩展,主要提供服务注册与发现、动态负载均衡、可视化管理、定制化路由、安全反扒、session ID复用、熔断降级、一键截流和性能统计等功能。本文主要讲述Oceanus如何通过策略抽象、查询、渲染和分组动态更新,实现HTTP请求的定制化路由。 随着公司业务的高速发展,路由场景也越来越复杂。比如: - 团购秒杀要灵活控制压测流量,实现线上服务单...

0
2
发表于软件架构专区
2020/07/18 10:00

山河岁月 未来可期 Conflux 2周年&网络第二阶段(Oceanus)上线

END 了解最新动态 (向上滑动查看内容) 官方网站 confluxnetwork.org Bounty网站 bounty.conflux-chain.org 抖音关注@烤仔 微博关注@Conflux中文社区 weibo.com/confluxchain 知乎关注@Conflux中文社区 www.zhihu.com/org/confluxzhong-wen-she-qu/activities 百度贴吧关注@Conflux中文社区 tieba.baidu.com/f?kw=conflux%E4%B8%AD%E6%96%87%E7%A4%BE%E5%8C%BA Twitter关注@ConfluxChain twitter.com/Conflux_Network Reddit ...

0
0
发表了博客
2019/01/31 15:21

腾讯大数据平台Oceanus: A one-stop platform for real time stream processing powered by Apache Flink

January 25, 2019 Use Cases, Apache Flink The Big Data Team at Tencent In recent years, the increasing need for timeliness, together with advances in software and hardware technologies, drive the emergence of real-time stream processing. Real-time stream processing allows public and private organizations to monitor collected information, make rapid decisions, tweak production processes, and ulti...

0
0
没有更多内容
加载失败,请刷新页面
点击加载更多
加载中
下一页
发表了问答
2015/04/10 14:46

Spring 如何整合Oceanus

如题,spring怎么集成Oceanus,配置文件要怎么弄?

1
0
没有更多内容
加载失败,请刷新页面
点击加载更多
加载中
下一页
5 评论
290 收藏
分享
OSCHINA
登录后可查看更多优质内容
返回顶部
顶部