CARVIEW |
Select Language
HTTP/2 200
date: Thu, 31 Jul 2025 07:41:01 GMT
content-type: text/html; charset=utf-8
vary: X-PJAX, X-PJAX-Container, Turbo-Visit, Turbo-Frame, X-Requested-With,Accept-Encoding, Accept, X-Requested-With
x-robots-tag: none
etag: W/"74e47b376938d0c8d2cb3f5ba485143c"
cache-control: max-age=0, private, must-revalidate
strict-transport-security: max-age=31536000; includeSubdomains; preload
x-frame-options: deny
x-content-type-options: nosniff
x-xss-protection: 0
referrer-policy: no-referrer-when-downgrade
content-security-policy: default-src 'none'; base-uri 'self'; child-src github.githubassets.com github.com/assets-cdn/worker/ github.com/assets/ gist.github.com/assets-cdn/worker/; connect-src 'self' uploads.github.com www.githubstatus.com collector.github.com raw.githubusercontent.com api.github.com github-cloud.s3.amazonaws.com github-production-repository-file-5c1aeb.s3.amazonaws.com github-production-upload-manifest-file-7fdce7.s3.amazonaws.com github-production-user-asset-6210df.s3.amazonaws.com *.rel.tunnels.api.visualstudio.com wss://*.rel.tunnels.api.visualstudio.com objects-origin.githubusercontent.com copilot-proxy.githubusercontent.com proxy.individual.githubcopilot.com proxy.business.githubcopilot.com proxy.enterprise.githubcopilot.com *.actions.githubusercontent.com wss://*.actions.githubusercontent.com productionresultssa0.blob.core.windows.net/ productionresultssa1.blob.core.windows.net/ productionresultssa2.blob.core.windows.net/ productionresultssa3.blob.core.windows.net/ productionresultssa4.blob.core.windows.net/ productionresultssa5.blob.core.windows.net/ productionresultssa6.blob.core.windows.net/ productionresultssa7.blob.core.windows.net/ productionresultssa8.blob.core.windows.net/ productionresultssa9.blob.core.windows.net/ productionresultssa10.blob.core.windows.net/ productionresultssa11.blob.core.windows.net/ productionresultssa12.blob.core.windows.net/ productionresultssa13.blob.core.windows.net/ productionresultssa14.blob.core.windows.net/ productionresultssa15.blob.core.windows.net/ productionresultssa16.blob.core.windows.net/ productionresultssa17.blob.core.windows.net/ productionresultssa18.blob.core.windows.net/ productionresultssa19.blob.core.windows.net/ github-production-repository-image-32fea6.s3.amazonaws.com github-production-release-asset-2e65be.s3.amazonaws.com insights.github.com wss://alive.github.com wss://alive-staging.github.com api.githubcopilot.com api.individual.githubcopilot.com api.business.githubcopilot.com api.enterprise.githubcopilot.com; font-src github.githubassets.com; form-action 'self' github.com gist.github.com copilot-workspace.githubnext.com objects-origin.githubusercontent.com; frame-ancestors 'none'; frame-src viewscreen.githubusercontent.com notebooks.githubusercontent.com; img-src 'self' data: blob: github.githubassets.com media.githubusercontent.com camo.githubusercontent.com identicons.github.com avatars.githubusercontent.com private-avatars.githubusercontent.com github-cloud.s3.amazonaws.com objects.githubusercontent.com release-assets.githubusercontent.com secured-user-images.githubusercontent.com/ user-images.githubusercontent.com/ private-user-images.githubusercontent.com opengraph.githubassets.com copilotprodattachments.blob.core.windows.net/github-production-copilot-attachments/ github-production-user-asset-6210df.s3.amazonaws.com customer-stories-feed.github.com spotlights-feed.github.com objects-origin.githubusercontent.com *.githubusercontent.com; manifest-src 'self'; media-src github.com user-images.githubusercontent.com/ secured-user-images.githubusercontent.com/ private-user-images.githubusercontent.com github-production-user-asset-6210df.s3.amazonaws.com gist.github.com; script-src github.githubassets.com; style-src 'unsafe-inline' github.githubassets.com; upgrade-insecure-requests; worker-src github.githubassets.com github.com/assets-cdn/worker/ github.com/assets/ gist.github.com/assets-cdn/worker/
server: github.com
content-encoding: gzip
accept-ranges: bytes
set-cookie: _gh_sess=g%2BRvObqizc2yPwHyWRcsHIr3hmGeUjESuYpyz7ciJeerSxIIZasyxlsI5rIiHyGxKoUl7hVul777Kl8OlbA5%2FEb%2FHYn45I54THhtnCvNux5AGlYazd%2FztXtuO0ioYFBWoQ4gqdcmnDLFCLBtlKaj861vjzroloMuKhZMHTXdbosv%2BAendh8%2BVeHu8VeGkAVxL7hUBSN%2Fk%2Bf6oUu3Rh9DUsvrFv7PQ7TgY6uAetwUYj3CuVHw%2FKODbL0Vsq1PAAyuTmxBCVExqIJrYWubOelmwA%3D%3D--UWVOMCBLwXAIuND%2F--poR60m34cTwiHpTd1%2F7rVQ%3D%3D; Path=/; HttpOnly; Secure; SameSite=Lax
set-cookie: _octo=GH1.1.2049239683.1753947661; Path=/; Domain=github.com; Expires=Fri, 31 Jul 2026 07:41:01 GMT; Secure; SameSite=Lax
set-cookie: logged_in=no; Path=/; Domain=github.com; Expires=Fri, 31 Jul 2026 07:41:01 GMT; HttpOnly; Secure; SameSite=Lax
x-github-request-id: 86F2:4E82A:5500F7:6A6D95:688B1E0D
ScrollParallel · olivere/elastic Wiki · GitHub
Skip to content
Navigation Menu
{{ message }}
-
Notifications
You must be signed in to change notification settings - Fork 1.2k
ScrollParallel
tom10271 edited this page Apr 3, 2018
·
11 revisions
The ScrollService
allows you to iterate through a large result set. The example below for elastic v3.0.50+ illustrates how to do that effectively as a pipeline, using multiple goroutines. We use the excellent golang.org/x/sync/errgroup
for our solution.
package main
import (
"encoding/json"
"io"
"golang.org/x/net/context"
"golang.org/x/sync/errgroup"
"gopkg.in/cheggaaa/pb.v1"
"gopkg.in/olivere/elastic.v3"
)
type Product struct {
SKU string `json:"sku"`
Name string `json:"name"`
}
func main() {
client, err := elastic.NewClient()
if err != nil {
panic(err)
}
// Count total and setup progress
total, err := client.Count("warehouse").Type("product").Do()
if err != nil {
panic(err)
}
bar := pb.StartNew(int(total))
// This example illustrates how to use goroutines to iterate
// through a result set via ScrollService.
//
// It uses the excellent golang.org/x/sync/errgroup package to do so.
//
// The first goroutine will Scroll through the result set and send
// individual documents to a channel.
//
// The second cluster of goroutines will receive documents from the channel and
// deserialize them.
//
// Feel free to add a third goroutine to do something with the
// deserialized results.
//
// Let's go.
// 1st goroutine sends individual hits to channel.
hits := make(chan json.RawMessage)
g, ctx := errgroup.WithContext(context.Background())
g.Go(func() error {
defer close(hits)
// Initialize scroller. Just don't call Do yet.
scroll := client.Scroll("warehouse").Type("product").Size(100)
for {
results, err := scroll.Do()
if err == io.EOF {
return nil // all results retrieved
}
if err != nil {
return err // something went wrong
}
// Send the hits to the hits channel
for _, hit := range results.Hits.Hits {
select {
case hits <- *hit.Source:
case <-ctx.Done():
return ctx.Err()
}
}
}
return nil
})
// 2nd goroutine receives hits and deserializes them.
//
// If you want, setup a number of goroutines handling deserialization in parallel.
for i := 0; i < 10; i++ {
g.Go(func() error {
for hit := range hits {
// Deserialize
var p Product
err := json.Unmarshal(hit, &p)
if err != nil {
return err
}
// Do something with the product here, e.g. send it to another channel
// for further processing.
_ = p
bar.Increment()
// Terminate early?
select {
default:
case <-ctx.Done():
return ctx.Err()
}
}
return nil
})
}
// Check whether any goroutines failed.
if err := g.Wait(); err != nil {
panic(err)
}
// Done.
bar.FinishPrint("Done")
}
Notice: You can sort the results with ScrollService
. But that comes with a big performance hit. Elasticsearch has to sort results first before returning them to you. So if all you need is to get each result from a result set (potentially with a Query
), do not add a sort order. See here for details.
You can’t perform that action at this time.