प्रॉक्सी के पीछे apt-key के साथ gpg कुंजी जोड़ने में असमर्थ


34

apt-keyउबंटू 17.04 पर स्विच किए जाने के बाद से व्यवस्थित रूप से एक gpg कुंजी जोड़ना विफल रहता है (मुझे संदेह है कि यह सीधे संबंधित है हालांकि)। Spotify के रेपो कुंजी के साथ उदाहरण :

$ sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv-keys BBEBDCB318AD50EC6865090613B00F1FD2C19886
Executing: /tmp/apt-key-gpghome.wRE6z9GBF8/gpg.1.sh --keyserver hkp://keyserver.ubuntu.com:80 --recv-keys BBEBDCB318AD50EC6865090613B00F1FD2C19886
gpg: keyserver receive failed: No keyserver available

अगर मैं hkp://उपसर्ग को हटा दूं तो भी वही ।


संदर्भ: मैं स्थानीय कॉर्पोरेट प्रॉक्सी का सामना करने के लिए CNTLM का उपयोग करता हूं । Env चर सेट (में /etc/environment) हैं:

$ env | grep 3128
https_proxy=http://localhost:3128
http_proxy=http://localhost:3128
ftp_proxy=http://localhost:3128

/etc/apt/apt.confकॉन्फ़िगर किया गया है ( aptआदेश ठीक काम कर रहे हैं):

$ cat /etc/apt/apt.conf
Acquire::http::Proxy "http://localhost:3128";
Acquire::https::Proxy "http://localhost:3128";
Acquire::ftp::Proxy "http://localhost:3128";

अंत में, निर्दिष्ट कीपर उपलब्ध है:

$ curl keyserver.ubuntu.com:80
<?xml version="1.0"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
  <head>
    <title>SKS OpenPGP Public Key Server</title>
  </head>
  <body>
  [...]

मैं क्या कर सकता हूँ ? मुझे यकीन नहीं है कि आगे इसे कैसे डीबग करना है ...


चीजें जो मैंने पहले ही करने की कोशिश की, बिना किसी परिणाम के:

  • (परिरक्षित एनवी) विकल्प के sudoसाथ चलाएँ-E
  • विकल्प ( स्रोत ) के apt-key advसाथ चलाएं--keyserver-options http-proxy=http://localhost:3128/
  • $ gpg --list-keysकिसी कारण ( स्रोत ) के लिए चलाएं
  • एक अन्य कीज़र का उपयोग करें ( --keyserver pgp.mit.edu)
  • hkp://भाग निकालें ( --keyserver keyserver.ubuntu.com:80)

अजीब बात यह है कि मैं कभी भी /var/log/syslogदौड़ते समय कोई "cntlm" प्रविष्टि नहीं देखता apt-key


जब आप http://keyserver.ubuntu.com/अपने ब्राउज़र में पहुंचने का प्रयास करते हैं तो क्या होता है?
17'17

मुझे वेब पेज मिला है (जैसा कि curlऊपर दिए गए आउटपुट में दिखाया गया है )
Anto

जवाबों:


50

आपके पास आमतौर पर ftp, http और https के लिए एक प्रॉक्सी है; मैं एक URL के रूप में वहाँ hkp: // देख रहा हूँ; इसलिए इसे शुद्ध http प्रॉक्सी के माध्यम से निर्देशित नहीं किया जाना चाहिए, इसलिए संचार विफल हो जाता है।

इसके बजाय इसका उपयोग करें:

sudo apt-key adv --keyserver keyserver.ubuntu.com --keyserver-options http-proxy=http://localhost:3128 --recv-keys BBEBDCB318AD50EC6865090613B00F1FD2C19886

सिस्टम अपडेट के लिए, मैं उदाहरण के लिए, APT प्रॉक्सी का उपयोग करने की सलाह दूंगा apt-cacher-ng

इसे करने का एक और तरीका, सार्वजनिक वेब इंटरफ़ेस में खोज रहा है, उदाहरण के लिए, अपने काम करने वाले स्टेशन पर उदाहरण के लिए, जिसे आप https://keyserver.ubuntu.com पर चाहते हैं।

साइट खोलें, और आपको एक फॉर्म मिला। इस मामले में मैंने "खोज स्ट्रिंग" "Spotify" का उपयोग किया; फिर "खोज" चुनें; यह कई कुंजी सूचीबद्ध करेगा।

