nginxని ఉపయోగించి Google డిస్క్ నుండి ఫైల్‌లను పంపిణీ చేస్తోంది

పూర్వచరిత్ర

నేను ఎక్కడో 1.5 TB కంటే ఎక్కువ డేటాను నిల్వ చేయవలసి ఉంది మరియు సాధారణ వినియోగదారులకు నేరుగా లింక్ ద్వారా డౌన్‌లోడ్ చేసుకునే సామర్థ్యాన్ని కూడా అందించాలి. సాంప్రదాయకంగా ఇటువంటి మెమరీ మొత్తం VDSకి వెళుతుంది కాబట్టి, ప్రాజెక్ట్ బడ్జెట్‌లో "ఏమీ చేయనక్కర్లేదు" వర్గం నుండి అద్దెకు తీసుకునే ఖర్చు పెద్దగా చేర్చబడలేదు మరియు సోర్స్ డేటా నుండి నేను VPS 400GB SSDని కలిగి ఉన్నాను, నేను కూడా కావాలనుకున్నాను, లాస్‌లెస్ కంప్రెషన్ లేకుండా నేను 1.5TB చిత్రాలను ఉంచలేను, అది విజయవంతమవుతుంది.

ఆపై నేను Google డిస్క్ నుండి జంక్‌ని తొలగిస్తే, Windows XPలో మాత్రమే రన్ అయ్యే ప్రోగ్రామ్‌లు మరియు ఇంటర్నెట్ అంత వేగంగా లేని రోజుల నుండి అపరిమితంగా ఒక పరికరం నుండి మరొక పరికరంలోకి మారుతున్న ఇతర విషయాలు ( ఉదాహరణకు, వర్చువల్ బాక్స్ యొక్క ఆ 10-20 సంస్కరణలు నోస్టాల్జిక్ కాకుండా మరే ఇతర విలువను కలిగి ఉండే అవకాశం లేదు), అప్పుడు ప్రతిదీ బాగా సరిపోతుంది. ఇక చెప్పేదేం లేదు. కాబట్టి, apiకి అభ్యర్థనల సంఖ్యపై పరిమితిని అధిగమించడం (మార్గం ద్వారా, ఎటువంటి సమస్యలు లేకుండా సాంకేతిక మద్దతు వినియోగదారుకు అభ్యర్థనల కోటాను 100 సెకన్లలో 10కి పెంచింది), డేటా త్వరగా దాని తదుపరి విస్తరణ స్థానానికి ప్రవహిస్తుంది. .

అంతా బాగానే ఉంది, కానీ ఇప్పుడు దాన్ని తుది వినియోగదారుకు తెలియజేయాలి. అంతేకాకుండా, ఇతర వనరులకు మళ్లింపులు లేకుండా, కానీ ఒక వ్యక్తి కేవలం "డౌన్‌లోడ్" బటన్‌ను నొక్కి, ఐశ్వర్యవంతమైన ఫైల్ యొక్క సంతోషకరమైన యజమాని అవుతాడు.

ఇక్కడ, దేవుని ద్వారా, నేను అన్ని రకాల ఇబ్బందుల్లోకి వెళ్ళాను. మొదట ఇది AmPHPలో స్క్రిప్ట్‌గా ఉంది, కానీ అది సృష్టించిన లోడ్‌తో నేను సంతృప్తి చెందలేదు (ప్రారంభంలో 100% కోర్ వినియోగానికి ఒక పదునైన జంప్). అప్పుడు ReactPHP కోసం కర్ల్ రేపర్ అమలులోకి వచ్చింది, ఇది వినియోగించిన CPU సైకిళ్ల సంఖ్య పరంగా నా కోరికలకు బాగా సరిపోతుంది, కానీ నేను కోరుకున్న వేగాన్ని ఇవ్వలేదు (మీరు కాలింగ్ విరామాన్ని తగ్గించవచ్చని తేలింది. curl_multi_select, కానీ అప్పుడు మేము మొదటి ఎంపిక వలె తిండిపోతు కలిగి ఉన్నాము ). నేను రస్ట్‌లో ఒక చిన్న సేవను వ్రాయడానికి కూడా ప్రయత్నించాను మరియు ఇది చాలా త్వరగా పనిచేసింది (ఇది పని చేయడం ఆశ్చర్యంగా ఉంది, నా జ్ఞానం ప్రకారం), కానీ నేను మరింత కోరుకున్నాను మరియు దానిని అనుకూలీకరించడం కష్టం. అదనంగా, ఈ పరిష్కారాలన్నీ ఏదో ఒకవిధంగా ప్రతిస్పందనను వింతగా బఫర్ చేశాయి మరియు ఫైల్ డౌన్‌లోడ్ అత్యంత ఖచ్చితత్వంతో ముగిసిన క్షణాన్ని ట్రాక్ చేయాలనుకుంటున్నాను.

సాధారణంగా, ఇది కొంతకాలం వంకరగా ఉంది, కానీ అది పనిచేసింది. ఒక రోజు వరకు నేను దాని వెర్రితనంలో చెప్పుకోదగ్గ ఆలోచనతో ముందుకు వచ్చాను: nginx, సిద్ధాంతంలో, నాకు కావలసినది చేయగలదు, త్వరగా పని చేయవచ్చు మరియు కాన్ఫిగరేషన్‌తో అన్ని రకాల వక్రీకరణలను కూడా అనుమతించవచ్చు. మనం ప్రయత్నించాలి - ఇది పని చేస్తే? మరియు అరరోజు నిరంతర శోధన తర్వాత, చాలా నెలలుగా స్థిరంగా పనిచేస్తున్న మరియు నా అవసరాలన్నింటినీ తీర్చే ఒక పరిష్కారం పుట్టింది.

