学习日志---打造搜索引擎搜索提示

打包过程

创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于成都网站设计、成都做网站、临邑网络推广、成都微信小程序、临邑网络营销、临邑企业策划、临邑品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联公司为所有大学生创业者提供临邑建站搭建服务,24小时服务热线:18982081108,官方网址:www.cdcxhl.com

将网站程序打成war包,使用clean package;

将war包放到服务器的tomcat上的webapps中;

在conf的目录下更改server.xml文件:

加上如下编码,更改编码方式,防止乱码

URIEncoding="UTF-8"

logs目录下有tomcat的访问记录,如下:

[root@hadoop11 logs]# ls
catalina.2015-08-14.log  host-manager.2015-08-14.log  localhost_access_log.2015-08-14.txt
catalina.out             localhost.2015-08-14.log     manager.2015-08-14.log
localhost_access_log.2015-08-14.txt

这个是记录的访问,里面有输入的记录值,用于分析。

为了方便统计,要改server.xml里的,修改的是日志文件,如下:

 

prefix是前缀,suffix是后缀,fileDataFormat是频率


使用ajax触发异步请求,如下:

使用的是jquery的autocomplete的插件,会在后台向uri发送请求,服务器会返回一个json结构数据的信息到前台,在页面上展示。


    $(document).ready(function(){
        $("#query").autocomplete({
            source : function(request, response){
                $.ajax({
                    //这里是请求服务器的处理类
                    url : "http://hadoop11:8080/web/suggest.do",
                    //这里的dataType是response回来的数据结构 
                    dataType : "json",
                    //data是传送过去的数据
                    data : {
                        query : $("#query").val()
                    },
                    //响应成功的话就success
                    success : function(data){
                        //这里找的是action里的类,类里面的result属性,是一个set集合
                        //这里返回的是一个集合,以json的结构返回
                        //struts2里,加入到值栈的对象,会先对属性做get赋值,再执行要求的方法
                        response($.map(data.result, function(item){
                            return {value:item}
                        }));
                    }
                });
            },
            minLength:1,
        });
    });

public class SearchAction extends ActionSupport {
    String text;
    String query;

    Set result;
    
    public Set getResult() {
        //this.result = redisTool.zrevrange(query, 0, 5);
        result = new HashSet();
        result.add("aaa");
        result.add("子");
        return result;
    }
    。。。。。。
    。。。。。

这里的类对应上面的result。

需要的脚本

ui又依赖于:

在使用redis时,使用sort排列来插入索引;

hGetAll 键,这个是列出该键下的所有值。

通过query传过去一个值:由redis去查询后返回一个set集合。

public static Set zrevrange(String text, int i, int j) {
        // TODO Auto-generated method stub
        try{
            CreateJedisObj();
            //hadoop_users
            
            return jedis.zrevrange(text, 0, 5);
            
            }catch(Exception e){
                e.printStackTrace();
                jedis = null;
                return null;
            }
    }

redis的操作可以熟悉下。

在实际开发中,redis数据库的更新可以逐个更新,在reduce的过程中去删除redis原有的数据记录。


网站栏目:学习日志---打造搜索引擎搜索提示
新闻来源:http://scyanting.com/article/jisgec.html