Przy świeżej instalacji Ubuntu 16.04 chciałbym użyć gpg do szyfrowania moich kopii zapasowych baz danych, ale nie mogę tego zrobić gpg-agent
.
postgres@db:~$ gpg -s test.txt
You need a passphrase to unlock the secret key for
user: "Nicolas Remond <[email protected]>"
2048-bit RSA key, ID F5DECA47, created 2016-11-03
gpg: gpg-agent is not available in this session
Enter passphrase:
Wygląda też na to, że gpg-agent działa, jak wcześniej:
postgres@db:~$ gpg-agent
gpg-agent[1715]: no gpg-agent running in this session
postgres@db:~$ gpg-connect-agent /bye
gpg-connect-agent: no running gpg-agent - starting '/usr/bin/gpg-agent'
gpg-connect-agent: waiting for the agent to come up ... (5s)
gpg-connect-agent: connection to agent established
postgres@db:~$ pidof gpg-agent
1762
A konfiguracja gpg ma use-agent
ustawienie:
postgres@dbmaster0:~$ cat ~/.gnupg/gpg.conf | grep use-agent
# For Ubuntu we now use-agent by default to support more automatic
use-agent
Czego mi brakuje ?
--log-file [myfile]
i sprawdź, czy w dzienniku występują błędy.gpg: gpg-agent is not available in this session
. Gdybym miał log, jak sugerujesz, dostaję tylko:2016-12-19 13:39:39 gpg-agent[10957] gpg-agent (GnuPG) 2.1.11 started
GPG_AGENT_INFO
, ale nie wiem, jak wiedzieć, co ustawić ... wtedy dostałemgpg: problem with the agent - disabling agent use
.export GPG_AGENT_INFO=/var/lib/postgresql/.gnupg/S.gpg-agent:0:1
działa, ale nie jako użytkownik. Wygląda na to, że musiałbym to zrobić ręcznie, prawda?Odpowiedzi:
Odpowiadając sobie na wypadek, gdyby ktoś inny utknął na tym.
W systemie Ubuntu 16.04 domyślnymi wersjami są:
i
Nie są kompatybilne. Korzystanie z GPG2 jest obowiązkowe:
źródło
Rozwiązaniem jest instalacja
gpgv2
:Wynika to z faktu, że gpg-agent dostarczany z Ubuntu jest wersją 2 i próbuje połączyć się z gpg w wersji 2. Ale Ubuntu ma zainstalowaną wersję 1 gpg.
źródło
gnupg2