zoukankan      html  css  js  c++  java
  • 使用go向es进行数据操作脚本

    /**
     * @Author: anchnet
     * @Description:
     * @File:  main.go
     * @Version: 1.0.0
     * @Date: 2021/7/2 13:07
     */
    
    package main
    
    import (
    	"bytes"
    	"encoding/json"
    	"flag"
    	"fmt"
    	"github.com/elastic/go-elasticsearch/v8"
    	"io/ioutil"
    	"strconv"
    	"time"
    )
    
    func main() {
    	start := time.Now() // 获取当前时间
    
    	//支持参数
    	var (
    		count int    // 起始数
    		total int    // 截至数
    		index string // index
    		id    string // id
    		title string // title
    	)
    	flag.IntVar(&count, "c", 1, "起始数")
    	flag.IntVar(&total, "e", 1, "截至数")
    	flag.StringVar(&index, "i", "", "index")
    	flag.StringVar(&id, "d", "", "id")
    	flag.StringVar(&title, "t", "", "title")
    	// 解析参数
    	flag.Parse()
    	if index == "" {
    		index = "demo"
    	}
    	if id == "" {
    		id = "id_1"
    	}
    	if title == "" {
    		title = "安畅"
    	}
    	fmt.Println("count:", count)
    	fmt.Println("total:", total)
    	fmt.Println("index:", index)
    	fmt.Println("id:", id)
    	fmt.Println("title:", title)
    
    	addresses := []string{"http://192.168.201.113:31526"}
    	config := elasticsearch.Config{
    		Addresses: addresses,
    		Username:  "elastic",
    		Password:  "5SgDC5mlovMmiTd79FA1",
    		CloudID:   "",
    		APIKey:    "",
    	}
    	// new client
    	es, err := elasticsearch.NewClient(config)
    	if err != nil {
    		fmt.Println(err, "Error creating the client")
    	}
    
    	//Get(*es, index, id)
    	//Update(*es, index, id)
    	//Get(*es, index, id)
    	create(*es, index, count, total)
    	//Search(*es, index, title)
    
    	elapsed := time.Since(start)
    	fmt.Println("该函数执行完成耗时:", elapsed)
    
    }
    
    func create(es elasticsearch.Client, index string, count int, total int) bool {
    	//var wg sync.WaitGroup
    	// Create creates a new document in the index.
    	// Returns a 409 response when a document with a same ID already exists in the index.
    	for i := count; i < total; i++ {
    		//wg.Add(1)
    		k := strconv.Itoa(i)
    		var buf bytes.Buffer
    
    		content, err := ioutil.ReadFile("./test.log") // just pass the file name
    		if err != nil {
    			fmt.Print(err)
    		}
    
    		doc := map[string]interface{}{
    			"title":   "安畅是一家怎么样的公司呢?" + k,
    			"content": content,
    			"time":    time.Now().Unix(),
    			"date":    time.Now(),
    		}
    		if err := json.NewEncoder(&buf).Encode(doc); err != nil {
    			fmt.Println(err, "Error encoding doc")
    			return false
    		}
    
    		func() {
    			time.Sleep(1 * time.Millisecond)
    			res, err := es.Create(index, "idx_"+k, &buf)
    			if err != nil {
    				fmt.Println(err, "Error create response")
    			}
    			//wg.Done()
    			defer res.Body.Close()
    			fmt.Println(res.String())
    		}()
    	}
    	//wg.Wait()
    	return true
    }
    //
    //func Search(es elasticsearch.Client, index string, title string) {
    //	// info
    //	res, err := es.Info()
    //	if err != nil {
    //		fmt.Println(err, "Error getting response")
    //	}
    //	fmt.Println(res.String())
    //	// search - highlight
    //	var buf bytes.Buffer
    //	query := map[string]interface{}{
    //		"query": map[string]interface{}{
    //			"match": map[string]interface{}{
    //				"title": title,
    //			},
    //		},
    //		"highlight": map[string]interface{}{
    //			"pre_tags":  []string{"<font color='red'>"},
    //			"post_tags": []string{"</font>"},
    //			"fields": map[string]interface{}{
    //				"title": map[string]interface{}{},
    //			},
    //		},
    //	}
    //	if err := json.NewEncoder(&buf).Encode(query); err != nil {
    //		fmt.Println(err, "Error encoding query")
    //	}
    //	// Perform the search request.
    //	res, err = es.Search(
    //		es.Search.WithContext(context.Background()),
    //		es.Search.WithIndex(index),
    //		es.Search.WithBody(&buf),
    //		es.Search.WithTrackTotalHits(true),
    //		es.Search.WithFrom(0),
    //		es.Search.WithSize(10),
    //		es.Search.WithSort("time:desc"),
    //		es.Search.WithPretty(),
    //	)
    //	if err != nil {
    //		fmt.Println(err, "Error getting response")
    //	}
    //	defer res.Body.Close()
    //	fmt.Println(res.String())
    //}
    //
    //func DeleteByQuery(es elasticsearch.Client) {
    //	// DeleteByQuery deletes documents matching the provided query
    //	var buf bytes.Buffer
    //	query := map[string]interface{}{
    //		"query": map[string]interface{}{
    //			"match": map[string]interface{}{
    //				"title": "外面",
    //			},
    //		},
    //	}
    //	if err := json.NewEncoder(&buf).Encode(query); err != nil {
    //		fmt.Println(err, "Error encoding query")
    //	}
    //	index := []string{"demo"}
    //	res, err := es.DeleteByQuery(index, &buf)
    //	if err != nil {
    //		fmt.Println(err, "Error delete by query response")
    //	}
    //	defer res.Body.Close()
    //	fmt.Println(res.String())
    //}
    //
    //func Delete(es elasticsearch.Client, index string, id string) {
    //	// Delete removes a document from the index
    //	res, err := es.Delete(index, id)
    //	if err != nil {
    //		fmt.Println(err, "Error delete by id response")
    //	}
    //	defer res.Body.Close()
    //	fmt.Println(res.String())
    //}
    //
    //func Get(es elasticsearch.Client, index string, id string) {
    //	res, err := es.Get(index, id)
    //	if err != nil {
    //		fmt.Println(err, "Error get response")
    //	}
    //	defer res.Body.Close()
    //	fmt.Println(res.String())
    //}
    //
    //func Update(es elasticsearch.Client, index string, id string) {
    //	// Update updates a document with a script or partial document.
    //	var buf bytes.Buffer
    //	doc := map[string]interface{}{
    //		"doc": map[string]interface{}{
    //			"title":       "更新你看到外面的世界是什么样的?",
    //			"content":     "更新外面的世界真的很精彩",
    //			"update_time": time.Now().Unix(),
    //			"update_date": time.Now(),
    //		},
    //	}
    //	if err := json.NewEncoder(&buf).Encode(doc); err != nil {
    //		fmt.Println(err, "Error encoding doc")
    //	}
    //	res, err := es.Update(index, id, &buf)
    //	if err != nil {
    //		fmt.Println(err, "Error Update response")
    //	}
    //	defer res.Body.Close()
    //	fmt.Println(res.String())
    //}
    //
    //func UpdateByQuery(es elasticsearch.Client, indexs string) {
    //	// UpdateByQuery performs an update on every document in the index without changing the source,
    //	// for example to pick up a mapping change.
    //	index := []string{indexs}
    //	var buf bytes.Buffer
    //	doc := map[string]interface{}{
    //		"query": map[string]interface{}{
    //			"match": map[string]interface{}{
    //				"title": "外面",
    //			},
    //		},
    //		// 根据搜索条件更新title
    //		/*
    //		   "script": map[string]interface{}{
    //		       "source": "ctx._source['title']='更新你看到外面的世界是什么样的?'",
    //		   },
    //		*/
    //		// 根据搜索条件更新title、content
    //		/*
    //		   "script": map[string]interface{}{
    //		       "source": "ctx._source=params",
    //		       "params": map[string]interface{}{
    //		           "title": "外面的世界真的很精彩",
    //		           "content": "你看到外面的世界是什么样的?",
    //		       },
    //		       "lang": "painless",
    //		   },
    //		*/
    //		// 根据搜索条件更新title、content
    //		"script": map[string]interface{}{
    //			"source": "ctx._source.title=params.title;ctx._source.content=params.content;",
    //			"params": map[string]interface{}{
    //				"title":   "看看外面的世界真的很精彩",
    //				"content": "他们和你看到外面的世界是什么样的?",
    //			},
    //			"lang": "painless",
    //		},
    //	}
    //	if err := json.NewEncoder(&buf).Encode(doc); err != nil {
    //		fmt.Println(err, "Error encoding doc")
    //	}
    //	res, err := es.UpdateByQuery(
    //		index,
    //		es.UpdateByQuery.WithBody(&buf),
    //		es.UpdateByQuery.WithContext(context.Background()),
    //		es.UpdateByQuery.WithPretty(),
    //	)
    //	if err != nil {
    //		fmt.Println(err, "Error Update response")
    //	}
    //	defer res.Body.Close()
    //	fmt.Println(res.String())
    //}
    
    
    过手如登山,一步一重天
  • 相关阅读:
    c++ 类 总结
    SQLite入门与分析(四)Page Cache之事务处理(3)
    SQLite入门与分析(三)内核概述(1)
    SQLite入门与分析(八)存储模型(1)
    glibc笔记——strlen
    SQLite入门与分析(二)设计与概念
    线性时间选择问题——分治
    SQLite入门与分析(二)设计与概念(续)
    浅谈c语言中的字符串
    SQLite入门与分析(六)再谈SQLite的锁
  • 原文地址:https://www.cnblogs.com/zisefeizhu/p/14964460.html
Copyright © 2011-2022 走看看