【2】JMicro微服务-Hello World
如非授权,禁止用于商业用途,转载请注明出处
作者:mynewworldyyl
1. 首先完成
JMicro微服务-RPC体验 的1到5步。
按默认方式启动ZK及Redis;
JDK需要Java8及以上。
2.建立Maven Java项目,如下图

2.1 jmicro.example.api公共接口项目代码
在pom.xml增加如下依赖
<dependency>
<groupId>org.jmicro</groupId>
<artifactId>jmicro.api</artifactId>
</dependency>
新建RPC接口,代码如下
import org.jmicro.api.annotation.Service;
public interface ISimpleRpc {
String hello(String name);
}
2.2 服务提供者jmicro.example.provider
在pom.xml加如下依赖
<dependency>
<groupId>org.jmicro</groupId>
<artifactId>jmicro.all</artifactId>
</dependency>
<dependency>
<groupId>org.jmicro</groupId>
<artifactId>jmicro.example.api</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
新建服务提供者类,并实现ISimpleRpc接口,代码如下
@Override
@SMethod
public String hello(String name) {
System.out.println("Server hello: " +name);
return "Server say hello to: "+name;
}
Service注解表示这是一个服务类,对外提供RPC服务
SMethod表示这是一个RPC方法,如果没有SMethod注解,Service类下的全部public方法都将作为RPC方法。
打包运行服务提供者,CMD进入jmicro.example.provider目录,运行
mvn clean install -Pbuild-main
运行服务(请确保ZK及Redis已经启动,并且使用默认端口)
java -jar target/jmicro.example.provider-0.0.1-SNAPSHOT-jar-with-dependencies.jar
2.3 服务消费者jmicro.example.comsumer
pom.xml依赖和提供者相同,注意服务提供者和消费者都只依赖于jmicro.example.api中的接口类ISimpleRpc,相互之间没有直接依赖
build配置,使用我们自定义的main函数类入口org.jmicro.example.comsumer.ServiceComsumer
<build>
<plugins>
<plugin>
<artifactId>maven-assembly-plugin</artifactId>
<configuration>
<archive>
<manifest>
<mainClass>org.jmicro.example.comsumer.ServiceComsumer</mainClass>
</manifest>
</archive>
</configuration>
</plugin>
</plugins>
</build>
消费者类很简单,代码如下
public class ServiceComsumer {
public static void main(String[] args) {
IObjectFactory of = JMicro.getObjectFactoryAndStart(new String[]{""});
ISimpleRpc src = of.get(ISimpleRpc.class);
//invoke remote service
System.out.println(src.hello("Hello JMicro"));
}
}
打包运行消费者,CMD进入jmicro.example.comsumer目录,运行
mvn clean install
运行消息者(请确保服务供者已经启动)
java -jar target/jmicro.example.comsumer-0.0.1-SNAPSHOT-jar-with-dependencies.jar
分别查看服务提供者和费者终端输出
关键点:
1。ZK及Redis默认端口启动;
2。Service注解服务提供者,SMethod注解服务方法;
3。通IObjectFactory取得远程服务ISimpleRpc实例,并调用RPC方法;
4。必须先完成
JMicro微服务-RPC体验 的1到5步。
进一步尝试:
开不同的CMD窗口,CD进入jmicro.example.provider目录,运行多个服务提供者
java -jar target/jmicro.example.provider-0.0.1-SNAPSHOT-jar-with-dependencies.jar
然后多次运行消费者,Ctrl+C退出,然后重复执行
java -jar target/jmicro.example.comsumer-0.0.1-SNAPSHOT-jar-with-dependencies.jar
观察每次每个服务提供者的输出?
【2】JMicro微服务-Hello World的更多相关文章
- 【13】JMicro微服务-ID生成与Redis
如非授权,禁止用于商业用途,转载请注明出处作者:mynewworldyyl 往下看前,建议完成前面1到12小节 1. 微服务中ID地位 如果说前面小节的功能点是微服务的大脑,那么全局唯一ID则是微服务 ...
- 【12】JMicro微服务-Zookeeper
如非授权,禁止用于商业用途,转载请注明出处作者:mynewworldyyl 往下看前,建议完成前面1到11小节 1. CuratorFramework支持 JMicro目前基于Zookeeper实现统 ...
- 【11】JMicro微服务-配置管理
如非授权,禁止用于商业用途,转载请注明出处作者:mynewworldyyl 往下看前,建议完成前面1到10小节 JMicro目前仅支持基于Zookeeper做配置管理,全部配置信息可以在ZK做增删改查 ...
- 【10】JMicro微服务-API网关
如非授权,禁止用于商业用途,转载请注明出处作者:mynewworldyyl 往下看前,建议完成前面1到9小节 1. Api网关基本特性: Api网关作为对外网提供服务的基本入口,地位类似于NGINX, ...
- 【8】JMicro微服务-JMicro ZKUI
ZKUI是一个开源项目,是一个查看,修改ZK数据非常方便的工具.JMicro基于ZK做服务治理,配置管理,因此使用ZKUI会提供非常大的方便. Github地址:https://github.com/ ...
- 【3】JMicro微服务-服务超时,重试,重试间隔
如非授权,禁止用于商业用途,转载请注明出处作者:mynewworldyyl 接下来的内容都基于[2]JMicro微服务-Hello World做Demo 微服务中,超时和重试是一个最基本问题下面Dem ...
- JMicro微服务之超时&重试
JMicro是本人开发的基于Java实现的微服务框架,当前正式版本为0.0.3,并已发布到maven中央仓库.项目源码github:https://github.com/mynewworldyyl/j ...
- 【6】JMicro微服务-服务日志监控
如非授权,禁止用于商业用途,转载请注明出处作者:mynewworldyyl 1. 微服务相关 在前面的1到5节中,总共涉及服务提供者,服务消费者,服务监听服务,发布订阅服务,熔断器服务5种类型的猪 ...
- 【9】JMicro微服务-发布订阅消息服务
如非授权,禁止用于商业用途,转载请注明出处作者:mynewworldyyl 1. JMicro消息服务目前实现特性 a. JMicro只支持发布订阅消息服务,不支持队列式消息服务: b. 不支持消息持 ...
随机推荐
- Django基础学习四_数据库的增删改查
今天主要学习两个东西 1.如何对数据库做增删改查 2.如果将数据库中的数据用html的方式返回到前台 一.对数据库中增删改查操作 1.首先需要先见表,见表的方法我们在“http://www.cnblo ...
- Win2003+apache+PHP+SqlServer2008 配置
Win2003+apache+PHP+SqlServer2008 配置 安装前的准备: 1.Apache2.2.2 2.PHP5.2.17 3.SqlServer2008 4.sqlncli. ...
- golang语言基础(一)
0.项目的组织结构: GOPATH路径下是src文件夹---->src文件夹下是项目名称---->项目名称下是该项目的各个包名---->各包名下是.go文件(一个包下,无论有多少个. ...
- Python之Scrapy遇见个坑
运行Scrapy爬虫被限制抓取,报错: -- :: [scrapy.middleware] INFO: Enabled item pipelines: [] -- :: [scrapy.core.en ...
- python高性能编程方法一-乾颐堂
阅读 Zen of Python,在Python解析器中输入 import this. 一个犀利的Python新手可能会注意到"解析"一词, 认为Python不过是另一门脚本语言. ...
- linux / centos 安装SQL Server 2017 设置默认语言与排序规则Chinese_PRC_CI_AS
安装 安装很简单参照官方教程 https://docs.microsoft.com/zh-cn/sql/linux/quickstart-install-connect-red-hat?view=sq ...
- 【转】简说GNU, GCC and MinGW (Lu Hongling)
原地址:https://my.oschina.net/u/588967/blog/73478 GNU, GCC, MinGW是开源社区常常要遇到的概念. 网上一般的解释比较繁琐, 让人如坠云雾. 本文 ...
- [转]go中的main函数和init函数
Go里面有两个保留的函数:init函数(能够应用于所有的package)和main函数(只能应用于package main).这两个函数在定义时不能有任何的参数和返回值.虽然一个package里面可以 ...
- linux平台 spark standalone集群 使用 start-all,stop-all 管理集群的启动和退出
一.配置/etc/profile: 文件尾部增加以下内容: export SPARK_HOME=/home/spark/spark-2.2.0-bin-hadoop2.7 export PATH=$P ...
- HDU 6065 RXD, tree and sequence (LCA+DP)
题意:给定上一棵树和一个排列,然后问你把这个排列分成m个连续的部分,每个部分的大小的是两两相邻的LCA的最小深度,问你最小是多少. 析:首先这个肯定是DP,然后每个部分其实就是里面最小的那个LCA的深 ...