概述
Uncode 是基于Java 语言的一系列开源后端开发组件,主要包括:移动后端开发框架Uncode-BaaS,通用数据库访问组件Uncode-DAL和分布式任务调度组件Uncode-Schedule。其核心设计目标是使移动后端开发更加简单、易于维护,同时框架对部分基础操作进行了封装,提供认证、安全控制、Restful等基础功能模块,可以大大提高开发速度,降低开发成本。
发展概况
Uncode 项目开发始于2014年末,作者冶卫军(Juny Ye)架构师,具有多年电商、银行等大型系统开发和架构经验,随着移动互联网的流行,在移动互联网领域带领技术团队创业多年。深刻体会到中小公司在发展过程中所遇到的各种技术问题,所以发起 Uncode 系列开源项目,希望可以为中小公司快速发展提供参考和方向。Uncode 采用对商业应用友好的Apache Licence 2.0协议。开源以来在中国最大的开源社区深受广大开发者欢迎。
Uncode 系列项目秉承以下设计目:快速开发、代码简单、易于学习、功能强大、轻量级、易扩展,在坚持以上设计目标的同时,本着不重复制造轮子的原则,很好的应用和整合现有流行框架,打创功能全面的移动应用后端系列组件,彻底解放中小公司开发者的生产力,让中小公司开发者将更多的精力投入到具体业务实现,降低公司产品研发的时间和人力成本,使产品快速投向市场。
Uncode 通过实践将逐步形成了一系列移动互联网公司后端开发组件,并将在 Uncode 开发社区展示出来。
Uncode-BaaS 移动后端开发框架
功能概述
Uncode-BaaS移动后端开发框架,注于移动应用后端服务开发,旨在让移动后端开发变得更简单。任何企业或个人,通过Uncode-BaaS都可以给移动应用快速定制个性化的后端业务逻辑,可以大大降低后端开发时间和成本。Uncode-BaaS框架提供了这种灵活性,可以让您的代码实现非常简单,并直接在各种云服务上运行。一旦你更新了代码,所有的移动应用都会立即自动更新,新功能的发布将会变得更加简单可控。
主要特色
1、简单易用
Uncode-BaaS移动后端开发框架,简单易用,易于开发。开发者可以自已制定或者直接使用第三方插件实现移动应用后端业务逻辑,让开发者可以快速完成业务逻辑制定,并直接运行,完全省掉后端开发的时间和人力成本。使开发者可以投入更多精力到移动应用本身,研发出更具竞争力的移动产品。
2、易于维护
Uncode-BaaS移动后端开发框架,为开发者提供集成测试功能,可以随时进行测试,直接运行,无需发布。具有良好的可扩展性,无需对原有业务进行修改,即可实现扩展,同时多个服务之间可以互相调用。可以根据业务量自动扩容,不会对现有业务产生任何影响,具有完美的可伸缩性。
3、个性化定制
Uncode-BaaS移动后端开发框架,可以帮助开发者为自已的移动应用定制个性化的业务逻辑,可以满足所有业务场景的需求。开发者可以用最小的成本快速定制出所需要的业务逻辑,在众多移动应用中脱颖而出,占领先机。同时当应用需要调整时,开发者也可以快速重试。
4、低成本快速开发
Uncode-BaaS移动后端开发框架,对移动后端业务逻辑进行了高度封装,提供非常简单的方法,可以使任何开发者根据自已的业务需要定制业务逻辑,同时我们提供非常完善的帮助文档、示例应用和在线问答,帮助您完成业务定制。您可以完全不需要后端开发人员,将大量精力投入到移动应用本身,极大的降低人工及时间成本。
5、多终端
Uncode-BaaS移动后端开发框架,基于标准rest协议,可以适用所有终端,包括IOS、Android、Windows Phone、Html5等。不用在移动应用中作任何代码嵌入,就可以对开发者的应用进行全方位的统计和分析,大大降低了移动应用开发的难度和成本,同时可以保证数据的及时性和准确性。
6、安全可靠
Uncode-BaaS移动后端开发框架,为了保障数据安全,可以同时对服务和数据进行权限控制,对于服务可以设置服务的访问对象和操作权限。对于数据本身,可以分别按照用户、角色和用户组,对表或字段级使用权限进行严格控制,可以保障最小粒度的权限控制,完美解决移动应用数据安全问题。另外利用云特性保障存储安全。
Uncode-DAL 通用数据访问组件
功能概述
Uncode-DAL通用数据访问组件,本着不重复制造轮子的原则,基于Mybatis、Spring JDBC、Hibernate、MongoDB等ORM框架开发,同时支持基于多数据源的读写分离、主备切换、故障转移,自动恢复、负载均衡、缓存等。可以大大提高开发速度。
主要特色
1、基于Mybatis、Spring JDBC、Hibernate等ORM框架实现通用DAL层功能,并可以与已有项目完全兼容。同时支持在ORM框架之间任意切换,不需要对代码作任何改动。
2、实现统一的DAL层Cache,可以自由设置过期时间。
3、实现基于多数据源(DataSource)的读写分离、主备切换、故障转移、恢复检测和负载均衡。
4、使用该组件建议遵循以下规则:
在使用DTO时,字段名称与数据库表字段一致,不区分大小写,也可以不使用任何DTO类,直接使用MAP。
不支持连表查询,主要是单表操作,如果需要连表请与原生orm框架配合使用。
SQL默认主键字段为id,NoSql默认主键字段为_id。
Uncode-Schedule 分布式任务调度组件
功能概述
Uncode-Schedule基于Zookeeper和Quartz/Spring Task的分布式任务调度组件,非常小巧,无需任何修改就可以使Quartz和Spring Task具备分布式特性,并确保所有任务在集群中不重复,不遗漏的被执行。
主要特色
1、基于流行的Zookeeper和Quartz/Spring Task的分布任务调度组件。
2、集群任务节点以单个JVM为单位,确保每个任务在集群中不同节点上不重复的执行。
3、单个任务节点故障时自动转移到其他任务节点继续执行。
4、弱依赖于Zookeeper,任务节点启动时需要保证Zookeeper可用,任务节点运行期Zookeeper集群不可用时任务节点保持可用前状态运行,Zookeeper可用后自动注册任务并恢复正常。
5、支持已有任务动态停止和运行。
6、使用注意事项:
单节点故障时需要应用自已保障数据完整性或幂等性。
具体使用方式和Quartz和Spring Task相同,只需要添加ZKScheduleManager配置即可。
项目评价
开源中国
2015 年 Git@OSC 新增热门开源软件项目 Top 50
其他
来源:oschina
链接:https://my.oschina.net/u/99241/blog/615090