NGINXని సెటప్ చేస్తోంది

# Первым делом создадим в конфигах нашего сайта отдельную локацию.
location ~* ^/google_drive/(.+)$ {

    # И закроем её от посторонних глаз (рук, ног и прочих частей тела).
    internal;

    # Ограничим пользователям скорость до разумных пределов (я за равноправие).
    limit_rate 1m;

    # А чтоб nginx мог найти сервера google drive укажем ему адрес резолвера.
    resolver 8.8.8.8;

    # Cоберем путь к нашему файлу (мы потом передадим его заголовками).
    set $download_url https://www.googleapis.com/drive/v3/files/$upstream_http_file_id?alt=media;

    # А так же Content-Disposition заголовок, имя файла мы передадим опять же в заголовках.
    set $content_disposition 'attachment; filename="$upstream_http_filename"';

    # Запретим буфферизировать ответ на диск.
    proxy_max_temp_file_size 0;

    # И, что немаловажно, передадим заголовок с токеном (не знаю почему, но в заголовках из $http_upstream токен передать не получилось. Вернее передать получилось, но скорей всего его где-то нужно экранировать, потому что гугл отдает ошибку авторизации).
    proxy_set_header Authorization 'Bearer $1';

    # И все, осталось отправить запрос гуглу по ранее собранному нами адресу.
    proxy_pass $download_url;

    # А чтоб у пользователя при скачивании отобразилось правильное имя файла мы добавим соответствующий заголовок.
    add_header Content-Disposition $content_disposition;

    # Опционально можно поубирать ненужные нам заголовки от гугла.
    proxy_hide_header Content-Disposition;
    proxy_hide_header Alt-Svc;
    proxy_hide_header Expires;
    proxy_hide_header Cache-Control;
    proxy_hide_header Vary;
    proxy_hide_header X-Goog-Hash;
    proxy_hide_header X-GUploader-UploadID;
}

స్పాయిలర్ కింద వ్యాఖ్యలు లేని చిన్న సంస్కరణను చూడవచ్చు

location ~* ^/google_drive/(.+)$ {
    internal;
    limit_rate 1m;
    resolver 8.8.8.8;
    
    set $download_url https://www.googleapis.com/drive/v3/files/$upstream_http_file_id?alt=media;
    set $content_disposition 'attachment; filename="$upstream_http_filename"';
    
    proxy_max_temp_file_size 0;
    proxy_set_header Authorization 'Bearer $1';
    proxy_pass $download_url;
    
    add_header Content-Disposition $content_disposition;
    
    proxy_hide_header Content-Disposition;
    proxy_hide_header Alt-Svc;
    proxy_hide_header Expires;
    proxy_hide_header Cache-Control;
    proxy_hide_header Vary;
    proxy_hide_header X-Goog-Hash;
    proxy_hide_header X-GUploader-UploadID;
}

ఈ సంతోషం అంతా మేనేజ్ చేయడానికి స్క్రిప్ట్ రాస్తున్నాం

ఉదాహరణ PHPలో ఉంటుంది మరియు ఉద్దేశపూర్వకంగా కనీస కిట్‌తో వ్రాయబడుతుంది. ఏదైనా ఇతర భాషతో అనుభవం ఉన్న ఎవరైనా నా ఉదాహరణను ఉపయోగించి ఈ విభాగాన్ని ఏకీకృతం చేయగలరని నేను భావిస్తున్నాను.

<?php

# Токен для Google Drive Api.
define('TOKEN', '*****');

# ID файла на гугл диске
$fileId = 'abcdefghijklmnopqrstuvwxyz1234567890';

# Опционально, но так как мы не передаем никаких данных - почему бы и нет?
http_response_code(204);

# Зададим заголовок c ID файла (в конфигах nginx мы потом получим его как $upstream_http_file_id).
header('File-Id: ' . $fileId);
# И заголовок с именем файла (соответственно $upstream_http_filename).
header('Filename: ' . 'test.zip');
# Внутренний редирект. А еще в адресе мы передадим токен, тот самый, что мы получаем из $1 в nginx.
header('X-Accel-Redirect: ' . rawurlencode('/google_drive/' . TOKEN));

ఫలితాలు

సాధారణంగా, ఈ పద్ధతి ఏదైనా క్లౌడ్ నిల్వ నుండి వినియోగదారులకు ఫైల్‌ల పంపిణీని నిర్వహించడం చాలా సులభం చేస్తుంది. అవును, టెలిగ్రామ్ లేదా VK నుండి కూడా, (ఫైల్ పరిమాణం ఈ నిల్వ యొక్క అనుమతించదగిన పరిమాణాన్ని మించకుండా ఉంటే). నాకు అలాంటి ఆలోచన వచ్చింది , కానీ దురదృష్టవశాత్తు నేను 2GB వరకు ఫైల్‌లను చూస్తున్నాను మరియు అప్‌స్ట్రీమ్ నుండి ప్రతిస్పందనలను అతుక్కోవడానికి నేను ఇంకా ఒక పద్ధతి లేదా మాడ్యూల్ కనుగొనలేదు మరియు ఈ ప్రాజెక్ట్ కోసం కొన్ని రకాల రేపర్‌లను వ్రాయడం అసమంజసంగా శ్రమతో కూడుకున్నది.

మీరు ఆసక్తి చూపినందుకు ధన్యవాదములు. నా కథ మీకు కనీసం కొంచెం ఆసక్తికరంగా లేదా ఉపయోగకరంగా ఉంటుందని నేను ఆశిస్తున్నాను.

మూలం: www.habr.com

ఒక వ్యాఖ్యను జోడించండి