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
热门工具 换一换