Командная строка. Справочник администратора

Командная строка для системного администратора - как нож для повара: без него можно обойтись, но используя его, работа становится гораздо удобней. К сожалению не всегда есть возможность держать в голове все команды, полезные, но которые нужны в работе только время от времени. Список таких команд удобней держать в виде небольшого справочника, к которому в случае необходимости удобно обращаться.

Навигация по директориям

КомандаОписание
cd -Перейти в предыдущую директорию
cdПерейти в $HOME директорию
(cd dir && command)Перейти в директорию dir, выполнить команду command и вернуться в текущую директорию. конструкция && позволяет объединять команды, втрая комада выполняется только в случае успешного выполнения предыдущей команды.
pushd .Положить текущую директорию в стек, чтобы позже вернуться к ней с помощью popd
popdдостать из стека директорию.
alias l='ls -l --color=auto'Быстрое отображение содержимого директории.
Затем достаточно ввести команду l и нажать Enter
ls -lrtСписок файлов, отсортированный по дате. См. также newest и find_mm_yyyy
ls /usr/bin | pr -T9 -W$COLUMNSНапечатать в 9 столбцов в ширину терминала
find /var/www -t d -exec chmod 755 {} \;Внутри /var/www, только для папок, Сделать права доступа 755
sudo find /var/www -t f -exec chmod 644 {} \;Внутри /var/www, только для файлов, Сделать права доступа 644
find -name '*.[ch]' | xargs grep -E 'expr'Искать ‘expr’ в текущей директории и в нижестоящих директориях. См. также findrepo
find -type f -print0 | xargs -r0 grep -F 'example'Поиск всех файлов по ‘example’ в текущей директории и ниже
find -maxdepth 1 -type f | xargs grep -F 'example'Поиск всех файлов по ‘example’ в текущей директории
find -maxdepth 1 -type d | while read dir; do echo $dir; echo cmd2; doneОбработать каждый элемент с несколькими командами (в цикле while)
find -type f ! -perm -444Найти файлы, которые не являются видимыми для всех (полезно для веб сайта)
find -type d ! -perm -111Найти директории не доступные для всех (полезно для web сайтов)
locate -r 'file[^/]*\.txt'Искать в кешированном индексе по именам.
look referenceБыстрый поиск (сортированный) словаря по префиксу
grep --color reference /usr/share/dict/wordsПодсвечивание мест где регулярное выражение появляется в словаре

Архивирование и сжатие

КомандаОписание
gpg -c fileЗашифровать файл
gpg file.gpgРасшифровать файл
tar -c dir/ | bzip2 > dir.tar.bz2Заархивировать директорию (папку) dir/
bzip2 -dc dir.tar.bz2 | tar -xРазархивировать архив (используйте gzip вместо bzip2 для файлов tar.gz)
tar -c dir/ | gzip | gpg -c | ssh user@remote 'dd of=dir.tar.gz.gpg'Создать зашифрованный архив директории (папки) dir/ на удаленном компьютере
find dir/ -name '*.txt' | tar -c --files-from=- | bzip2 > dir_txt.tar.bz2Создать архив для папки dir/ и всех вложенных папок
find dir/ -name '*.txt' | xargs cp -a --target-directory=dir_txt/ --parentsСоздать копию папки dir/ с вложенными папками
( tar -c /dir/to/copy ) | ( cd /where/to/ && tar -x -p )Скопировать (с правами доступа) папку copy/ в папку /where/to/
( cd /dir/to/copy && tar -c . ) | ( cd /where/to/ && tar -x -p )Скопировать (с правами доступа) содержимое папки copy/ в /where/to
( tar -c /dir/to/copy ) | ssh -C user@remote 'cd /where/to/ && tar -x -p' Скопировать (с правами доступа) папку copy/ на удаленный компьютер remote:/where/to
dd bs=1M if=/dev/sda | gzip | ssh user@remote 'dd of=sda.gz'Сделать резервную копию жесткого диска и послать ее на удаленный компьютер

