1 服务提供者Provider
pom.xml:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>io.dubbo.springboot</groupId>
<artifactId>spring-boot-starter-dubbo</artifactId>
<version>1.0.0</version>
</dependency>
application.properties:
server.port=8084
## Dubbo 服务提供者配置
spring.dubbo.application.name=provider
spring.dubbo.registry.address=zookeeper://127.0.0.1:2181
spring.dubbo.protocol.name=dubbo
spring.dubbo.protocol.port=20888
spring.dubbo.scan=com.chaozai.dubbo.service
服务接口定义:
package com.chaozai.dubbo.service;
/**
* hello服务
* @author chaozai
* @date 2019年3月6日
*
*/
public interface HelloDubboService {
public String sayHello(String client);
}
服务接口实现:
package com.chaozai.dubbo.service;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.alibaba.dubbo.config.annotation.Service;
import com.alibaba.dubbo.rpc.RpcContext;
/**
* Hello服务实现类
*
* @author chaozai
* @date 2019年3月6日
*
*/
@Service
public class HelloDubboServiceImpl implements HelloDubboService {
private static final Logger logger = LoggerFactory.getLogger(HelloDubboServiceImpl.class);
public String sayHello(String client) {
logger.info("Hello " + client + ", request from consumer: " + RpcContext.getContext().getRemoteAddress());
return "Hello " + client + ", response from provider: " + RpcContext.getContext().getLocalAddress();
}
}
服务启动类:
package com.chaozai.dubbo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
/**
* dubbo服务提供者
* @author chaozai
* @date 2019年3月6日
*
*/
@SpringBootApplication
public class SpringbootDubboProviderApplication {
public static void main(String[] args) {
SpringApplication.run(SpringbootDubboProviderApplication.class, args);
}
}
2 服务消费者
拷贝提供者的服务接口:
package com.chaozai.dubbo.service;
/**
* hello服务,和服务提供者保持一致,原则上是放在common中,然后引入
* @author chaozai
* @date 2019年3月6日
*
*/
public interface HelloDubboService {
public String sayHello(String client);
}
定义本地消费服务:
package com.chaozai.dubbo.service;
import org.springframework.stereotype.Component;
import com.alibaba.dubbo.config.annotation.Reference;
/**
* 测试服务消费
* @author chaozai
* @date 2019年3月6日
*
*/
@Component
public class HelloService {
@Reference
HelloDubboService helloDubboService;
public String testHello() {
return helloDubboService.sayHello("test");
}
}
消费者启动类:
package com.chaozai.dubbo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.chaozai.dubbo.service.HelloService;
/**
* Dubbo服务消费者
*
* @author chaozai
* @date 2019年3月6日
*
*/
@SpringBootApplication
@EnableScheduling
@RestController
public class SpringbootDubboConsumerApplication {
@Autowired
HelloService helloService;
@RequestMapping(value = "/")
public String hello() {
return helloService.testHello();
}
public static void main(String[] args) {
SpringApplication.run(SpringbootDubboConsumerApplication.class, args);
}
}
3 环境准备及运行
1、运行zookeeper
2、运行dubbo-admin(可选),参考:【dubbo】部署dubbo-admin,演示基础应用
3、验证服务运行
消费者访问:
生产者收获消息:
INFO service.HelloDubboServiceImpl: Hello test, request from consumer: /192.168.10.132:12631
dubbo-admin展示:
生产者:
消费者:
爱家人,爱生活,爱设计,爱编程,拥抱精彩人生!