परिणाम पृष्ठ में आपके द्वारा हस्ताक्षरित हस्ताक्षर / फिंगरप्रिंट की खोज:

pub  4096R/D2C19886 2015-05-28            
     Fingerprint=BBEB DCB3 18AD 50EC 6865  0906 13B0 0F1F D2C1 9886 

uid Spotify Public Repository Signing Key <operations@spotify.com>
sig  sig3  D2C19886 2015-05-29 __________ 2017-11-22 [selfsig]
sig  sig   94558F59 2015-06-02 __________ __________ Spotify Public Repository Signing Key <operations@spotify.com>

हम देखते हैं कि यह वह प्रविष्टि है जो हमें रुचती है।

इसलिए हम D2C19886 में क्लिक करते हैं और https://keyserver.ubuntu.com/pks/lookup?op=get&search=0x13B00F1FD2C19886 पर कुंजी के साथ एक पृष्ठ प्रस्तुत किया जाता है ।

Public Key Server -- Get "0x13b00f1fd2c19886 "

-----BEGIN PGP PUBLIC KEY BLOCK-----
Version: SKS 1.1.6
Comment: Hostname: keyserver.ubuntu.com

mQINBFVm7dMBEADGcdfhx/pjGtiVhsyXH4r8TrFgsGyHEsOWaYeU2JL1tEi+YI1qjpExb2Te
TReDTiGEFFMWgPTS0y5HQGm+2P3XGv0pShvgg9A6FWZmZmT+tymA2zvNrdpmKdhScZ52StPL
Fz9wsmXHG4DIKVuzgzuV4YxJ1i2wFtoVp8zT9ORu1BxLZ0IBwTvLRbaQGZ8DwXVAHak9cK91
Ujj6gJ1MJPohZLHH2BjrOjEl/I36jFUjK0AadznNzo08lLAi94qjtheJtuJD3IEOAlCkaknz
6vbEFpszLGlLD7GENMzJk46ObuJuvW5R2PkOU2U8jS0GaUD9Ou/SIdJ6vIdvjSs/ettc2wwd
nbSdadvjovIfvEBRsEVMpRG+42B+DZpJbS9pCb8sxTJtnUy1YViZmG0++FhPGGPGzQYhC/Mz
07lsx5PkC7Kka2FCNmhauxw5deO43Ck181oQVdbt/VxmChzchUJ6N6/uOV5JKm7B9UnDNyqU
Yv6goeLvFnT9ag+FCxiroTrq+dINr6d+XT/cI9WtSagfmhcekwhyfcCgYsFemAOckRifjEGF
MksQlnWkGwWNoKe91KBxjgaJaazSbZRk0dFPSSmfKWaxuTwkR74pbaueyijnQJgHAjfCyzQe
9miN9DitON5l6T2gVAN3Jn1QQmV7tt5GB7amcHf5/b0oYmmRPQARAQABtD5TcG90aWZ5IFB1
YmxpYyBSZXBvc2l0b3J5IFNpZ25pbmcgS2V5IDxvcGVyYXRpb25zQHNwb3RpZnkuY29tPokB
HAQQAQIABgUCVW3SWAAKCRAILM7flFWPWUk5B/wOqqD9/2Do9PyPucfUs/rrP4+M8iJLpv8U
+bX/qHryTTWfpk3YuKL4+c8saHySK4HLGyxd3mdo1XMF351KrxLQvWMSSPbIRV9cSqZROOVn
2ya+3xpWk6t1omLzxtBBMOC4B5qAfWhog7ioAmzQNY5NUz5mqXVP5WbgR/G+GOszzuQUgeu1
Xxxzir3JqWQ0g8mp3EtX7dB76zxkkuTYbeVDPOvtJPn/38d3oSLUI1QJnL8pjREHeE8fO5mW
ncJmyZNhkYd+rfnPk+W0ZkTr59QBIEOGMTmATtNh+x1mo5e2dW91Oj4jEWipMUouLGqbo/gJ
uHFMt8RWBmy+zFYUEPYHiQI+BBMBAgAoAhsDBgsJCAcDAgYVCAIJCgsEFgIDAQIeAQIXgAUC
VWg3sAUJBK3QLQAKCRATsA8f0sGYhl6hEACJ1CrYjaflKKR2Znuh0g0gM89NAwO8AA4+SpkW
HagdGLo7OV/rGB3mlwD4mhaa8CbEnBT/za3jFnT19KsYQWiT21oOX/eo47ITbAspjDZTiXLi
nyAcOJn+q/EFkelROzbVaxZHi6SN5kCEd8KAew8h2jZf8wWqaYVyMPNSqotUhin6YjWsu57B
GixVThoMmxx3udsGAiYqt8buAANWbkUphrvtJuNCKkGym7psnS4Q5EnHPfvbYii9iAfBswX6
nZQlehva7aToN73elYL3opCArAxKAFx70bpGxb7T16KjKzkKS0a4iQ7xdbBGylb+AE/RhICa
+RM5tma2YnB3pZvFM/n0BNeYReCgvxkl1rqrB1KxmFHfGqjLkb2YAZ5RYnP3gEt+nbEWxL8F
O0Bhakn1RB3NqTC2oiQAUfh+66yUawUNkHRHlGAEzZAxvpfnf0hSJp734lyQZJs+zqXUAXa2
UmEZ6se62PgZRQIz5IbAVxSiGz4xIZs1yS36N2vZ34LFJa9o/HVk5OfpqZM0zjWwQIQN2b4O
BizL5r4h2Mi5BHUEyYMsDZn+txoJjPPYLolRlf31sqi5MJE+cbOAXSn8PC9k4i+hrbfqFzts
47+6xgCH3aXbhUkJh1CH/0/qEXfTPYTyayijm4rdvSBczzEORWGT5E38oV9h1eUqp4nVPg==
=/qip
-----END PGP PUBLIC KEY BLOCK-----

