JBoot的简单介绍和入门

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

猜你喜欢

转载自blog.csdn.net/zzzgd_666/article/details/80342669