ssh_scan: Konfigurace SSH a kontrola zásad pro server Linux a UNIX

Protokol SSH ("Secure Shell") je metoda pro zabezpečené vzdálené přihlášení z jednoho systému do jiného. Sysadmin a uživatelé používají zabezpečený kanál přes nezabezpečenou síť ve formátu architektury klient-server pro připojení SSH klienta se serverem SSH. Bezpečnostní ssh server je důležitý úkol. K dispozici je nástroj nazvaný ssh_scan z Mozilly, který funguje jako prototyp konfigurace SSH a skenování zásad pro SSHD.

Výhody ssh_scan

Z domovské stránky projektu:

  1. Minimální závislost - používá nativní Ruby a BinData, aby vykonával svou práci, bez těžkých závislostí.
  2. Nejde jen o skript - Implementace je přenosná pro použití v jiném projektu nebo pro automatizaci úkolů.
  3. Jednoduché - stačí ssh_scan u služby SSH a získat zprávu JSON o tom, co podporuje a jeho stavu politiky.
  4. Konfigurovatelné - Vytvořte si vlastní vlastní zásady, které odpovídají vašim jedinečným požadavkům.

Instalujte závislost

Zadejte následující příkaz apt-get/apt příkaz nainstalovat ruby ​​a klenot na Debian / Ubuntu Linux:
$ sudo apt-get install ruby gem
Vzorové výstupy:

Fig.01: Instalujte rubín a klenot
Fig.01: Instalujte rubín a klenot

Nainstalujte ssh_scan

Zadejte následující příkaz a nainstalujte ssh_scan jako gem:
$ sudo gem install ssh_scan
Vzorové výstupy:

Obr.02: Instalace ssh_scan pomocí gemu
Obr.02: Instalace ssh_scan pomocí gemu

Jak používat ssh_scan?

Syntaxe je:
$ ssh_scan -t ip
$ ssh_scan -t server
$ ssh_scan -t server1.cyberciti.biz

Například skenujte ssh server nainstalovaný na 192.168.2.15, zadejte:
$ ssh_scan -t 192.168.2.15
Vzorové výstupy:

