AppBoxFuture(一): Hello Future!
AppBoxFuture是一个快速应用框架(Rapid Application Framework),是作者十几年从事信息化建设的经验结晶。框架具备以下一些特色:
极简的分布式系统架构
根据需要可单节点或集群部署,如下图所示:
模型驱动开发(MDD):
框架将应用系统所涉及的数据结构、业务逻辑、用户界面、工作流、报表、权限等抽象为各类型的模型,通过组合模型以形成完整的应用系统,通过调整模型以适应业务的需求变更。由于模型具备抽象性开发人员可以快速根据业务需求构建相应的模型;由于模型具备规范性约束,可以有效的保障不同技能的开发人员开发出高质量的系统;由于模型具备关联性约束,可以有效的保障调整模型时不引入新的缺陷。
集成强一致性数据存储:
框架基于Raft及RocksDB实现了分布式强一致性的存储引擎,由于分布式存储天生的特性,随着数据量的不断增长可以通过低成本的方式横向扩展(Scaleout)节点,并且在集群的多数派节点存活的条件下可保障系统连续不间断运行。
目前框架还在开发过程中,现就已完成的部分做一个技术预览,让我们开始体验吧:
安装与启动:
注意:目前仅支持Ubuntu18.04
安装依赖包
$>sudo apt install libsnappy1v5 libcrypto++6 libgnutlsxx28 libxml2 libnuma1 libhwloc5 libc-ares2 libatomic1 libunistring2
安装运行时
$> git clone https://github.com/enjoycode/appbox.deploy.git
启动集群的第一个节点
$> sudo ./appbox --init=10.211.55.10:9000 --peer=1.1.1
--init 指明初始化集群的第一个节点,请修改为本机地址;
--peer 指明本节点的编号, [数据中心编号].[机架编号].[机器编号]
开发体验
打开浏览器(建议新版Chrome),输入http://10.211.55.10:5000/dev/index.html
出现登录界面,输入用户名:Admin,密码:760wb,登录后跳转至框架集成开发环境界面。
实体模型(EntityModel对应数据结构)
注意:尚未实现新建及修改模型,暂用系统内置的员工模型作为示例(注意:Account成员上有惟一索引)。
服务模型(ServiceModel对应业务逻辑)
在左侧模型树内选择Services节点,点击主菜单“New->Service”,弹出新建对话框输入服务名称:EmpService后点击OK,然后从左侧模型树内展开并选择新建的EmpService,出现服务模型编辑界面,输入以下示例服务代码:
注意:服务代码编辑时有智能提示,在IDE底部的"Problems"会提示代码错误
using System;
using System.Threading.Tasks;
namespace sys.ServiceLogic
{
public class EmpService
{
public async Task<Entities.Emploee[]> GetAll(string name)
{
var q = new TableScan<Entities.Emploee>();
if (!string.IsNullOrEmpty(name))
q.Filter(t => t.Name == name);
return await q.ToListAsync();
}
}
}
点击主菜单“Save”保存,并点击主菜单“Publish”弹出发布对话框,点击Ok将变更的模型发布至运行时。此时框架会将虚拟的业务逻辑代码编译转换为运行时代码,并由运行时容器管理。
视图模型(ViewModel对应用户界面)
在左侧模型树内选择Views节点,点击主菜单“New->View",弹出新建对话框输入视图名称:EmpList后点击OK,然后从左侧模型树内展开并选择新建的EmpList,出现视图模型编辑界面,输入以下示例代码:
注意:视图模型包括模版(Template)、脚本(Script)及样式(Style)代码,另点击"Preview"可展开实时预览界面
模版示例代码:
<div>
<el-button-group>
<el-button type="primary" icon="fas fa-plus-circle"> 新建</el-button>
<el-button type="primary" icon="fas fa-search" @click="loadData"> 查找</el-button>
</el-button-group>
<el-input v-model="qname" placeholder="查询关键词" icon="search" style="width:150px" size="small">
</el-input>
<el-table :data="emps" border highlight-current-row>
<el-table-column prop="Name" label="名称" width="220">
</el-table-column>
<el-table-column prop="Account" label="帐号">
</el-table-column>
</el-table>
</div>
脚本示例代码
@Component
export default class EmpList extends Vue {
qname: string //查询关键词
emps = [] //员工列表
// 调用服务加载员工列表
loadData() {
sys.Services.EmpService.GetAll(this.qname).then(res => {
this.emps = res
}).catch(err => {
this.$message.error('加载失败')
})
}
}
此时在预览界面点击“查找”按钮,即可看到列表结果,在“查询关键词”输入“Admin“即可过滤。
小结
本篇主要体验框架的集成开发环境如何快速开发一个列表视图,并绑定调用相应的业务服务。下篇“Say goodbye to Sql“将介绍框架集成的强一致性分布式存储。
目前作者想寻志同道合者(前端ts, vue, 后端c++ c# rocksdb)来共同完成它,如有意向或问题请发邮件联系enjoycode@icloud.com
AppBoxFuture(一): Hello Future!的更多相关文章
- AppBoxFuture(五): 分布式文件存储-Store Everything
本来本篇是想介绍前端组件化开发用户界面,发现框架还未实现文件存储,原本计划是后续设计开发的,索性把计划提前,所以本篇将介绍基于Raft实现分布式的文件存储引擎. 一. 实现思路 既然是分布式存 ...
- AppBoxFuture(二): Say goodbye to sql!
信息管理类应用系统离不开关系数据存储,目前大家基本都使用的是传统的数据库如MySql.Postgres等.作者从事信息化建设十多年,个人认为传统的数据库存在以下的问题: 扩展问题: 系统数据的 ...
- 面向未来的友好设计:Future Friendly
一年前翻译了本文的一部分,最近终于翻译完成.虽然此设计思想的提出已经好几年了,但是还是觉得应该在国内推广一下,让大家知道“内容策略”,“移动优先”,“响应式设计”,“原子设计”等设计思想和技术的根源. ...
- 线程笔记:Future模式
线程技术可以让我们的程序同时做多件事情,线程的工作模式有很多,常见的一种模式就是处理网站的并发,今天我来说说线程另一种很常见的模式,这个模式和前端里的ajax类似:浏览器一个主线程执行javascri ...
- 第二篇 Entity Framework Plus 之 Query Future
从性能的角度出发,能够减少 增,删,改,查,跟数据库打交道次数,肯定是对性能会有所提升的(这里单纯是数据库部分). 今天主要怎样减少Entity Framework查询跟数据库打交道的次数,来提高查询 ...
- Eclipse调试Android App若选择“Use same device for future launches”就再也无法选择其他设备的问题
在狂批了某供应商的多媒体控制App有多烂后,夸下海口自己要做一个也是分分钟的事.当然要做好不容易,要超过他们的烂软件还是有信心的.过程中遇到各种坑,其中之一如下 刚开始只使用一个平板进行调试,老是弹出 ...
- java Future 接口介绍
(转自:http://blog.csdn.net/yangyan19870319/article/details/6093481) 在Java中,如果需要设定代码执行的最长时间,即超时,可以用Java ...
- java多线程系类:JUC线程池:06之Callable和Future(转)
概要 本章介绍线程池中的Callable和Future.Callable 和 Future 简介示例和源码分析(基于JDK1.7.0_40) 转载请注明出处:http://www.cnblogs.co ...
- 架构师养成记--9.future模式讲解
什么是future模式呢?解释这个概念之前我们先来了解一个场景吧,财务系统的结账功能,这个功能可能是每个月用一次,在这一个月中相关的数据量已经积累得非常大,这一个功能需要调用好几个存储过程来完成.假如 ...
随机推荐
- Tensor基本操作
Tensor(张量) 1.Tensor,又名张量,从工程角度来说,可简单地认为它就是一个数组,且支持高效的科学计算.它可以是一个数(标量).一维数组(向量).二维数组(矩阵)或更高维的数组(高阶数组) ...
- poi导出Excel直接在浏览器下载
需求:导出成Excel格式,要在浏览器看到类似于下载的效果. 导出的Excel和下载在同一个目录下. xxController.java // 导出 @RequestMapping(value = & ...
- Java之hashCode的作用和equals方法的重构规则
这个是博主对hashcode的初步理解,以后加深了会再来更新: 1.hashcode是什么? hashcode是对象的散列码,不同的对象几乎不一样,说几乎是因为还是可以一样的. 特点:每一个对象都有h ...
- 自行搭建私有云kodexplorer
kodexplorer是一款开源的私有云框架,可以通过它实现个人网盘的功能,如果拥有一个性能不错的VPS,那么就可以摆脱奇慢无比的百度云等网盘啦!最近百度网盘还发出申明,说要限制使用空间.用别人的东西 ...
- laravel 邮件配置
.env的配置 MAIL_DRIVER=smtpMAIL_HOST=smtp.163.comMAIL_PORT=465MAIL_USERNAME=你的163邮箱地址MAIL_PASSWORD=你的16 ...
- [微信小程序]在应用地图时,如何设置满屏(高度)
微信小程序在做地图功能时 用常规的办法height:100%:来设置高度来占满屏幕是不行的 它不会生效 应该改用单位vh 例如 height:100vh 这样就可以是地图占满整个屏幕高度
- Mybatis Mapper文件中的一小坑
前几天来一需求,实现过程中需要修改一个底层的查询接口,具体修改就是在where中添加一个条件,由于这个底层SQL使用的地方太多,所以就想着是用if加一标识符做个判断,传一个只有我会使用的参数,然后动态 ...
- angular学习笔记(三)
1.安装npm install --save @angular/material@2.0.0-beta.72.安装http://chrome-extension-downloader.com安装aug ...
- 依赖注入[2]: 基于IoC的设计模式
正如我们在<控制反转>提到过的,很多人将IoC理解为一种"面向对象的设计模式",实际上IoC自身不仅与面向对象没有必然的联系,它也算不上是一种设计模式.一般来讲,设计模 ...
- JavaScript 实现textarea限制输入字数, 输入框字数实时统计更新,输入框实时字数计算移动端bug解决
textarea称文本域,又称文本区,即有滚动条的多行文本输入控件,在网页的提交表单中经常用到.与单行文本框text控件不同,它不能通过maxlength属性来限制字数,为此必须寻求其他方法来加以限制 ...