Descargas de archivos paralelas en Go usando Goroutines
En Go, es posible descargar y guardar archivos simultáneamente usando goroutines. Las gorutinas permiten una ejecución ligera de subprocesos, lo que facilita el procesamiento paralelo y mejora el rendimiento.
Aquí está el código que proporcionaste, modificado para utilizar gorutinas:
package main
import (
"encoding/json"
"fmt"
"io"
"io/ioutil"
"net/http"
"net/url"
"os"
"path/filepath"
"sync"
)
// Credentials
const app_key string = ""
const app_secret string = ""
// Authorization code
var code string
// Token response
type TokenResponse struct {
AccessToken string `json:"access_token"`
}
// File structure
type File struct {
Path string
}
// File list response
type FileListResponse struct {
FileList []File `json:"contents"`
}
// Download a file using goroutines
func download_file(file File, token TokenResponse, wg *sync.WaitGroup) {
download_file := fmt.Sprintf("https://api-content.dropbox.com/1/files/dropbox/%s?access_token=%s", file.Path, token.AccessToken)
resp, _ := http.Get(download_file)
defer resp.Body.Close()
filename := filepath.Base(file.Path)
out, err := os.Create(filename)
if err != nil {
panic(err)
}
defer out.Close()
io.Copy(out, resp.Body)
wg.Done()
}
func main() {
// Authorization and token retrieval
authorize_url := fmt.Sprintf("https://www.dropbox.com/1/oauth2/authorize?response_type=code&client_id=%s", app_key)
fmt.Printf("1. Go to: %s\n", authorize_url)
fmt.Println("2. Click 'Allow' (you might have to log in first)")
fmt.Println("3. Copy the authorization code.")
fmt.Printf("Enter the authorization code here: ")
fmt.Scanf("%s", &code)
// Get file list
file_list_url := fmt.Sprintf("https://api.dropbox.com/1/metadata/dropbox/Camera Uploads?access_token=%s", tr.AccessToken)
resp2, _ := http.Get(file_list_url)
defer resp2.Body.Close()
contents2, _ := ioutil.ReadAll(resp2.Body)
var flr FileListResponse
json.Unmarshal(contents2, &flr)
// WaitGroup to wait for all goroutines to finish
var wg sync.WaitGroup
// Download files concurrently
for i, file := range flr.FileList {
wg.Add(1)
go download_file(file, tr, &wg)
if i >= 2 {
break
}
}
wg.Wait()
}
En este código modificado, agregamos un sync.WaitGroup llamado wg para rastrear la cantidad de gorutinas que se ejecutan. Incrementamos wg antes de iniciar cada rutina y lo reducimos cuando cada rutina termina de usar wg.Done(). La rutina principal espera a que finalicen todas las rutinas llamando a wg.Wait(). Esto garantiza que el programa no se cierre antes de descargar todos los archivos.
Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.
Copyright© 2022 湘ICP备2022001581号-3