Docker方法运用(十一)-搜索引擎elasticsearch

各种搜索引擎:whoosh,Solr, Sphinx, Xapian。。

引擎的比较:https://blog.csdn.net/Akira_Rexlee/article/details/85163898

elasticsearch 官网地址: https://docs.docker.com/install/linux/docker-ce/ubuntu/

0. 卸载旧版本

sudo apt-get remove docker docker-engine docker.io containerd runc

1. 更新apt:

sudo apt-get update

2. 添加证书安装包以允许apt通过HTTPS:

sudo apt-get install \

    apt-transport-https \

    ca-certificates \

    curl \

    gnupg-agent \

    software-properties-common

sudo apt-get install apt-transport-https ca-certificates curl gnupg-agent software-properties-common

3. 添加Docker的官方GPG密钥:

curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -

4. 添加仓库。

sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) \stable"

5. 安装docker ce

sudo apt-get install docker-ce docker-ce-cli containerd.io

6. 测试

sudo docker run hello-world

7. 添加当前用户到 docker 用户组

sudo usermod -aG docker  pyvip

8.docker --version查看版本  docker images查看运行的容器

docker stop tbd8关闭容器  tbd8

/####################################/

# 拉取镜像到本地仓库使用docker安装elasticsearch  搜索引擎

#  docker image pull delron/elasticsearch-ik:2.4.6-1.0  很慢!!

xshell中用rz命令导入下载好的这个文件压缩包

然后导入镜像: docker load -i elasticsearch-ik-2.4.6_docker.tar


然后rz导入elasticsearch.zip文件接着操作unzip elasticsearch.zip解压文件等

里面的配置文件  端口已改为8002,原来9002??

创建docker容器并运行

# 根据拉取到本地的镜像创建容器,需要将/home/bd/elasticsearch/config配置文件所在目录修改为你自己的路径

docker run -dti --network=host --name=elasticsearch -v /home/pyvip/elasticsearch/config:/usr/share/elasticsearch/config delron/elasticsearch-ik:2.4.6-1.0

下面容器写了up才是启动状态的

# 运行如下命令,如果有显示则elasticsearch配置成功curl 127.0.0.1:8002


d.进入项目虚拟环境中,安装相关包

```linux

# 进入项目虚拟环境

workon taka

pip install django-haystack      安装前更新下pip    pip install --upgrade pip

pip install elasticsearch==2.4.1   就这个版本  比较稳定!!

接着在settings.py文件中加入如下配置:

```python

INSTALLED_APPS = [

    'haystack',

]

ELASTICSEARCH_DSL = {

    'default': {

        'hosts': '127.0.0.1:8002'

    },

}

# Haystack

HAYSTACK_CONNECTIONS = {

    'default': {

        'ENGINE': 'haystack.backends.elasticsearch_backend.ElasticsearchSearchEngine',

        'URL': 'http://127.0.0.1:8002/',  # 此处为elasticsearch运行的服务器ip地址,端口号默认为9200

        'INDEX_NAME': 'dj_pre_class',  # 指定elasticsearch建立的索引库的名称

    },

}

# 设置每页显示的数据量

HAYSTACK_SEARCH_RESULTS_PER_PAGE = 5

# 当数据库改变时,会自动更新索引

HAYSTACK_SIGNAL_PROCESSOR = 'haystack.signals.RealtimeSignalProcessor'

然后是后端的配置使用

```python

# 在apps/news/search_indexes.py中创建如下类:(名称固定为search_indexes.py)

from haystack import indexes

# from haystack import site

from .models import News

class NewsIndex(indexes.SearchIndex, indexes.Indexable):#NewsIndex名字固定!!

    """

    News索引数据模型类

    """

    text = indexes.CharField(document=True, use_template=True)

    id = indexes.IntegerField(model_attr='id')

    title = indexes.CharField(model_attr='title')

    digest = indexes.CharField(model_attr='digest')

    content = indexes.CharField(model_attr='content')

    image_url = indexes.CharField(model_attr='image_url')

    # comments = indexes.IntegerField(model_attr='comments')

    def get_model(self):

        """返回建立索引的模型类

        """

        return News

    def index_queryset(self, using=None):

        """返回要建立索引的数据查询集

        """

        return self.get_model().objects.filter(is_delete=False, tag_id=1)

```

