springboot+dubbo+zookeeper+mybatis

注:实体类和JSP页面省略

服务提供方相关代码如下:
pan-service的 POM文件
<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">

<artifactId>pan-service</artifactId>
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>cn.com.pan</groupId>
<artifactId>pan</artifactId>
<version>0.0.1-SNAPSHOT</version>
</parent>

<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
</properties>

<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>1.5.10.RELEASE</version>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.1</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>6.0.6</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.6</version>
</dependency>
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.4.11</version>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
<exclusion>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>dubbo</artifactId>
<version>2.5.8</version>
<exclusions>
<exclusion>
<groupId>org.springframework</groupId>
<artifactId>spring</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>com.101tec</groupId>
<artifactId>zkclient</artifactId>
<version>0.10</version>
</dependency>
<dependency>
<groupId>cn.com.pan</groupId>
<artifactId>pan-po</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
</dependencies>

<build>
<finalName>pan-service</finalName>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.7</source>
<target>1.7</target>
</configuration>
</plugin>
</plugins>
</build>
</project>


PushManageMapper类
package cn.com.pan.mapper;

import java.util.List;
import java.util.Map;
import org.apache.ibatis.annotations.Mapper;
import cn.com.po.push.PushManageTaskInfo;

@Mapper
public interface PushManageMapper {
public List<PushManageTaskInfo> queryPushManageList(Map<String,Object> reqMap);
}


PushManageService类
package cn.com.pan.service;

import java.util.List;
import java.util.Map;
import cn.com.po.push.PushManageTaskInfo;


public interface PushManageService {
public List<PushManageTaskInfo> queryPushManageTaskList(Map<String,Object> requestMap);
}




PushManageServiceImpl实现类
package cn.com.pan.service.impl.push;

import java.util.List;
import java.util.Map;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import cn.com.pan.mapper.PushManageMapper;
import cn.com.pan.service.PushManageService;
import cn.com.po.push.PushManageTaskInfo;

@Service("pushManageService")
public class PushManageServiceImpl  implements PushManageService{

@Autowired
private PushManageMapper pushManageMapper;

@Override
public List<PushManageTaskInfo> queryPushManageTaskList(
Map<String, Object> requestMap) {
return pushManageMapper.queryPushManageList(requestMap);
}
}



pushManageMapper.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="cn.com.pan.mapper.PushManageMapper">

<resultMap id="pushListResultMap" type="cn.com.po.push.PushManageTaskInfo">
<result column="task_id" property="taskId" jdbcType="VARCHAR" />
<result column="push_type" property="pushType" jdbcType="CHAR" />
<result column="state" property="state" jdbcType="CHAR" />
<result column="product" property="product" jdbcType="VARCHAR" />
<result column="send_total" property="sendTotal" jdbcType="VARCHAR" />
<result column="arrival_total" property="arrivalTotal" jdbcType="VARCHAR" />
<result column="click_total" property="clickTotal" jdbcType="VARCHAR" />
<result column="platform" property="platform" jdbcType="VARCHAR" />
</resultMap>

<select id="queryPushManageList" resultMap="pushListResultMap">
SELECT task_id,
push_type,
state,
product,
send_total,
arrival_total,
click_total,
platform
FROM wifi_push_manage_task
ORDER BY CREATED_DATE DESC
LIMIT #{page},#{pageSize}
</select>
</mapper>


application.properties属性文件
server.port=8002

spring.datasource.url=jdbc:mysql://localhost:3306/pwams?useUnicode=true&characterEncoding=utf-8
spring.datasource.username=
spring.datasource.password=
spring.datasource.driverClassName=com.mysql.cj.jdbc.Driver
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource

zookeeper.registry.center=127.0.0.1:2181
dubbo.port=20880

mybatis.mapperLocations=classpath:mapper/*.xml


dubbo-provider.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="pan-service"/>
     
       <dubbo:registry protocol="zookeeper" address="${zookeeper.registry.center}" />
      
       <dubbo:protocol name="dubbo" port="${dubbo.port}" />
      
       <dubbo:service  ref="pushManageService" interface="cn.com.pan.service.PushManageService" timeout="10000" />
       <dubbo:service  ref="pushMessageService"  interface="cn.com.pan.service.PushMessageService" timeout="10000" />
       <dubbo:annotation/>
       </beans>


ApplicationService类——服务提供方启动类
package cn.com.pan;

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.ImportResource;


@SpringBootApplication
@ImportResource(locations={"config/dubbo-provider.xml"})
@MapperScan(basePackages={"cn.com.pan.mapper"})
public class ApplicationService {

public static void main(String[] args) {
SpringApplication.run(ApplicationService.class, args);
System.out.println("======ApplicationService start success======");
}
}



服务消费方相关代码
pan-web的POM文件
<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>
<parent>
<groupId>cn.com.pan</groupId>
<artifactId>pan</artifactId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<artifactId>pan-web</artifactId>
<packaging>war</packaging>

<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
</properties>

<dependencies>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
<version>8.5.27</version>
</dependency>
<dependency>
<groupId>cn.com.pan</groupId>
<artifactId>pan-service</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>cn.com.pan</groupId>
<artifactId>pan-po</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
</dependencies>

<build>
<finalName>pan-web</finalName>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.7</source>
<target>1.7</target>
</configuration>
</plugin>
</plugins>
</build>
</project>


PushManageController类
package cn.com.web.controller;

import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;
import cn.com.pan.service.PushManageService;
import cn.com.po.push.PushManageTaskInfo;

@Controller
@RequestMapping("/pushManage")
public class PushManageController {

@Autowired
private PushManageService pushManageService;


@RequestMapping(value="/pushManageList")
public ModelAndView pushManage()
{
Map<String,Object> paraMap = new HashMap<String,Object>();
paraMap.put("page", 0);
paraMap.put("pageSize", 20);
List<PushManageTaskInfo> pushList = pushManageService.queryPushManageTaskList(paraMap);
ModelAndView views = new ModelAndView("/pushManageList");
views.addObject("pushManageList",pushList);
return views;
}
}


服务消费方的application.properties属性文件配置
server.port=8001

spring.mvc.view.prefix=/WEB-INF/jsp/
spring.mvc.view.suffix=.jsp

zookeeper.registry.center=127.0.0.1:2181


dubbo-consumer.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="pan-web"/>
     
       <dubbo:registry protocol="zookeeper" address="${zookeeper.registry.center}" />
      
       <dubbo:reference id="pushManageService" interface="cn.com.pan.service.PushManageService"/>
       <dubbo:reference id="pushMessageService"  interface="cn.com.pan.service.PushMessageService"/>
       </beans>



ApplicationWeb服务消费方启动类
package cn.com.web;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
import org.springframework.context.annotation.ImportResource;


@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
@ImportResource(locations="config/dubbo-consumer.xml")
public class ApplicationWeb {

public static void main(String[] args) {
SpringApplication application = new SpringApplication(ApplicationWeb.class);
application.run(args);
System.out.println("======ApplicationWeb start success======");
}
}

猜你喜欢

转载自kuailenanhaier.iteye.com/blog/2410573