ssh

  
КомандаОписание
ssh $USER@$HOST commandЗапустить команду command на удаленном хосте $HOST от имени пользователя $USER
(команда по умолчанию = shell)
ssh -f -Y $USER@$HOSTNAME xeyesЗапустить GUI команду на удаленном хосте $HOST от имени пользователя $USER
scp -p -r $USER@$HOST: file dir/Скопировать папку dir/ с правами доступа в домашнию папку пользователя $USER на хосте $HOST
ssh -g -L 8080:localhost:80 root@$HOSTПеренаправить соединения к $HOSTNAME:8080 наружу к $HOST:80
ssh -R 1434:imap:143 root@$HOSTПеренаправить соединения от $HOST:1434 к внутр. imap:143

wget (многоцелевой инструмент для скачивания)

  
КомандаОписание
(cd cli && wget -nd -pHEKk http://www.pixelbeat.org/cmdline.html)Сохранить веб страницу (как она открывается локально) в текущую директорию
wget -c http://www.example.com/large.fileПродолжить скачивание частично скаченного файла
wget -r -nd -np -l1 -A '*.jpg' http://www.example.com/Скачать множество файлов в текущую директорию
wget ftp://remote/file[1-9].iso/Ftp непосредственная поддержка globbing
wget -q -O- http://www.pixelbeat.org/timeline.html | grep 'a href' | headОтображать вывод напрямую (на экран)
echo 'wget url' | at 01:00Скачать url в 01:00 в текущую директорию
wget --limit-rate=20k urlСделать закачку с уменьшенной скоростью (ограничить скорость до 20 КB/s в этом примере)
wget -nv --spider --force-html -i bookmarks.htmlПроверить ссылки в файле
wget --mirror http://www.example.com/Оперативно обновлять локальную копию сайта (удобно использовать с cron)

Математические операции

Команда   Описание
echo '(1 + sqrt(5))/2' | bc -lПростая математика (Вычисление числа φ). См. также bc
echo 'pad=20; min=64; (100*10^6)/((pad+min)*8)' | bcБолее сложная (целая). Этот пример показывает максимум FastE packet rate
echo 'pad=20; min=64; print (100E6)/((pad+min)*8)' | pythonПитон занимается математическими вычислениями
echo 'pad=20; plot [64:1518] (100*10**6)/((pad+x)*8)' | gnuplot -persistНапечатать FastE packet rate против packet size
echo 'obase=16; ibase=10; 64206' | bcКонвертация систем счисления (десятичную в шестнадцатиричную)
echo $((0x2dec))Конвертация систем счисления (шестнадцатиричную в десятичную)
((арифметическое расширение shell-а))
units -t '100m/9.58s' 'miles/hour'Unit конвертация (метрической системы в имперскую)
units -t '500GB' 'GiB'Unit конвертация (SI в IEC префиксы)
units -t '1 googol'Поиск определения
seq 100 | (tr '\n' +; echo 0) | bcДобавить столбец чисел. См. также add и funcpy

rsync (Эффективный сетевой копировщик файлов: Используйте опцию –dry-run для тестирования)

КомандаОписание
rsync -P rsync://rsync.server.com/path/to/file fileТолько отобразить различия. Делайте много раз чтобы проверить прошли ли нормально закачки
rsync --bwlimit=1000 fromfile tofileСкопировать локально с предельной скоростью. Это приятно для I/O
rsync -az -e ssh --delete ~/public_html/ remote.com:'~/public_html'Зеркальный веб сайт (используется шифрование и дешифрование)
rsync -auz -e ssh remote:/dir/ . && rsync -auz -e ssh . remote:/dir/Синхронизировать текушую папку с папкой на удаленном компьютере

Сетевые команды (Обратите внимание, что команды ifconfig, route, mii-tool, nslookup устарели)

КомандаОписание
ethtool eth0Отобразить статус сетевого устройства (интерфейса) eth0
ethtool --change eth0 autoneg off speed 100 duplex fullВручную установить скорость сетевого интерфейса (устройства)
iwconfig eth1Отобразить статус беспроводного интерфейса (устройства) eth1
iwconfig eth1 rate 1Mb/s fixedВручную установить скорость беспроводного интерфейса (устройства)
iwlist scanСписок беспроводных сетей в радиусе действия
ip link showСписок сетевых интерфейсов (устройств)
ip link set dev eth0 name wanПереименовать интерфейс (устройство) eth0 в wan
ip link set dev eth0 upВключить интерфейс eth0 (чтобы выключить - down)
ip addr showСписок ip адресов интерфейсов
ip addr add 1.2.3.4/24 brd + dev eth0Добавить (или удалить) ip адрес и маску (255.255.255.0)
ip route showВывести таблицу маршрутизации
ip route add default via 1.2.3.254Установить 1.2.3.254 в качестве шлюза по умолчанию
tc qdisc add dev lo root handle 1:0 netem delay 20msecДобавить 20мс латентность к устройству loopback (для тестирования)
tc qdisc del dev lo rootУбрать латентность добавленную выше
host pixelbeat.orgПоиск ДНС ip адреса по имени хоста или наоборот
hostname -iПоиск локального ip адреса (идентично host ‘hostname’)
whois pixelbeat.orgПоиск whois информации по имени хоста или ip адресу
netstat -tuplСписок интернет сервисов в системе
netstat -tupСписок активных соединений к системе (от системы)
netstat -a список сетевых соединений
netstat -an список сетевых соединений, без определения доменного имени хоста
netstat -anp список сетевых соединений, без определения имени хоста, процесс
smbtreeНайти windows компьютеры в сети. См. также findsmb
nmblookup -A 1.2.3.4Найти windows (netbios) имя, ассоциируемое с ip адресом
smbclient -L windows_boxСписок shares на windows компьютере или samba сервере
mount -t smbfs -o fmask=666,guest //windows_box/share /mnt/shareСмонтировать windows share (папку с открытым доступом)
echo 'message' | smbclient -M windows_boxПослать popup сообщение на windows комьютер (отключено по умолчанию в XP sp2)
sudo pdbedit -L -vСписок пользователей Samba сервера

Манипуляции с текстом

КомандаОписание
SED 
sort -t. -k1,1n -k2,2n -k3,3n -k4,4nОтсортировать IPV4 ip адреса
echo 'Test' | tr '[:lower:]' '[:upper:]'Перевести из одного регистра в другой
tr -dc '[:print:]' < /dev/urandomОтфильтровать не печатаемые символы
history | wc -lПосчитать число строк, в данном случае в истории команд

Операции с множествами (Обратите внимание, что Вы можете export LANG=C для скорости. Это также полагает отсутствие линий дупликатов в файле)

КомандаОписание
sort file1 file2 | uniqОбъединение неотсортированных файлов
sort file1 file2 | uniq -dПересечение неотсортированных файлов
sort file1 file1 file2 | uniq -uРазность неотсортированных файлов
sort file1 file2 | uniq -uСимметрическая разность неотсортированных файлов
join -t'\0' -a1 -a2 file1 file2Объединение отсортированных файлов
join -t'\0' file1 file2Пересечение отсортированных файлов
join -t'\0' -v2 file1 file2Разность отсортированных файлов
join -t'\0' -v1 -v2 file1 file2Симметрическая разность отсортированных файлов

Календарь

КомандаОписание
cal -3Отобразить календарь
cal 9 1752Отобразить календарь для конкретного месяца года
date -d friКакая дата у текущей пятницы. См. также day
[ $(date -d "tomorrow" +%d) = "01" ] || exitЗавершить выполнение скрипта, если только сейчас не последний день месяца
date --date='25 Dec' +%AКакого числа будет рождество в текущем году
date --date='@2147483647'Перевести секунды прошедшие с epoch (1970-01-01 UTC) в дату
TZ=':America/Los_Angeles' dateСколько времени сейчас на Западном побережье США (используйте tzselect чтобы найти TZ)
echo "mail -s 'get the train' P@draigBrady.com < /dev/null" | at 17:45Напоминать по Email
echo "DISPLAY=$DISPLAY xmessage cooker" | at "NOW + 30 minutes"Напоминать в Popup окне

Информация о системе (см. также sysinfo) (’#’ означает, что для запуска нужны права root-а)

  
КомандаОписание
uname -aПоказать версию ядра и системную архитектуру
head -n1 /etc/issueПоказать название и версию дистрибутива (операционной системы)
cat /proc/partitionsПоказать все разделы, зарегистрированные в системе
grep MemTotal /proc/meminfoПоказать всю оперативную память, которую видит система
grep "model name" /proc/cpuinfoПоказать информацию о процессоре(ах) (CPU)
lspci -tvПоказать информацию о шине PCI
lsusb -tvПоказать информацию о USB
mount | column -tСписок смонтированных файловых систем в системе (херархический вывод)
dmidecode -q | lessОтобразить информацию о SMBIOS/DMI
smartctl -A /dev/sda | grep Power_On_HoursКакой промежуток времени этот диск (система) был включен (работал)
hdparm -i /dev/sdaПоказать информацию о диске sda
hdparm -tT /dev/sdaПротестировать скорость чтения на диске sda
badblocks -s /dev/sdaПротестировать на нечитаемые блоки диск sda

Locales

  
КомандаОписание
printf "%'d\n" 1234Напечатать четырехзначное число сгруппированное соответственно локали
BLOCK_SIZE=\'1 ls -lСделать чтобы ls группировала тысячи соответственно локали
echo "I live in `locale territory`"Получить информацию из базы данных локали
LANG=en_IE.utf8 locale int_prefixИскать информацию о локали для конкретной страны См. также ccodes
locale | cut -d= -f1 | xargs locale -kc | lessСписок полей, доступных в базе данных локали

Перекодирование (команды iconv, dos2unix, unix2dos устарели)

  
КомандаОписание
recode -l | lessОтобразить доступные переходы (по 1 алиасу на каждой строке)
recode windows-1252.. file_to_change.txtПеревести Windows “ansi” в локальную (текущую) кодировку (auto делает CRFL перевод)
recode utf-8/CRLF.. file_to_change.txtПеревести windows utf8 в локальную (текущую) кодирувку
recode iso-8859-15..utf8 file_to_change.txtПеревести из кодировки latin9 (западная европейская) в utf8
recode ../b64 < file.txt > file.b64Кодирование base64
recode /qp.. < file.txt > file.qpРаскодирование с кавычками
recode ..HTML < file.txt > file.htmlПеревести text в HTML
recode -lf windows-1252 | grep euroПоиск в таблице символов
echo -n 0x80 | recode latin-9/x1..dumpПоказать символ в кодировке latin9 по коду
echo -n 0x20AC | recode ucs-2/x2..latin-9/xПоказать latin-9 encoding
echo -n 0x20AC | recode ucs-2/x2..utf-8/xПоказать utf-8 encoding

CDs (операции с CD дисками)

  
КомандаОписание
gzip < /dev/cdrom > cdrom.iso.gzСохранить копию CD с данными
mkisofs -V LABEL -r dir | gzip > cdrom.iso.gzСоздать образ CD диска из содержимого директории
mount -o loop cdrom.iso /mnt/dirСмонтировать CD образ на /mnt/dir (только для чтения)
cdrecord -v dev=/dev/cdrom blank=fastОчистить CDRW
gzip -dc cdrom.iso.gz | cdrecord -v dev=/dev/cdrom -Записать CD образ (используйте dev=ATAPI -scanbus для выбора устройства записи)
cdparanoia -BСохранить аудио треки с CD в wav файлы (сохранятся в текущую папку)
cdrecord -v dev=/dev/cdrom -audio *.wavСоздать аудио диск (audio CD) из всех wav файлов,
находящихся в текущей директории (см. также cdrdao)
oggenc --tracknum='track' track.cdda.wav -o 'track.ogg'Создать ogg файл из wav файла

Мониторинг/отладка

  
КомандаОписание
tail -f /var/log/messagesМониторинг сообщений в log файле
strace -c ls >/dev/nullСумма/профиль системных вызовов, сделанных командой
strace -f -e open ls >/dev/nullСписок системных вызовов, сделанных командой
ltrace -f -e getenv ls >/dev/nullСписок библиотечных вызовов, сделанных командой
lsof -p $$Список путей, которые открывал процесс
lsof ~Список процессов, которые имеют открытые пути
tcpdump not port 22Отобразить сетевой (кроме ssh) траффик. См. также tcpdump_not_me
ps -e -o pid,args --forestИерархический список процессов
ps -e -o pcpu,cpu,nice,state,cputime,args --sort pcpu | sed '/^ 0.0 /d'Список процессов с % использования процессора
ps -e -orss=,args= | sort -b -k1,1n | pr -TW$COLUMNSСписок процессов с используемой ими памятью (См. также ps_mem.py)
ps -C firefox-bin -L -o pid,tid,pcpu,stateСписок всех потоков для конкретного процесса
ps -p 1,2Список информации о процессах с конкретными IDs (идентификаторами)
last rebootПоказать историю ребутов системы
free -mПоказать количество оставшейся оперативной памяти (-m отображает в мегабайтах)
watch -n.1 'cat /proc/interrupts'Наблюдать последовательно за изменяющимися данными
ionice -c3 bashПереводит процесс bash в режим ввода-вывода idle (режим простоя)
-c, --class class (0 for none, 1 for realtime, 2 for best-effort, 3 for idle.)

Дисковое пространство (См. также FSlint)

  
КомандаОписание
ls -lSrСписок файлов, отсортированных по размеру (файл с наибольшим размером - последний)
du -s * | sort -k1,1rn | headПоказать пользователей в текущей папке с наибольшим объемом используемых данных.
См. также dutop
df -hПоказать свободное место на смонтированных файловых системах
df -iПоказать свободные индексные дескрипторы на смонтированных файловых системах
fdisk -lПоказать размеры разделов дисков и типы (запускается от root-а)
rpm -q -a --qf '%10{SIZE}\t%{NAME}\n' | sort -k1,1nСписок всех пакетов с размером дистрибутивов (размер - в Байтах)
dpkg-query -W -f='${Installed-Size;10}\t${Package}\n' | sort -k1,1nСписок всех пакетов с размерами установки (размер - в килобайтах) для debian дистрибутивов
dd bs=1 seek=2TB if=/dev/null of=ext3.testСоздать большой тестовый файл. См. также truncate

Интерактивность (см. также горячие клавиши linux)

  
КомандаОписание
readlineРедактор строки, используемый bash, python, gnuplot, …
screenВиртуальные терминалы с возможностями открепления, …
mcМощный файл менеджер, которые может просматривать rpm, tar, ftp, ssh, …
gnuplotИнтерактивная (скриптовая) графика
linksТекстовый веб браузер

Active directory

  
ldifde -f export.ldf -d «CN=Users,DC=test,DC=home»Экспортирует все элементы из орг. Юнита Users

PowerShell

  
(Get-Item "$env:windir").creationtime 
Дастс создания директории Windows
gci d: -force | where {$_.creationtime -lt "15.11.2013" -and $_.creationtime -gt "16.11.2013"} | 
select fullname,creationtime | sort creationtime
Выводит список дочерних элементов в папке, отбирает только с датой ,удовлетворяющей критерию, сортирует по дате создания. Ключ -force инструктирует выводить также скрытые и системные файлы.

Разное

  
КомандаОписание
alias hd='od -Ax -tx1z -v'Ручной 16-ричный дамп (пример использования: hd /proc/self/cmdline | less)
alias realpath='readlink -f'Канонический путь (пример использования: realpath ~/../$USER)
set | grep $USERПоиск в текущем environment (окружении)
touch -c -t 0304050607 fileУстановить дату для файла (YYMMDDhhmm)
python -m SimpleHTTPServerОтобразить дерево текущего каталога по адресу http://$HOSTNAME:8000/
apropos whatisПоказать команды соответствующие строке. См. также threadsafe
man -t man | ps2pdf - > man.pdfСоздать pdf версию страницы мануала (man)
which commandПоказать полный путь к файлу команды
update-rc.d Управление запуском сервисов в Ubuntu Linux
update-rc.d [-n] [-f] name remove
update-rc.d [-n] name defaults [NN | SS KK]
update-rc.d [-n] name start|stop NN runlevel [runlevel]...
start|stop NN runlevel [runlevel]... . ...
update-rc.d [-n] name disable|enable [ S|2|3|4|5 ]
time commandВыполнить команду и отобразить время выполнения
time catЗапустить секундомер. Ctrl-d чтобы остановить его. См. также sw
nice infoЗапустить команду с низким приоритетом (”info” reader в данном случае)
renice 19 -p $$Установить shell (скрипту) низкий приоритет. Используется для не интерактивных задач.
disper --cycle-stages='-S : -s' --cycleПереключение между мониторами, подключенными к системе
iptables -t nat -A PREROUTING -i eth0 -p tcp --dport 5555 -j NAT --to 10.10.1.1:3389Проброс RDP пакетов снаружи во внутрь.

 

Добавить комментарий

You must have Javascript enabled to use this form.