http/get_simple/go/client/client.go (42 lines of code) (raw):

// Licensed to the Apache Software Foundation (ASF) under one // or more contributor license agreements. See the NOTICE file // distributed with this work for additional information // regarding copyright ownership. The ASF licenses this file // to you under the Apache License, Version 2.0 (the // "License"); you may not use this file except in compliance // with the License. You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package main import ( "fmt" "net/http" "time" "github.com/apache/arrow/go/v15/arrow" "github.com/apache/arrow/go/v15/arrow/ipc" "github.com/apache/arrow/go/v15/arrow/memory" ) func main() { start := time.Now() resp, err := http.Get("http://localhost:8008") if err != nil { panic(err) } if resp.StatusCode != http.StatusOK { panic(fmt.Errorf("got non-200 status: %d", resp.StatusCode)) } defer resp.Body.Close() rdr, err := ipc.NewReader(resp.Body, ipc.WithAllocator(memory.DefaultAllocator)) if err != nil { panic(err) } defer rdr.Release() batches := make([]arrow.Record, 0) defer func() { for _, b := range batches { b.Release() } }() for rdr.Next() { rec := rdr.Record() rec.Retain() batches = append(batches, rec) } if rdr.Err() != nil { panic(rdr.Err()) } execTime := time.Since(start) fmt.Printf("%d record batches received\n", len(batches)) fmt.Printf("%.2f seconds elapsed\n", execTime.Seconds()) }