Jboot发布啦

 

Jboot是什么呢?

详情地址地址:https://git.oschina.net/fuhai/jboot


jboot是一个类型springboot的开源框架,基于jfinal和undertow等非常优秀的、已经在商业项目中应用多年的、有良好口碑的、性能非常不出的诸多框架开发而成。

Jboot是一个新的轮子,但是是集大家之所长的一个极度好用的轮子。

如何使用Jboot呢?



第一步:maven依赖。
<dependency> <groupId>io.jboot</groupId> <artifactId>jboot</artifactId> <
version>1.0-alpha3</version> </dependency>
 



第二步:coding

废话,都低coding都支持什么样的coding,有什么样的好处呢?

 

我们从几个方面来看:



一、mvc
@RequestMapping("/") public class MyController extend JbootController{    
public void index(){ renderText("hello jboot"); } public static void main
(String [] args){ Jboot.run(args); } }
 

启动main方法,然后访问 http://127.0.0.1:8088,然后你就能看到浏览器输出:hello jboot.

 

怎么样?是否极度简单呢?

 

我们继续.

 

 



二、数据库查询。

表结构:

  CREATE TABLE `user` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `login_name` varchar(32) DEFAULT NULL,
  `password` varchar(32) DEFAULT NULL,
  PRIMARY KEY (`id`)
  ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
 

在resources下创建jboot.properties文件,并配置如下:

  jboot.datasource.type=mysql
  jboot.datasource.url=jdbc:mysql://127.0.0.1:3306/jbootdemo
  jboot.datasource.user=root
  jboot.datasource.password=
 

然后简单改造下刚才的controller:
@RequestMapping("/") public class MyController extend JbootController{    
public void index(){ List<Record> records = Db.find("select * from `user`");
setAttr("users",records); render("index.html"); } public static void main
(String [] args){ Jboot.run(args); } }
 

因为我们用到了html,所以我们在resource下建立一个index.html来渲染数据。html的内容如下:


<html >
<head>
<meta charset=“UTF-8”>
<title>users</title>
</head>
<body>

#for(user : users) #(user.login_name)<br />
end

</body>
</html>

 

启动main方法,访问页面后,页面显示了数据库列表的数据。

 

OK,实际上这些都是小case,来个复杂的。

 



三:微服务

微服务是什么呢?在大型的系统里面,比如京东。实际上有很多个“项目”组成的,每个“项目”都可以理解为一个服务,把大型的项目拆分成多个微小的服务就是微服务了。

 


微服务有什么好处呢?大家可以试想一下,如果我们把所有的功能都写在一个“项目”里面,如果说其中一个小模块除了点问题,我们重新升级这个小模块,那就需要我们对整个项目重新部署,这个过程中可能就会中断服务。

 

比如说,京东的快递查询模块出现问题了,不肯能因为升级而重启整个京东网站。

 

这个时候就只能把每个模块都做成一个“项目”或者叫“服务”。

 

但是这个时候,京东网想要去读取这个“项目”的数据,怎么办呢?我们可以让这个项目提供一个api接口,然后让需要这个数据的项目去调用这个接口。

 

但是,这样还是很麻烦。

 

在众多的项目中,都使用到了一种技术,叫RPC,也就是remote procedure
call的简写。翻译过来叫远程过程调用,再简单点就理解为“远程调用”好了,

也就是我们在我们的项目里,只要调用 xxx.aaa() 这样,就调用到了远程服务器的 aaa() 方法了。

 

RPC的开源框架,市面上有很多,比如google的grpc,tiwtter的thirft,淘宝的dubbo,新浪的motan。

 

Jboot集成了 grpc、thirft和motan(为什么不要dubbo呢?因为好几年没维护了),所以在jboot中使用rpc,极致、简单、爽!

 

首先需要我们定义个接口,接口中不要有任何的实现。代码如下:
public interface HelloService { public String hello(String name); }
然后只需要我们在项目A中,写我们自己的一个类,实现这个接口,一般叫service类。代码如下:
@JbootrpcService public class myHelloServiceImpl implements HelloService {
public String hello(String name){ System.out.println("hello" + name); return
"hello ok"; } }
注意:在实现类中添加@JbootrpcService注解。

 

然后在我们的另个项目,暂且叫项目B,在这个项目中代码如下:
public class MyController extends bootController{ @JbootrpcService HelloService
service ; public void index(){ renderText("hello " + service.hello()); } }
定义个HelloService接口,也是用@JbootrpcService注解,就可以爽快在在项目B中调用项目A的接口了。

 

当然,还需要给jboot做个简单的配置:
jboot.rpc.type = motan jboot.rpc.registryType = consul jboot
.rpc.registryAddress =127.0.0.1:8500
下载consul到本地计算机,然后执行命令
consul -agent dev
注:consul 下载地址 http://consul.io

 


一旦涉及到微服务,更多的只是好包括了如何防止微服务雪崩、如何对为辅的调用统计、如何对微服务的跟踪,如果对微服务的路由,这些实际上Jboot已经支持,但是并非这篇文字能写的完的了。

 

实际上、Jboot一样支持类型spring的ioc和aop,支持了众多的mq(activeMQ、rabbitMQ,阿里云商业MQ等等)和
良好的缓存机制、事件机制等等等等。

 

 

Jboot 开源地址:https://git.oschina.net/fuhai/jboot

 

 


友情链接
KaDraw流程图
API参考文档
OK工具箱
云服务器优惠
阿里云优惠券
腾讯云优惠券
华为云优惠券
站点信息
问题反馈
邮箱:ixiaoyang8@qq.com
QQ群:637538335
关注微信