I, [2017-04-25T16:12:11.019160 #32317]  INFO -- : You're using the latest version of ssh_scan 0.0.19
[
  {
    "ssh_scan_version": "0.0.19",
    "ip": "192.168.2.15",
    "port": 22,
    "server_banner": "SSH-2.0-OpenSSH_7.4p1 Ubuntu-10",
    "ssh_version": 2.0,
    "os": "ubuntu",
    "os_cpe": "o:canonical:ubuntu",
    "ssh_lib": "openssh",
    "ssh_lib_cpe": "a:openssh:openssh:7.4p1",
    "cookie": "82d7cc908765f03154b10d5cdf14195a",
    "key_algorithms": [
      "curve25519-sha256",
      "[email protected]",
      "ecdh-sha2-nistp256",
      "ecdh-sha2-nistp384",
      "ecdh-sha2-nistp521",
      "diffie-hellman-group-exchange-sha256",
      "diffie-hellman-group16-sha512",
      "diffie-hellman-group18-sha512",
      "diffie-hellman-group14-sha256",
      "diffie-hellman-group14-sha1"
    ],
    "server_host_key_algorithms": [
      "ssh-rsa",
      "rsa-sha2-512",
      "rsa-sha2-256",
      "ecdsa-sha2-nistp256",
      "ssh-ed25519"
    ],
    "encryption_algorithms_client_to_server": [
      "[email protected]",
      "aes128-ctr",
      "aes192-ctr",
      "aes256-ctr",
      "[email protected]",
      "[email protected]"
    ],
    "encryption_algorithms_server_to_client": [
      "[email protected]",
      "aes128-ctr",
      "aes192-ctr",
      "aes256-ctr",
      "[email protected]",
      "[email protected]"
    ],
    "mac_algorithms_client_to_server": [
      "[email protected]",
      "[email protected]",
      "[email protected]",
      "[email protected]",
      "[email protected]",
      "[email protected]",
      "[email protected]",
      "hmac-sha2-256",
      "hmac-sha2-512",
      "hmac-sha1"
    ],
    "mac_algorithms_server_to_client": [
      "[email protected]",
      "[email protected]",
      "[email protected]",
      "[email protected]",
      "[email protected]",
      "[email protected]",
      "[email protected]",
      "hmac-sha2-256",
      "hmac-sha2-512",
      "hmac-sha1"
    ],
    "compression_algorithms_client_to_server": [
      "none",
      "[email protected]"
    ],
    "compression_algorithms_server_to_client": [
      "none",
      "[email protected]"
    ],
    "languages_client_to_server": [

    ],
    "languages_server_to_client": [

    ],
    "hostname": "m6700",
    "auth_methods": [
      "publickey",
      "password"
    ],
    "fingerprints": {
      "rsa": {
        "known_bad": "false",
        "md5": "1d:14:84:f0:c7:21:10:0e:30:d9:f9:59:6b:c3:95:97",
        "sha1": "70:ac:7c:2c:94:54:aa:09:f2:58:f3:48:f0:9e:f2:a0:a2:37:f1:0a",
        "sha256": "6d:d8:20:c6:8e:e7:db:0d:94:9d:34:66:ba:b7:9c:68:8a:ea:79:19:a6:0d:76:cc:ec:fe:82:21:68:a5:64:74"
      }
    },
    "start_time": "2017-04-25 16:12:11 +0000",
    "end_time": "2017-04-25 16:12:11 +0000",
    "scan_duration_seconds": 0.118730486,
    "duplicate_host_key_ips": [

    ],
    "compliance": {
      "policy": "Mozilla Modern",
      "compliant": false,
      "recommendations": [
        "Remove these Key Exchange Algos: curve25519-sha256, diffie-hellman-group16-sha512, diffie-hellman-group18-sha512, diffie-hellman-group14-sha256, diffie-hellman-group14-sha1",
        "Remove these MAC Algos: [email protected], [email protected], [email protected], hmac-sha1",
        "Remove these Authentication Methods: password"
      ],
      "references": [
        "https://wiki.mozilla.org/Security/Guidelines/OpenSSH"
      ]
    }
  }
]

Chcete-li zobrazit další možnosti, zadejte:
$ ssh_scan -h
Vzorové výstupy:

ssh_scan v0.0.19 (https://github.com/mozilla/ssh_scan) Použití: ssh_scan [options] -t, --target [IP / Range / Hostname] IP / Ranges / Hostname pro skenování -f, --file [FilePath] Cesta souboru souboru obsahujícího protokol IP / Range / Hostnames pro skenování -T, --timeout [seconds] Časový limit pro připojení, po kterém se ssh_scan vzdává hostiteli -L, --logger [Log File Path] Povolit logger -O, - -from_json [FilePath] Soubor pro čtení JSON výstupu z -o, --output [FilePath] Soubor pro zápis výstupu JSON na -p, --port port [PORT] (výchozí: 22) -P, --policy [ Soubor vlastních zásad (výchozí: Mozilla Modern) - podnáší [NUMBER] Počet pracovních podprocesů (výchozí: 5) - fingerprint-db [FILE] update-status Nekontrolovat aktualizace -u, --unit -test [SOUBOR] Házet příslušné kódy výstupu založené na stavu shody -V [STD_LOGGING_LEVEL], --verbosity -v, -version Zobrazit pouze informace o verzi -h, - -help Zobrazit tuto zprávu Příklady: ssh_scan -t 192.168.1.1 ssh_scan -t server.e xample.com ssh_scan -t :: 1 ssh_scan -t :: 1 -T 5 ssh_scan -f hosts.txt ssh_scan -o výstup.json ssh_scan -O výstup.json -o rescan_output.json ssh_scan -t 192.168.1.1 -p 22222 ssh_scan - t 192.168.1.1 -p 22222 -L výstup.log -V INFO ssh_scan -t 192.168.1.1 -P custom_policy.yml ssh_scan -t 192.168.1.1 -unit-test -P custom_policy.yml

Jak zabezpečím a optimalizuji svůj OpenSSH server?

  1. Nejlepší postupy zabezpečení OpenSSH
  2. Informace o poskytnutí správné základní zásady pro konfigurační parametry SSH naleznete na této stránce

Zdroj