e3mall Day07
来源:互联网 发布:php微信商城三级分销 编辑:程序博客网 时间:2024/06/05 15:14
搜索系统
??问题:搜索原理 分片和查询优化!!!
solr 基于lucence的服务器 war包???
lucence api??
topic01 solr安装:
step0:java开发的:需要jdk环境
step1:安装solr solr目录结构
bin/ 启动的容器是jetty 也可以tomcat
contrib/ 扩展包
dist/ 目标文件编译出来的目录 war sorj客户端jar
example/ solr solrhome有一些配置文件
step2:tomcat
mkdir /usr/local/solr
cp apache-tomcat-7.0.47 -r /usr/local/solr/tomcat
把solr的war(dist里)部署到tc里
启动tc war自动解压
step3:拷贝所需要jar example/lib/ext *
到tc的solr工程WEB-INF/lib
step4:cp -r example/solr /usr/local/solr/solrhome
step5:web.xml env-entry solrhome
step6:启动tc
step7:访问solr主页
分词器和域
有关solr“域”的概念:必须先定义后使用
需要哪些域?
id(下一步点击搜索出的某商品需要查查询)
title sellpoint image status
cat_name(联合两个表)
step1:IK分析器的jar 加入solr工程的lib
step2:dic(2个) 和 xml 加入solr的classes
step3:solrhome/collection1/conf/schema.xml
指定分词的分析器:fieldtype是TextField
<fieldType name="text_ik" class="solr.TextField"> <analyzer class="org.wltea.analyzer.lucene.IKAnalyzer"/></fieldType>
step4:定义业务域
每个文档都需要有个id域
复制域:copyField 把一些业务域复制加入“关键词”业务域 搜索的需要
<field name="item_title" type="text_ik" indexed="true" stored="true"/><field name="item_sell_point" type="text_ik" indexed="true" stored="true"/><field name="item_price" type="long" indexed="true" stored="true"/><field name="item_image" type="string" indexed="false" stored="true" /><field name="item_category_name" type="string" indexed="true" stored="true" /><field name="item_keywords" type="text_ik" indexed="true" stored="false" multiValued="true"/><copyField source="item_title" dest="item_keywords"/><copyField source="item_sell_point" dest="item_keywords"/><copyField source="item_category_name" dest="item_keywords"/>
step5: 保存 重启tc
step6:solr主页,点击“Analysis”
可选择FieldType 就可以做一些分词的实验
搜索服务工程的创建&导入商品数据到索引库
e3mall-search工程创建:参考content工程,该改的改 删除redis
和事务的配置
这次可别忘了web.xml
搜索:和dao没关系!!!?查询的是索引库,但是初始导入需要从数
据库导入
导入商品数据到索引库
step1:编写联合查询sql:
SELECT
a.id,
a.title,
a.sell_point,
a.price,
a.image,
b.name
category_name
FROM
tb_item
a
LEFT JOIN tb_item_cat b ON a.cid = b.id
WHERE a.status
=1
step02:
搜索定制的pojo,别的层也可能用到,放common:SearchItem
public class SearchItem implements Serializable{
private String id;
private String title;
private String sell_point;
private long price;
private String image;
private String category_name;
}
getters/setters 不能落下
step03:
search-service中编写ItemMapper
List getItemList();
编写同名xml
step04:service层
难点:写入数据到索引库,通过客户端solrj
4.1 把solrj的依赖加入service
4.2 测试solrj addDocument()
创建服务器,创建文档,向文档添加域,把文档写入索引库,提交
deleteDocument()两种方式
4.3 interface:E3Result importAllItems();
4.4 service:实现
注意:自己的Mapper要让ac-dao.xml扫描到
注入solorServer(spring容器,单例)
完成异常处理,返回E3Result.build(error_code.”msg”);
**万能对象E3Result
!!【非常重要】异常处理的利器,异常消化在service层
4.5表现层 manager-web
引入search-interface接口
引入服务
controller:”/index/item/import”
【异常处理】:BindingException:
接口和文件不在一个目录下:找不到xml,它们作为resources默认在
resources源下搜寻,却出现在java源里,应该在pom里配置资源映射:
*后台删除节点:用xml
搜索工程搭建search-web:参考portal-web
搜索功能
默认搜索域:text solrconfig.xml(solrhome下某子目录)
requestHandler select
df 默认搜索域
API小计:
query可以创建,可以各种set
server.query方法 得到qr
QueryResponse.getxxx 取文档列表 高亮显示结果等等
取高亮结果时候注意:防御性编程(搜索域和高亮显示域不一致时候)
,复杂的map结果结构
商品搜索功能编码部分
dao层:
pojo (commons)
pojo SearchResult(别忘序列化)
private long recordCount
private int totalPages;
privaet List itemList;
getters/setters
dao:(search-service)
@Repository
SearchDao public SearchResult search(SolrQuery query)
抛异常
取总数,取商品列表,取高亮
interface:SearchResult search(String keyword, int page, int
rows); 抛异常给表现层!
service:
表现层:/search
keyword page设置默认值 model
get请求出现乱码 表现层手动转码
- e3mall Day07
- day07
- day07
- day07
- day07
- day07
- day07
- day07
- day07
- day07
- day07
- day07
- Day07
- day07
- day07
- day07
- e3mall Day01
- e3mall Day03
- Java常用算法之归并排序
- 第三周项目2—建设“顺序表”算法库
- pytorch学习笔记(十一):fine-tune 预训练的模型
- Android初学者入门—————XlistView与下拉刷新,上拉加载
- 浅谈架构---前后端分离和未来发展之路。
- e3mall Day07
- 深入理解 js this 绑定 (尾部有总结和面试题解析 )
- App适配iOS 11
- HttpURLConnection之多线程下载
- java ThreadLocal(应用场景及使用方式及原理)
- UVAlive 3490 AC自动机+(整数)高斯消元
- 应聘嵌入式工程师笔试常考之宏定义的优缺点
- ios 两句话解决,从无导航栏push到有导航栏界面,顶部闪现空白问题
- ios实现UITableView左滑删除-复制即用