学习淘淘商城第三十八课(搜索服务搭建)

来源:互联网 发布:mac怎么改用户头像 编辑:程序博客网 时间:2024/05/24 04:17

       首先,我们还是要先看下淘淘商城的整体架构图,如下图所示,我们已经写完了后台管理系统、商品服务、商城门户、内容服务,现在需要搭建的是搜索系统和搜索服务。


       下面我们便来搭建搜索服务工程

第一步:点击File------->New------->Maven Project,会看到如下图所示对话框,勾选最上面那个复选框,然后点击"Next",如下图所示。


第二步:在弹出的对话框中输如下图所示内容,taotao-search是个聚合工程,需要聚合interface、service、dao、pojo四个模块。点击"Finish"。


第三步:参考taotao-content聚合工程,把它的pom.xml文件中的依赖拷过来,只是需要修改下tomcat插件的端口号,修改为8084(前面已经用到8083了)


<dependencies>  <dependency>  <groupId>com.taotao</groupId>    <artifactId>taotao-common</artifactId>    <version>0.0.1-SNAPSHOT</version>  </dependency>  </dependencies>  <build>  <plugins>  <plugin>  <groupId>org.apache.tomcat.maven</groupId>  <artifactId>tomcat7-maven-plugin</artifactId>  <configuration>  <path>/</path>  <port>8084</port>  </configuration>  </plugin>  </plugins>  </build>

第四步:新建maven模块,在taotao-search工程上右键------->New---------->Other...如下图所示。


       在弹出的对话框中选择"Maven Module",然后点击"Next"。


        在下面的对话框中勾选上最上面的复选框,然后在"Module Name"一栏输入"taotao-search-interface",然后点击"Finish"。这样第一个模块taotao-search-interface便创建好了。


     我们还需要创建一个模块,即taotao-search-service,这个工程与上面那个taotao-search-interface工程有一点不同的地方,我们走到如下图这步时不要点击"Finish",而是点击"Next"。


       打包方式选择"war"然后点击"Finish"。


第五步:配置taotao-search-interface工程的pom.xml文件,我们参考taotao-content-interface工程的pom.xml文件,由于我们的搜索服务也可能用到pojo,因此这个依赖加上。


  <dependencies>  <dependency>  <groupId>com.taotao</groupId>    <artifactId>taotao-manager-pojo</artifactId>    <version>0.0.1-SNAPSHOT</version>  </dependency>  </dependencies>
第六步:配置taotao-search-service工程的pom.xml文件,我们可以参考taotao-content-service工程的依赖。由于搜索服务要用到数据库,因此需要有taotao-manager-dao,把依赖的interface改为我们的taotao-search-interface。由于solr本身提供了缓存,因此把缓存的依赖去掉了,taotao-search-service所需要依赖的内容如下所示。

<dependencies>  <dependency>  <groupId>com.taotao</groupId>    <artifactId>taotao-manager-dao</artifactId>    <version>0.0.1-SNAPSHOT</version>  </dependency>  <dependency>  <groupId>com.taotao</groupId>    <artifactId>taotao-search-interface</artifactId>    <version>0.0.1-SNAPSHOT</version>  </dependency>  <!-- Spring --><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-beans</artifactId></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</artifactId></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-jdbc</artifactId></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-aspects</artifactId></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-jms</artifactId></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-context-support</artifactId></dependency><!-- dubbo相关的jar包 --><dependency><groupId>com.alibaba</groupId><artifactId>dubbo</artifactId><exclusions><exclusion><artifactId>spring</artifactId><groupId>org.springframework</groupId></exclusion><exclusion><artifactId>netty</artifactId><groupId>org.jboss.netty</groupId></exclusion></exclusions></dependency><dependency><groupId>org.apache.zookeeper</groupId><artifactId>zookeeper</artifactId></dependency><dependency><groupId>com.github.sgroschupf</groupId><artifactId>zkclient</artifactId></dependency>  </dependencies>

第七步:taotao-search-service工程整合,我们把taotao-content-service工程的src/main/resources目录下的三个文件夹拷贝到taotao-search-service工程的相同目录下。

       首先看第一个文件夹mybatis下面的SqlMapConfig.xml,该文件中配置的是关于分页的配置,如果数据量特别大的时候,我们可能也需要用到分页,因此这段配置我们保留。