```python   app news中views里加的

from haystack.views import SearchView as _SearchView

class SearchView(_SearchView):

    # 模版文件

    template = 'news/search.html'

    # 重写响应方式,如果请求参数q为空,返回模型News的热门新闻数据,否则根据参数q搜索相关数据

    def create_response(self):

        kw = self.request.GET.get('q', '')

        if not kw:

            show_all = True

            hot_news = models.HotNews.objects.select_related('news'). \

                only('news__title', 'news__image_url', 'news__id'). \

                filter(is_delete=False).order_by('priority', '-news__clicks')

            paginator = Paginator(hot_news, settings.HAYSTACK_SEARCH_RESULTS_PER_PAGE)

            try:

                page = paginator.page(int(self.request.GET.get('page', 1)))

            except PageNotAnInteger:

                # 如果参数page的数据类型不是整型,则返回第一页数据

                page = paginator.page(1)

            except EmptyPage:

                # 用户访问的页数大于实际页数,则返回最后一页的数据

                page = paginator.page(paginator.num_pages)

            return render(self.request, self.template, locals())

        else:

            show_all = False

            qs = super(SearchView, self).create_response()

            return qs

```

```python

# 创建templates/search/indexes/news/news_text.txt文件(文件名为:app名/模型类小写名_text.txt)

这三段为文件的内容:

{{ object.title }}

{{ object.digest }}

{{ object.content }}

```

```python

# 在apps/news/urls.py中

urlpatterns = [

    path('search/', views.SearchView(), name='search'),

]

```

```linux

# 在虚拟机中执行如下命令,生成索引

python manage.py rebuild_index

```

####.前端功能实现

