前言: 搭建属于Springboot 整合Dubbo、Zookeeper、Mybatis,最终的结果 不能直接使用数据库,存在问题,后面还要根据情况继续修改。
环境的搭建:
主架构:
接下啦是父工程的引进的包
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.zhl</groupId>
<artifactId>dubbozookeeper</artifactId>
<packaging>pom</packaging>
<version>1.0-SNAPSHOT</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.4.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<modules>
<!-- 公共接口,主要存放接口、实体 -->
<module>dubbo-api</module>
<!-- 服务提供者 -->
<module>dubbo-provider</module>
<!-- 服务消费者 -->
<module>dubbo-consumer</module>
<module>dubbo-api</module>
<module>dubbo-privoder</module>
<module>dubbo-consumer</module>
</modules>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<dubbo.version>2.5.5</dubbo.version>
<zkClient.version>0.10</zkClient.version>
<lombok.version>1.16.18</lombok.version>
<springBoot.version>1.5.7</springBoot.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
<!--<version>${springBoot.version}</version>-->
</dependency>
<!-- web应用 springmvc -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>-->
<!-- 使用lombok实现JavaBean的get、set、toString、hashCode、equals等方法的自动生成 -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>${lombok.version}</version>
<scope>provided</scope>
</dependency>
<!-- Dubbo依赖 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>dubbo</artifactId>
<version>${dubbo.version}</version>
<exclusions>
<exclusion>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
</exclusion>
</exclusions>
</dependency>
<!--zookeeper的客户端依赖-->
<dependency>
<groupId>com.101tec</groupId>
<artifactId>zkclient</artifactId>
<version>${zkClient.version}</version>
</dependency>
<!-- 热加载 -->
<!-- <dependency>-->
<!-- <groupId>org.springframework.boot</groupId>-->
<!-- <artifactId>spring-boot-devtools</artifactId>-->
<!-- <scope>runtime</scope>-->
<!-- <optional>true</optional>-->
<!-- </dependency>-->
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>${java.version}</source>
<target>${java.version}</target>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-resources-plugin</artifactId>
<configuration>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<fork>true</fork>
<addResources>true</addResources>
</configuration>
</plugin>
</plugins>
</build>
</project>
dubbo-api公共接口架构
dubbo-api引进的jar包
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>dubbozookeeper</artifactId>
<groupId>com.zhl</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>dubbo-api</artifactId>
<!-- <parent>-->
<!-- <groupId>org.springframework.boot</groupId>-->
<!-- <artifactId>spring-boot-starter-parent</artifactId>-->
<!-- <version>2.0.4.RELEASE</version>-->
<!-- <relativePath/>-->
<!-- </parent>-->
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
实体类User.java
package com.zhl.common.entity;
import java.io.Serializable;
/**
* @author
* @description 用户实体
* @date
*/
public class User implements Serializable {
private static final long serialVersionUID = -1688765204850364609L;
private Integer id;
private String userName;
private String passWord;
private String roleList;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getPassWord() {
return passWord;
}
public void setPassWord(String passWord) {
this.passWord = passWord;
}
public String getRoleList() {
return roleList;
}
public void setRoleList(String roleList) {
this.roleList = roleList;
}
}
接口UserService.java
package com.zhl.common.service;
import com.zhl.common.entity.User;
import java.util.List;
public interface UserService {
List<User> getAllUser();
}
服务提供者privoder
架构
UserMapper.java
package com.zhl.privoder.mapper;
import com.zhl.common.entity.User;
import java.util.List;
public interface UserMapper {
List<User> getAllUser();
}
接口实现UserServiceImpl.java
package com.zhl.privoder.service.impl;
import com.alibaba.dubbo.config.annotation.Service;
import com.zhl.common.entity.User;
import com.zhl.common.service.UserService;
import com.zhl.privoder.mapper.UserMapper;
import javax.annotation.Resource;
import java.util.ArrayList;
import java.util.List;
/**
* @author
* @description
* @date
*/
@Service(version = "1.0.0",timeout = 10000)
public class UserServiceImpl implements UserService {
@Resource
private UserMapper userMapper;
public List<User> getAllUser() {
List<User> list = new ArrayList<>();
User user = new User();
user.setId(1);
user.setUserName("23");
user.setPassWord("fdsf");
list.add(user);
// List<User> userList = userMapper.getAllUser();
return list;
}
}
启动类
package com.zhl.privoder;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.ImportResource;
import java.io.IOException;
/**
* @author
* @description 启动类
* @date
*/
@SpringBootApplication
@ImportResource("classpath:spring-dubbo.xml")
@MapperScan("com.zhl.privoder.mapper")
public class DubboProviderApplication {
public static void main(String[] args){
SpringApplication.run(DubboProviderApplication.class,args);
System.out.println("服务端启动成功!!!!!!!!!!!!!!");
try {
System.in.read();
} catch (IOException e) {
e.printStackTrace();
}
}
}
UserMapper.xml(提示现在用出错)
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.zhl.privoder.mapper.UserMapper">
<resultMap id="UserBaseResultMap" type="com.zhl.common.entity.User">
<id column="id" property="id" jdbcType="INTEGER"/>
<result column="userName" property="userName" jdbcType="VARCHAR"/>
<result column="passWord" property="passWord" jdbcType="VARCHAR"/>
<result column="roleList" property="roleList" jdbcType="VARCHAR"/>
</resultMap>
<!-- <sql id="Base_Column_List">-->
<!-- id, userName, passWord-->
<!-- </sql>-->
<select id="getAllUser" resultMap="UserBaseResultMap">
select *
from user
</select>
</mapper>
application.yml
server:
port: 8082
servlet:
context-path: /
spring:
datasource:
name: test
url: jdbc:mysql://127.0.0.1:3306/springdb
username: root
password: 123456
# 使用druid数据源
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.jdbc.Driver
filters: stat
maxActive: 20
initialSize: 1
maxWait: 60000
minIdle: 1
timeBetweenEvictionRunsMillis: 60000
minEvictableIdleTimeMillis: 300000
testWhileIdle: true
testOnBorrow: false
testOnReturn: false
poolPreparedStatements: true
maxOpenPreparedStatements: 20
#Mybatis配置
mybatis:
typeAliasesPackage: com.zhl.common.entity
mapperLocations: classpath:mapper/*.xml
#打印Mybatis的sql语句
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
spring-dubbo.xml配置
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://code.alibabatech.com/schema/dubbo
http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
<dubbo:application name="dubbo-provider"/>
<!-- 注册中心的ip地址 -->
<dubbo:registry address="zookeeper://192.168.1.84:2181"/>
<!-- 扫描注解包路径,多个包用逗号分隔,不填pacakge表示扫描当前ApplicationContext中所有的类 -->
<dubbo:annotation package="com.zhl.privoder.service.impl"/>
<dubbo:protocol name="dubbo" port="20880" />
<bean id="userService" class="com.zhl.privoder.service.impl.UserServiceImpl" />
<dubbo:service interface="com.zhl.common.service.UserService" ref="userService" />
</beans>
consumer消费者 使用接口
架构
UserController.java
package com.zhl.consumer.controller;
import com.alibaba.dubbo.config.annotation.Reference;
import com.zhl.common.entity.User;
import com.zhl.common.service.UserService;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource;
import java.util.List;
/**
* @author
* @description
* @date
*/
@RestController
public class UserController {
@Resource
@Reference(version = "1.0.0" )
UserService userService;
@RequestMapping("/getAllUser")
public List<User> getAllUser(){
System.out.println("进来了!!!!!!!!!");
List<User> list = userService.getAllUser();
return list;
}
}
启动类
package com.zhl.consumer;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.ComponentScans;
import org.springframework.context.annotation.ImportResource;
/**
* @author
* @description 消费者启动类
* @date
*/
@SpringBootApplication
//@ComponentScan(basePackages = {"com.zhl.consumer"})
@ImportResource("classpath:spring-dubbo.xml")
public class DubboConsumerApplication {
public static void main(String[] args){
System.setProperty("spring.devtools.restart.enabled", "false");
SpringApplication.run(DubboConsumerApplication.class,args);
System.out.println("消费端启动成功!!!!");
}
}
spring-dubbo.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://code.alibabatech.com/schema/dubbo
http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
<dubbo:application name="dubbo-consumer"/>
<dubbo:registry address="zookeeper://192.168.1.84:2181"/>
<dubbo:protocol name="dubbo" port="20880"/>
<dubbo:reference id="userService" check="false" interface="com.zhl.common.service.UserService"/>
<dubbo:annotation package="com.zhl.consumer"/>
</beans>
数据库User
CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',
`userName` varchar(255) DEFAULT NULL COMMENT '用户名',
`passWord` varchar(255) DEFAULT NULL COMMENT '密码',
`roleList` varchar(255) DEFAULT NULL COMMENT '角色',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;
先启动dubbo-provider,然后启动dubbo-consumer,使用数据库有问题,还在解决。
出现的问题:
1.SpringBoot之class is not visible from class loader(https://www.jianshu.com/p/3bdaafd0993f)
2.dubbo调用Failed to invoke remote method异常解决
参考(https://blog.csdn.net/weixin_33910137/article/details/93799273)