Я просто налаштував екземпляр EC2 під управлінням Linux. Чи є спосіб отримати версію / розповсюдження Linux, що працює на екземплярі через термінал?
Я просто налаштував екземпляр EC2 під управлінням Linux. Чи є спосіб отримати версію / розповсюдження Linux, що працює на екземплярі через термінал?
Відповіді:
Для інформації про дистрибуцію:
cat /etc/issue
Для ядра / архітектури (як згадувалося раніше):
uname -a
/etc/issue
, оскільки це локально керований файл, який відображається перед входом у систему і може буквально бути будь-яким (або нічого). :) Наприклад, мої системи в даний час кажуть, що "системи вимагають авторизації, несанкціонований доступ є незаконним" там. Кожен, хто взагалі піклується про безпеку, напевно , не ставить всю інформацію про ідентифікаційну систему ОС у / etc / issue.
Портативна команда для Linux Standard Base-сумісних дистрибутивів (що майже все популярне) є lsb_release
. Розподіл можна отримати за допомогою "-i", а версія походить від "-r". Параметр "-s" пригнічує стовпчик імен і просто показує значення, а -a показує все, що lsb_release
знає про систему. Так, наприклад, у системі RHEL 5.5:
$ lsb_release -s -i
RedHatEnterpriseServer
$ lsb_release -s -r
5.5
$ lsb_release -a
LSB Version: :core-3.1-amd64:core-3.1-ia32:core-3.1-noarch:graphics-3.1-amd64:graphics-3.1-ia32:graphics-3.1-noarch
Distributor ID: RedHatEnterpriseServer
Description: Red Hat Enterprise Linux Server release 5.5 (Tikanga)
Release: 5.5
Codename: Tikanga
Якщо ви перебуваєте в Red Hat, SuSE, Ubuntu, Debian або будь-якому іншому, що виходить з них (Fedora, CentOS, що завгодно), ця команда буде працювати. В іншому випадку вам доведеться з’ясувати деяку інформацію, що стосується дистрибуції. Наприклад, RedHat знову встановлює пакет з іменем redhat-release
та створює файл у / etc:
$ rpm -q redhat-release
redhat-release-5Server-5.5.0.2
$ cat /etc/redhat-release
Red Hat Enterprise Linux Server release 5.5 (Tikanga)
Ось як це виглядає у щойно створеній системі (2 лютого 2017 року) системи Amazon Linux 2 - після того, як я скинув ім’я хоста:
[ec2-user@fresh-amazon-host ~]$ cat /etc/system-release
Amazon Linux release 2.0 (2017.12) LTS Release Candidate
[ec2-user@fresh-amazon-host ~]$ cat /etc/os-release
NAME="Amazon Linux"
VERSION="2.0 (2017.12)"
ID="amzn"
ID_LIKE="centos rhel fedora"
VERSION_ID="2.0"
PRETTY_NAME="Amazon Linux 2.0 (2017.12) LTS Release Candidate"
ANSI_COLOR="0;33"
CPE_NAME="cpe:2.3:o:amazon:amazon_linux:2.0"
HOME_URL="https://amazonlinux.com/"
ІМХО, ви дійсно повинні користуватися, lsb_release
якщо є. Якщо ви просто робите це візуально, lsb_release -a
це легко запам'ятовується і досить легко читається. Але якщо це не варіант, / etc / os-release заповнюється, як зазначено вище, у кількох останніх версіях ОС Linux.
-bash: lsb_release: command not found
. Я також спробував ваш другий підхід і не можу знайти нічого згаданого redhat в /etc
. Будь-які інші пропозиції?
apt-get
немає в системі. Я не бачу нічого з цим ідентифікувати rpm -qa|less
. ls -d /etc/*rel*
працювали. Я тоді nano /etc/system-release
. У файлі мені сказано, що ОС є Amazon Linux AMI release 2011.02.1.1
. Спасибі.
lsb_release
недоступний на Amazon linux, що, як правило, призводить до того, що це питання задається ... lsb_release
вимагає великої ланцюга dep, яка поставляється разом, redhat-lsb-core
і Aws вирішує залишити це - forums.aws.amazon.com/message.jspa?messageID = 519816
Це працювало для мене:
# cat /etc/os-release
NAME="Amazon Linux AMI"
VERSION="2015.03"
ID="amzn"
ID_LIKE="rhel fedora"
VERSION_ID="2015.03"
PRETTY_NAME="Amazon Linux AMI 2015.03"
ANSI_COLOR="0;33"
CPE_NAME="cpe:/o:amazon:linux:2015.03:ga"
HOME_URL="http://aws.amazon.com/amazon-linux-ami/"
cat /usr/share/doc/system-release/ReleaseNotes.txt
. Це, ймовірно, працює на новіших виданнях.
Як ви бачите при вході в AMI EC2 Amazon Linux AMI:
"Дивіться / usr / share / doc / system-release / для останніх нотаток до випуску."
Отже ... просто введіть:
cat /usr/share/doc/system-release/ReleaseNotes.txt
Amazon Linux AMI 2011.09
.