आप "----- BEGIN" से शुरू होने वाली रेखा और "----- END" के साथ समाप्त होने वाली रेखा के बीच में कटौती करते हैं, उन पंक्तियों सहित, और फ़ाइल में पेस्ट करते हैं, spotify.pgpउस इच्छित सर्वर पर कहते हैं जिसे आप आयात करना चाहते हैं कुंजी। (इसे यहां से न काटें, क्योंकि मैंने प्रारूपण करते समय प्रत्येक पंक्ति से पहले 4 स्थान जोड़े थे)

अंत में आपके द्वारा किए जाने वाले सर्वर में कुंजी आयात करने के लिए:

$sudo apt-key add spotify.pgp
OK

@ कोई काम नहीं किया?
रुई एफ रिबेरो

1
हैलो रुई, वास्तव में यह "मैनुअल" विधि काम करती है और इस बीच मैंने इसे "अस्थायी रूप से" हल किया। जाहिरा तौर पर यह अस्थायी समाधान अस्थायी नहीं रहने वाला है :( लेकिन वैसे भी बहुत धन्यवाद।
एंटो

4

यहाँ एक समाधान है जो http के लिए कर्ल के माध्यम से उपयोग करता है इसके बजाय apt-key या gpg को प्रॉक्सी करने की कोशिश कर रहा है:

curl -sSL \
'http://keyserver.ubuntu.com/pks/lookup?op=get&search=0xBBEBDCB318AD50EC6865090613B00F1FD2C19886' \
| sudo apt-key add -

इस विधि के बजाय प्रयोग किया जाना चाहिए apt-keyकमांड लाइन या http_proxy या https_proxy वातावरण चर सेटिंग्स (जिनमें से नवीनतम संस्करण में अक्षम हैं apt-key)।


-1

आप निम्न के-रिपॉजिटरी को जोड़ने के लिए एक पैरामीटर के रूप में कीज़र को निर्दिष्ट कर सकते हैं:

sudo add-apt-repository --keyserver hkps://keyserver.ubuntu.com:443 some_ppa

निवर्तमान बंदरगाह 443 को कॉर्पोरेट फ़ायरवॉल द्वारा अवरुद्ध नहीं किया जाएगा।


क्यूं कर? यह डिफ़ॉल्ट रूप से मेरे सभी नेटवर्क पर अवरुद्ध है।
cprn

यह उत्तर काम नहीं करेगा, इस सवाल की चुनौती यह है कि पहुंच केंद्रीय रूप से फ़ायरवॉल है।
रुई एफ रिबेरो
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.