```html

<!-- 在templates/news1/search.html中加入如下代码: -->

<div class="main-contain ">

        <!-- search-box start -->

        <div class="search-box">

            <form action="" style="display: inline-flex;">

                <input type="search" placeholder="请输入要搜索的内容" name="q" class="search-control">

                <input type="submit" value="搜索" class="search-btn">

            </form>

            <!-- 可以用浮动 垂直对齐 以及 flex  -->

        </div>

        <!-- search-box end -->

        <!-- content start -->

        <div class="content">

            <!-- search-list start -->

            {% if not show_all %}

                <div class="search-result-list">

                    <h2 class="search-result-title">

                        搜索结果 <span style="font-weight: 700;color: #ff6620;">{{ paginator.num_pages }}</span>页

                    </h2>

                    <ul class="news-list">

                        {# 导入自带高亮功能 #}

                        {% load highlight %}

                        {% for one_news in page.object_list %}

                            <li class="news-item clearfix">

                                <a href="{% url 'news:news_detail' one_news.id %}" class="news-thumbnail"

                                  target="_blank">

                                    <img src="{{ one_news.object.image_url }}">

                                </a>

                                <div class="news-content">

                                    <h4 class="news-title">

                                        <a href="{% url 'news:news_detail' one_news.id %}">

                                            {% highlight one_news.title with query %}

                                        </a>

                                    </h4>

                                    <p class="news-details">{% highlight one_news.digest with query %}</p>

                                    <div class="news-other">

                                        <span class="news-type">{{ one_news.object.tag.name }}</span>

                                        <span class="news-time">{{ one_news.object.update_time }}</span>

                                        <span

                                                class="news-author">{% highlight one_news.object.author.username with query %}

                                      </span>

                                    </div>

                                </div>

                            </li>

                        {% endfor %}

                    </ul>

                </div>

            {% else %}

                <div class="news-contain">

                    <div class="hot-recommend-list">

                        <h2 class="hot-recommend-title">热门推荐</h2>

                        <ul class="news-list">

                            {% for one_hotnews in page.object_list %}

                                <li class="news-item clearfix">

                                    <a href="#" class="news-thumbnail">

                                        <img src="{{ one_hotnews.news.image_url }}">

                                    </a>

                                    <div class="news-content">

                                        <h4 class="news-title">

                                            <a href="{% url 'news:news_detail' one_hotnews.news.id %}">{{ one_hotnews.news.title }}</a>

                                        </h4>

                                        <p class="news-details">{{ one_hotnews.news.digest }}</p>

                                        <div class="news-other">

                                            <span class="news-type">{{ one_hotnews.news.tag.name }}</span>

                                            <span class="news-time">{{ one_hotnews.update_time }}</span>

                                            <span class="news-author">{{ one_hotnews.news.author.username }}</span>

                                        </div>

                                    </div>

                                </li>

                            {% endfor %}

                        </ul>

                    </div>

                </div>

            {% endif %}

            <!-- search-list end -->

            <!-- news-contain start -->

            {# 分页导航 #}

            <div class="page-box" id="pages">

                <div class="pagebar" id="pageBar">

                    <a class="a1">{{ page.paginator.count }}条</a>

                    {# 上一页的URL地址 #}

                    {% if page.has_previous %}

                        {% if query %}

                            <a href="{% url 'news:search' %}?q={{ query }}&amp;page={{ page.previous_page_number }}"

                              class="prev">上一页</a>

                        {% else %}

                            <a href="{% url 'news:search' %}?page={{ page.previous_page_number }}" class="prev">上一页</a>

                        {% endif %}

                    {% endif %}

                    {# 列出所有的URL地址 #}

                    {% for num in page.paginator.page_range|slice:":10" %}

                        {% if num == page.number %}

                            <span class="sel">{{ page.number }}</span>

                        {% else %}

                            {% if query %}

                                <a href="{% url 'news:search' %}?q={{ query }}&amp;page={{ num }}"

                                  target="_self">{{ num }}</a>

                            {% else %}

                                <a href="{% url 'news:search' %}?page={{ num }}" target="_self">{{ num }}</a>

                            {% endif %}

                        {% endif %}

                    {% endfor %}

                    {# 如果页数大于10,则打两点 #}

                    {% if page.paginator.num_pages > 10 %}

                        ..

                        {% if query %}

                            <a href="{% url 'news:search' %}?q={{ query }}&amp;page={{ page.paginator.num_pages }}"

                              target="_self">{{ page.paginator.num_pages }}</a>

                        {% else %}

                            <a href="{% url 'news:search' %}?page={{ page.paginator.num_pages }}"

                              target="_self">{{ page.paginator.num_pages }}</a>

                        {% endif %}

                    {% endif %}

                    {# 下一页的URL地址 #}

                    {% if page.has_next %}

                        {% if query %}

                            <a href="{% url 'news:search' %}?q={{ query }}&amp;page={{ page.next_page_number }}"

                              class="next">下一页</a>

                        {% else %}

                            <a href="{% url 'news:search' %}?page={{ page.next_page_number }}" class="next">下一页</a>

                        {% endif %}

                    {% endif %}

                </div>

            </div>

            <!-- news-contain end -->

        </div>

        <!-- content end -->

    </div>

```

```css

/* 在static/css/news/search.css中加入如下代码: */

/* === current index start === */

#pages {

padding: 32px 0 10px;

}

.page-box {

text-align: center;

    /*font-size: 14px;*/

}

#pages a.prev, a.next {

width: 56px;

padding: 0

}

#pages a {

display: inline-block;

height: 26px;

line-height: 26px;

background: #fff;

border: 1px solid #e3e3e3;

text-align: center;

color: #333;

padding: 0 10px

}

#pages .sel {

display: inline-block;

height: 26px;

line-height: 26px;

background: #0093E9;

border: 1px solid #0093E9;

color: #fff;

text-align: center;

padding: 0 10px

}

.highlighted{

    color:coral;

    mso-ansi-font-weight: bold;

}

/* === current index end === */

```

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,776评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,527评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,361评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,430评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,511评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,544评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,561评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,315评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,763评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,070评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,235评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,911评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,554评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,173评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,424评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,106评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,103评论 2 352

推荐阅读更多精彩内容