<!-- 配置分页插件 --><plugins><plugin interceptor="com.github.pagehelper.PageHelper"><property name="dialect" value="mysql"/></plugin></plugins>

       接着,我们到第二个目录properties下来看看配置是否需要改动,其中db.properties文件中是数据库的相关配置,由于搜索服务的信息是要从数据库中导进来的,因此肯定需要用到数据库连接的,因此这段配置保留。


jdbc.driver=com.mysql.jdbc.Driverjdbc.url=jdbc:mysql://localhost:3306/taotao?characterEncoding=utf-8jdbc.username=rootjdbc.password=root

        接着我们看resource.properties文件,这个文件经常用于定义某些常量,用于业务操作。由于目前我们还没有写任何业务代码,因此先把这个配置文件空着。


       接着我们再看下spring目录下的文件,首先看applicationContext-dao.xml文件,这个配置文件用来操作数据库,我们不用做任何改动。


<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"xmlns:context="http://www.springframework.org/schema/context" xmlns:p="http://www.springframework.org/schema/p"xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.2.xsdhttp://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.2.xsdhttp://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.2.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.2.xsdhttp://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.2.xsd"><!-- 配置数据库连接池 --><!-- 加载配置文件 --><context:property-placeholder location="classpath:properties/*.properties" /><!-- 数据库连接池 --><bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"destroy-method="close"><property name="url" value="${jdbc.url}" /><property name="username" value="${jdbc.username}" /><property name="password" value="${jdbc.password}" /><property name="driverClassName" value="${jdbc.driver}" /><property name="maxActive" value="10" /><property name="minIdle" value="5" /></bean><!-- SqlSessionFactory --><!-- 让spring管理sqlsessionfactory 使用mybatis和spring整合包中的 --><bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"><!-- 数据库连接池 --><property name="dataSource" ref="dataSource" /><!-- 加载mybatis的全局配置文件 --><property name="configLocation" value="classpath:mybatis/SqlMapConfig.xml" /></bean><!-- Mapper映射文件的包扫描器 --><bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"><property name="basePackage" value="com.taotao.mapper" /></bean></beans>

      下面我们来看下spring目录下的第二个文件,applicationContext-jedis.xml,由于我们的solr本身就带有缓存,不需要用到redis,因此这个文件我们用不着,删掉即可。

      下面我们来看下spring目录下的第三个文件,applicationContext-service.xml,我们把包扫描器扫描的包修改为"com.taotao.search.service",将对外发布的dubbo服务的端口改为"20882",由于还没写服务接口,我们先把拷过来的暴露的服务接口注释掉(留个模板)。提供方应用信息名称改为"taotao-search"。


<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"xmlns:context="http://www.springframework.org/schema/context"xmlns:p="http://www.springframework.org/schema/p"xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.2.xsdhttp://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.2.xsdhttp://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.2.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.2.xsdhttp://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsdhttp://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.2.xsd">        <!-- 配置包扫描器,扫描所有带@Service注解的类 --><context:component-scan base-package="com.taotao.search.service"/><!-- 发布dubbo服务 --><!-- 提供方应用信息,用于计算依赖关系 --><dubbo:application name="taotao-search" /><!-- 注册中心的地址 --><dubbo:registry protocol="zookeeper" address="192.168.156.14:2181" /><!-- 用dubbo协议在20882端口暴露服务 --><dubbo:protocol name="dubbo" port="20882" /><!-- 声明需要暴露的服务接口 --><!-- <dubbo:service interface="com.taotao.content.service.ContentCategoryService" ref="contentCategoryServiceImpl" timeout="300000"/> --></beans>
    

       由于上面配置的要扫描的包还没有创建,因此我们在taotao-search-interface工程新建"com.taotao.search.service"包,在taotao-search-service工程新建"com.taotao.search.service.impl"包。如下图所示。
     

    我们再看下一个配置文件applicationContext-trans.xml,这个配置文件是用来配置事务的,由于搜索服务只是查数据库,不涉及到改数据库,因此我们用不到事务,我们把这个配置文件删除即可。

    下面我们需要在taotao-search-service工程下新建WEB-INF目录并从taotao-content-service工程拷贝一份web.xml文件到本工程下,将<display-name>的名字改为taotao-search,如下图所示。


<?xml version="1.0" encoding="UTF-8"?><web-app version="2.5"  id="WebApp_ID" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> <display-name>taotao-search</display-name> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list>  <!-- 初始化spring容器 --><context-param><param-name>contextConfigLocation</param-name><param-value>classpath:spring/applicationContext-*.xml</param-value></context-param><listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class></listener> </web-app>

     这样,我们的搜索服务工程便搭建完了。


0 0