Несколько основных команд в Linux

Информация о системе

# arch вывести архитектуру компьютера (1)
# cal 2007 отобразить календарь на 2007 год.
# cat /proc/cpuinfo отобразить информацию о CPU (центральный процессор)
# cat /proc/interrupts отобразить прерывания
# cat /proc/meminfo проверить используемую память
# cat /proc/swaps отобразить фаил(ы) swap (виртуальная память)
# cat /proc/version отобразить версию ядра
# cat /proc/net/dev отобразить сетевые карты и статистику по ним
# cat /proc/mounts отобразить примонтированные файловые системы
# clock -w сохранить текущую системную дату в BIOS (Базовая Система Ввода Вывода)
# date отобразить текущую системную дату
# date 041217002007.00 установить дату и время МесяцДеньЧасМинутаГод.Секунда
# dmidecode -q отобразить аппаратное оборудование системы (SMBIOS / DMI)
# hdparm -i /dev/hda отобразить характеристики жесткого диска
# hdparm -tT /dev/sda протестировать производительность чтения данных с жесткого диска
# lspci -tv отобразить устройства на PCI шине
# lsusb -tv отобразить устройства на USB шине
# uname -m отобразить архитектуру компьютера(2)
# uname -r отобразить используемую версию ядра


Выключение, Перезагрузка и Выход из системы

# init 0 выключить систему(2)
# logout покинуть сессию
# reboot перезагрузка(2)
# shutdown -h now выключить систему(1)
# shutdown -h 16:30 & запланированное выключение системы на 16 часов 30 минут
# shutdown -c отмена запланированного выключения системы
# shutdown -r now перезагрузка(1)
# telinit 0 выключить систему(3)

Фаилы и папки

# cd /home сменить текущую директорию на '/home'
# cd .. перейти в директорию уровнем выше
# cd ../.. перейти в директорию двумя уровнями выше
# cd перейти в домашнюю директорию
# cd ~user1 перейти в домашнюю директорию пользователя user
# cd - перейти в директорию, в которой находились до перехода в текущую директорию
# cp file1 file2 сопировать файл file1 в файл file2
# cp dir/* . копировать все файлы директории dir в текущую директорию
# cp -a /tmp/dir1 . копировать директорию dir1 со всем содержимым в текущую директорию
# cp -a dir1 dir2 копировать директорию dir1 в директорию dir2
# cp file file1 сопировать файл file1 в файл file2
# iconv -l показывает список всех известных кодировок
# iconv -f fromEncoding -t toEncoding inputFile > outputFile преобразовать символы из одной кодировки в другую
# find . -maxdepth 1 -name *.jpg -print -exec convert
# ln -s file1 lnk1 создать символическую ссылку на файл или директорию
# ln file1 lnk1 создать "жёсткую" (физическую) ссылку на файл или директорию
# ls отобразить содержимое текущей директории
# ls -F отобразить содержимое текущей директории с добавлением к именам символов, храктеризующих тип
# ls -l показать детализированое представление файлов и директорий в текущей директории
# ls -a показать скрытые файлы и директории в текущей директории
# ls *[0-9]* показать файлы и директории содержащие в имени цифры
# lstree показать дерево файлов и директорий, начиная от корня (/)
# mkdir dir1 создать директорию с именем 'dir1'
# mkdir dir1 dir2 создать две директории одновременно
# mkdir -p /tmp/dir1/dir2 создать дерево директорий
# mv dir1 new_dir переименовать или переместить файл или директорию
# pwd показать текущую директорию
# rm -f file1 удалить файл с именем 'file1'
# rm -rf dir1 удалить директорию с именем 'dir1' и рекурсивно всё её содержимое
# rm -rf dir1 dir2 удалить две директории и рекурсивно их содержимое
# rmdir dir1 удалить директорию с именем 'dir1'
# touch -t 0712250000 file1 модифицировать дату и время создания файла, при его отсутствии, создать файл с указанными датой и временем (YYMMDDhhmm)
# tree показать дерево файлов и директорий, начиная от корня (/)

Поиск фаила

# find / -name file1 найти файлы и директории с именем file1. Поиск начать с корня (/)
# find / -user user1 найти файл и директорию принадлежащие пользователю user1. Поиск начать с корня (/)
# find /home/user1 -name \*.bin Найти все файлы и директории, имена которых оканчиваются на '. bin'. Поиск начать с '/ home/user1'
# find /usr/bin -type f -atime +100 найти все файлы в '/usr/bin', время последнего обращения к которым более 100 дней
# find /usr/bin -type f -mtime -10 найти все файлы в '/usr/bin', созданные или изменённые в течении последних 10 дней
# find / -name *.rpm -exec chmod 755 '{}' \; найти все фалы и директории, имена которых оканчиваются на '.rpm', и изменить права доступа к ним
# find / -xdev -name \*.rpm найти все фалы и директории, имена которых оканчиваются на '.rpm', игнорируя съёмные носители, такие как cdrom, floppy и т.п.
# locate \*.ps найти все файлы, сожержащие в имени '.ps'. Предварительно рекомендуется выполнить команду 'updatedb'
# whereis halt показывает размещение бинарных файлов, исходных кодов и руководств, относящихся к файлу 'halt'
# which halt отображает полный путь к файлу 'halt'

Монтирование файловых систем

# fuser -km /mnt/hda2 отмонтировать устройство hda2 если оно занято
# mount /dev/hda2 /mnt/hda2 примонтировать диск с именем /dev/hda2 в папку с именем '/mnt/hda2'- перед монтированием проверьте существование папки '/mnt/hda2'
# mount /dev/fd0 /mnt/floppy примонтировать floppy disk (дисковод мягких магнитных дисков)
# mount /dev/cdrom /mnt/cdrom примонтировать cdrom / dvdrom
# mount /dev/hdc /mnt/cdrecorder примонтировать cdrw / dvdrom
# mount /dev/hdb /mnt/cdrecorder примонтировать cdrw / dvdrom
# mount -o loop file.iso /mnt/cdrom примонтировать фаил или ISO образ (ISO - образ диска в ISO формате)
# mount -t vfat /dev/hda5 /mnt/hda5 примонтировать раздел диска с Windows FAT32 фаловой системой
# mount /dev/sda1 /mnt/usbdisk примонтировать USB накопитель
# mount -t smbfs -o username=user,password=pass //WinClient/share /mnt/share монтировать сетевую файловую систему Windows (SMB/CIFS)
# umount /dev/hda2 отмонтировать диск с именем hda2 - незабудьте сначала выйти из точки монтирования '/mnt/hda2'
# umount -n /mnt/hda2 начать отмонтирование без записи в фаил /etc/mtab - используется когда фаил находится в режиме только чтение или жесткий диск переполнен

Дисковое пространство

# df -h отображает информацию о смонтированных разделах с отображением общего, доступного и используемого пространства
# dpkg-query -W -f='${Installed-Size;10}t${Package}n' | sort -k1,1n показывает размер используемого дискового пространства, занимаемое файлами deb-пакета, с сортировкой по размеру (ubuntu, debian т.п.)
# du -sh dir1 подсчитывает и выводит размер, занимаемый директорией 'dir1'
# du -sk * | sort -rn отображает размер и имена файлов и директорий, с соритровкой по размеру
# ls -lSr |more выдаёт список файлов и директорий рекурсивно с сортировкой по возрастанию размера и позволяет осуществлять постраничный просмотр
# rpm -q -a --qf '%10{SIZE}t%{NAME}n' | sort -k1,1n показывает размер используемого дискового пространства, занимаемое файлами rpm-пакета, с сортировкой по размеру (fedora, redhat и т.п.)

Пользователи и группы

# chage -E 2005-12-31 user1 установить дату окончания действия учётной записи пользователя user1
# groupadd [group] создать новую группу с именем group_name
# groupdel [group] удалить группу group_name
# groupmod -n moon sun переименовать группу moon в sun
# grpck проверяет корректность системных файлов учётных записей. Проверяется файл/etc/group
# newgrp - [group] изменяет первичную группу текущего пользователя. Если указать "-", ситуация будет идентичной той, в которой пользователь вышил из системы и снова вошёл. Если не указывать группу, первичная группа будет назначена из /etc/passwd
# passwd сменить пароль
# passwd user1 сменить пароль пользователя user1 (только root)
# pwck проверить корректность системных файлов учётных записей. Проверяются файлы /etc/passwd и /etc/shadow
# useradd -c "User Linux" -g admin -d /home/user1 -s /bin/bash user1 создать пользователя user1, назначить ему в качестве домашнего каталога /home/user1, в качестве shell'а /bin/bash, включить его в группу admin и добавить комментарий User Linux
# useradd user1 создать пользователя user1
# userdel -r user1 удалить пользователя user1 и его домашний каталог
# usermod -c "User FTP" -g system -d /ftp/user1 -s /bin/nologin user1 изменить атрибуты пользователя

Права на файлы

# chgrp group1 file1 сменить группу-владельца файла file1 на group1
# chmod ugo+rwx directory1 добавить полномочия на директорию directory1 ugo(User Group Other)+rwx(Read Write eXecute) - всем полные права. Аналогичное можно сделать таким образом chmod 777 directory1
# chmod go-rwx directory1 отобрать у группы и всех остальных все полномочия на директорию directory1
# chmod u+s /bin/file1 назначить SUID-бит файлу /bin/binary_file. Это даёт возможность любому пользователю запускать на выполнение файл с полномочиями владельца файла.
# chmod u-s /bin/file1 снять SUID-бит с файла /bin/binary_file
# chmod g+s /home/public назначить SGID-бит директории /home/public
# chmod g-s /home/public снять SGID-бит с директории /home/public
# chmod o+t /home/public назначить STIKY-бит директории /home/public. Позволяет удалять файлы только владельцам
# chmod o-t /home/public снять STIKY-бит с директории /home/public
# chown user1 file1 назначить владельцем файла file1 пользователя user1
# chown -R user1 directory1 назначить рекурсивно владельцем директории directory1 пользователя user1
# chown user1:group1 file1 сменить владельца и группу владельца файла file1
# find / -perm -u+s найти, начиная от корня, все файлы с выставленным SUID
# ls -lh просмотр полномочий на файлы и директории в текущей директории
# ls /tmp | pr -T5 -W$COLUMNS вывести содержимое директории /tmp и разделить вывод на пять колонок

Специальные атрибуты в файлах

# chattr +a file1 позволить открывать файл на запись только в режиме добавления
# chattr +c file1 позволяет ядру автоматически сжимать/разжимать содержимое файла
# chattr +d file1 указавет утилите dump игнорировать данный файл во время выполнения backup'а
# chattr +i file1 делает файл недоступным для любых изменений: редактирование, удаление, перемещение, создание линков на него
# chattr +s file1 позволяет сделать удаление файла безопасным, т.е. выставленный атрибут s говорит о том, что при удалении файла, место, занимаемое файлом на диске заполняется нулями, что предотвращяет возможность восстановления данных
# chattr +S file1 указывает, что, при сохранении изменений, будет произведена синхронизация, как при выполнении команды sync
# chattr +u file1 данный атрибут указывает, что при удалении файла содержимое его будет сохранено и при необходимости пользователь сможет его восстановить
# lsattr показать атрибуты файлов

Архивация и сжатие фаилов

# bunzip2 file1.bz2 разжимает файл 'file1.bz2'
# bzip2 file1 сжимает файл 'file1'
# gunzip file1.gz разжимает файл 'file1.gz'
# gzip file1 сжимает файл 'file1'
# gzip -9 file1 сжать файл file1 с максимальным сжатием
# rar a file1.rar test_file создать rar-архив 'file1.rar' и включить в него файл test_file
# rar a file1.rar file1 file2 dir1 создать rar-архив 'file1.rar' и включить в него file1, file2 и dir1
# rar x file1.rar распаковать rar-архив
# tar -cvf archive.tar file1 создать tar-архив archive.tar, содержащий файл file1
# tar -cvf archive.tar file1 file2 dir1 создать tar-архив archive.tar, содержащий файл file1, file2 и dir1
# tar -tf archive.tar показать содержимое архива
# tar -xvf archive.tar распаковать архив
# tar -xvf archive.tar -C /tmp распаковать архив в /tmp
# tar -cvfj archive.tar.bz2 dir1 создать архив и сжать его с помощью bzip2(Прим.переводчика. ключ -j работает не во всех *nix системах)
# tar -xvfj archive.tar.bz2 разжать архив и распаковать его(Прим.переводчика. ключ -j работает не во всех *nix системах)
# tar -cvfz archive.tar.gz dir1 создать архив и сжать его с помощью gzip
# tar -xvfz archive.tar.gz разжать архив и распаковать его
# unrar x file1.rar распаковать rar-архив
# unzip file1.zip разжать и распаковать zip-архив
# zip file1.zip file1 создать сжатый zip-архив
# zip -r file1.zip file1 file2 dir1 создать сжатый zip-архив и со включением в него нескольких файлов и/или директорий

RPM пакеты (Fedora, Red Hat и тому подобное)

# rpm -ivh [package.rpm] установить пакет с выводом сообщений и прогресс-бара
# rpm -ivh --nodeeps [package.rpm] установить пакет с выводом сообщений и прогресс-бара без контроля зависимостей
# rpm -U [package.rpm] обновить пакет без изменений конфигурационных файлов, в случае отсутствия пакета, он будет установлен
# rpm -F [package.rpm] обновить пакет только если он установлен
# rpm -e [package] удалить пакет
# rpm -qa отобразить список всех пакетов, установленных в системе
# rpm -qa | grep httpd среди всех пакетов, установленных в системе, найти пакет содержащий в своём имени "httpd"
# rpm -qi [package] вывести информацию о конкрентном пакете
# rpm -qg "System Environment/Daemons" отобразить пакеты входящие в группу пакетов (fedora, redhat)
# rpm -ql [package] вывести список файлов, входящих в пакет
# rpm -qc [package] вывести список конфигурационных файлов, входящих в пакет
# rpm -q [package] --whatrequires вывести список пакетов, необходимых для установки конкретного пакета по зависимостям
# rpm -q [package] --whatprovides список предоставляемой функциональности
# rpm -q [package] --scripts отобразит скрипты, запускаемые при установке/удалении пакета
# rpm -q [package] --changelog вывести историю ревизий пакета
# rpm -qf /etc/httpd/conf/httpd.conf проверить какому пакету принадлежит указанный файл. Указывать следует полный путь и имя файла
# rpm -qp [package.rpm] -l отображает список файлов, входящих в пакет, но ещё не установленных в систему
# rpm --import /media/cdrom/RPM-GPG-KEY ипортировать публичный ключ цифровой подписи
# rpm --checksig [package.rpm] проверит подпись пакета
# rpm -qa gpg-pubkey проверить целостность установленного содержимого пакета
# rpm -V [package] проверить размер, полномочия, тип, владельца, группу, MD5-сумму и дату последнего изменеия пакета
# rpm -Va проверить содержимое всех пакеты установленные в систему. Выполняйте с осторожностью!
# rpm -Vp [package.rpm] проверить пакет, который ещё не установлен в систему
# rpm -ivh /usr/src/redhat/RPMS/`arch`/[package.rpm] установить пакет, собранный из исходных кодов
# rpm2cpio [package.rpm] | cpio --extract --make-directories *bin* извлечь из пакета файлы содержащие в своём имени bin
# rpmbuild --rebuild [package.src.rpm] собрать пакет из исходных кодов

YUM - средство обновления пакетов(Fedora, RedHat и тому подо

# yum -y install [package] закачать и установать пакет
# yum localinstall [package.rpm] попытаться установить пакет RPM и все зависимые от него пакеты, используя ваши репозитории
# yum -y update обновить все пакеты, установленные в систему
# yum update [package] обновить пакет
# yum remove [package] удалить пакет
# yum list вывести список всех пакетов, установленных в систему
# yum search [package] найти пакет в репозитории
# yum clean [package] очисть rpm-кэш, удалив закачанные пакеты
# yum clean headers удалить все заголовки файлов, которые система использует для разрешения зависимостей
# yum clean all очисть rpm-кэш, удалив закачанные пакеты и заголовки

DEB пакеты (Debian, Ubuntu и тому подобное)

# dpkg -i [package.deb] установить / обновить пакет
# dpkg -r [package] удалить пакет из системы
# dpkg -l показать все пакеты, установленные в систему
# dpkg -l | grep httpd среди всех пакетов, установленных в системе, найти пакет содержащий в своём имени "httpd"
# dpkg -s [package] отобразить инфрмацию о конкретном пакете
# dpkg -L [package] вывести список файлов, входящих в пакет, установленный в систему
# dpkg --contents [package.deb] отобразить список файлов, входящих в пакет, который ешё не установлен в систему
# dpkg -S /bin/ping найти пакет, в который входит указанный файл.

APT - средство управление пакетами (Debian, Ubuntu и тому по

# apt-cache search [package] возвращает список пакетов, которые соответствуют строке 'package'
# apt-cdrom install [package] установить / обновить пакет с cdrom'а
# apt-get install [package] установить / обновить пакет
# apt-get update получить обновлённые списки пакетов
# apt-get upgrade обновить пакеты, установленные в систему
# apt-get remove [package] удалить пакет, установленный в систему с сохранением файлов конфигурации
# apt-get check проверить целостность зависимостей
# apt-get clean удалить загруженные архивные файлы пакетов

Pacman packages tool (Arch, Frugalware and alike)

# pacman -S name установить пакет 'name' и зависимые от него пакеты
# pacman -R name

Просмотр содержимого файлов

# cat file1 Отобразить содержимое файла начиная с первой строки
# head -2 file1 Отобразить две первые строки файла
# less file1 Аналогична команде "more" но позволяет перемещаться по содержимому вперед и назад
# more file1 Отобразить содержимое файла постранично
# tac file1 Отобразить содержимое файла начиная с последней строки
# tail -2 file1 Отобразить две последнии строки файла
# tail -f /var/log/messages Отобразить в реальном времени что добавляется в фаил

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

# cat example.txt | awk 'NR%2==1' при выводе содержимого файла, не выводить чётные строки файла
# echo a b c | awk '{print $1}' вывести первую колонку. Разделение, по-умолчанию, по проблелу/пробелам или символу/символам табуляции
# echo a b c | awk '{print $1,$3}' вывести первую и треью колонки. Разделение, по-умолчанию, по проблелу/пробелам или символу/символам табуляции
# cat -n file1 пронумеровать строки при выводе содержимого файла
# comm -1 file1 file2 сравнить содержимое двух файлов, не отображая строки принадлежащие файлу 'file1'
# comm -2 file1 file2 сравнить содержимое двух файлов, не отображая строки принадлежащие файлу 'file2'
# comm -3 file1 file2 сравнить содержимое двух файлов, удаляя строки встречающиеся в обоих файлах
# diff file1 file2 сравнить два файла
# grep Aug /var/log/messages из файла '/var/log/messages' отобрать и вывести на стандартное устройство вывода строки, содержащие "Aug"
# grep ^Aug /var/log/messages из файла '/var/log/messages' отобрать и вывести на стандартное устройство вывода строки, начинающиеся на "Aug"
# grep [0-9] /var/log/messages из файла '/var/log/messages' отобрать и вывести на стандартное устройство вывода строки, содержащие цифры
# grep Aug -R /var/log/* отобрать и вывести на стандартное устройство вывода строки, содержащие "Aug", во всех файлах, находящихся в директории /var/log и ниже
# paste file1 file2 объединить содержимое file1 и file2 в виде таблицы: строка 1 из file1 = строка 1 колонка 1-n, строка 1 из file2 = строка 1 колонка n+1-m
# paste -d '+' file1 file2 объединить содержимое file1 и file2 в виде таблицы с разделителем "+"
# sdiff file1 file2
# sed 's/string1/string2/g' example.txt в файле example.txt заменить "string1" на "string2", результат вывести на стандартное устройство вывода
# sed '/^$/d' example.txt удалить пустые строки и комментарии из файла example.txt
# sed '/ *#/d; /^$/d' example.txt удалить пустые строки и комментарии из файла example.txt
# sed -e '1d' exampe.txt удалить первую строку из файла example.txt
# sed -n '/string1/p' отобразить только строки содержашие "string1"
# sed -e 's/ *$//' example.txt удалить пустые символы в в конце каждой строки
# sed -e 's/string1//g' example.txt удалить строку "string1" из текста не изменяя всего остального
# sed -n '1,5p' example.txt взять из файла с первой по восьмую строки и из них вывести первые пять
# sed -n '5p;5q' example.txt вывести пятую строку
# sed -e 's/00*/0/g' example.txt заменить последовательность из любого количества нулей одним нулём
# sort file1 file2 отсортировать содержимое двух файлов
# sort file1 file2 | uniq отсортировать содержимое двух файлов, не отображая повторов
# sort file1 file2 | uniq -u отсортировать содержимое двух файлов, отображая только уникальные строки (строки, встречающиеся в обоих файлах, не выводятся на стандартное устройство вывода)
# sort file1 file2 | uniq -d отсортировать содержимое двух файлов, отображая только повторяющиеся строки
# echo 'word' | tr '[:lower:]' '[:upper:]' преобразовать символы из нижнего регистра в верхний

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

# dos2unix filedos.txt fileunix.txt конвертировать файл текстового формата из MSDOS в UNIX (разница в символах возврата коретки)
# recode ..HTML < page.txt > page.html конвертировать содержимое тестового файла page.txt в html-файл page.html
# recode -l | more вывести список доступных форматов
# unix2dos fileunix.txt filedos.txt конвертировать файл текстового формата из UNIX в MSDOS (разница в символах возврата коретки)

Анализ файловой системы

# badblocks -v /dev/hda1 проверить раздел hda1 на наличие bad-блоков
# dosfsck /dev/hda1 проверить/восстановить целостность файловой системы fat раздела hda1
# e2fsck /dev/hda1 проверить/восстановить целостность файловой системы ext2 раздела hda1
# e2fsck -j /dev/hda1 проверить/восстановить целостность файловой системы ext3 раздела hda1 с указанием, что журнал расположен там же
# fsck /dev/hda1 проверить/восстановить целостность linux-файловой системы раздела hda1
# fsck.ext2 /dev/hda1 проверить/восстановить целостность файловой системы ext2 раздела hda1
# fsck.ext3 /dev/hda1 проверить/восстановить целостность файловой системы ext3 раздела hda1
# fsck.vfat /dev/hda1 проверить/восстановить целостность файловой системы fat раздела hda1
# fsck.msdos /dev/hda1 проверить/восстановить целостность файловой системы fat раздела hda1

Форматирование файловой системы

# fdformat -n /dev/fd0 форматирование флоппи-диска без проверки
# mke2fs /dev/hda1 создать файловую систему ext2 на разделе hda1
# mke2fs -j /dev/hda1 создать журналирующую файловую систему ext3 на разделе hda1
# mkfs /dev/hda1 создать linux-файловую систему на разделе hda1
# mkfs -t vfat 32 -F /dev/hda1 создать файловую систему FAT32 на разделе hda1
# mkswap /dev/hda3 создание swap-пространства на разделе hda3

Файловая система SWAP

# mkswap /dev/hda3 создание swap-пространства на разделе hda3
# swapon /dev/hda3 активировать swap-пространство, расположенное на разделе hda3
# swapon /dev/hda2 /dev/hdb3 активировать swap-пространства, расположенные на разделах hda2 и hdb3

Создание резервных копий (Backup)

# find /var/log -name '*.log' | tar cv --files-from=- | bzip2 > log.tar.bz2 поиск в /var/log всех файлов, имена которых оканчиваются на '.log', и создание bzip-архива из них
# find /home/user1 -name '*.txt' | xargs cp -av --target-directory=/home/backup/ --parents поиск в /home/user1 всех файлов, имена которых оканчиваются на '.txt', и копирование их в другую директорию
# dd bs=1M if=/dev/hda | gzip | ssh user@ip_addr 'dd of=hda.gz' сделать "слепок" локального диска в файл на удалённом компьютере через ssh-туннель
# dd if=/dev/sda of=/tmp/file1 бэкапит содержимое жесткого диска в файл file1
# dd if=/dev/hda of=/dev/fd0 bs=512 count=1 создать копию MBR (Master Boot Record) с /dev/hda на флоппи-диск
# dd if=/dev/fd0 of=/dev/hda bs=512 count=1 восстановить MBR с флоппи-диска на /dev/hda
# dump -0aj -f /tmp/home0.bak /home создать полную резервную копию директории /home в файл /tmp/home0.bak
# dump -1aj -f /tmp/home0.bak /home создать инкрементальную резервную копию директории /home в файл /tmp/home0.bak
# restore -if /tmp/home0.bak восстановить из резервной копии /tmp/home0.bak
# rsync -rogpav --delete /home /tmp синхронизировать /tmp с /home
# rsync -rogpav -e ssh --delete /home ip_address:/tmp синхронизировать через SSH-туннель
# rsync -az -e ssh --delete ip_addr:/home/public /home/local синхронизировать локальную директорию с удалённой директорией через ssh-туннель со сжатием
# rsync -az -e ssh --delete /home/local ip_addr:/home/public синхронизировать удалённую директорию с локальной директорией через ssh-туннель со сжатием
# tar -Puf backup.tar /home/user создать инкрементальную резервную копию директории '/home/user' в файл backup.tar с сохранением полномочий
# ( cd /tmp/local/ && tar c . ) | ssh -C user@ip_addr 'cd /home/share/ && tar x -p' копирование содержимого /tmp/local на удалённый компьютер через ssh-туннель в /home/share/
# ( tar c /home ) | ssh -C user@ip_addr 'cd /home/backup-home && tar x -p' копирование содержимого /home на удалённый компьютер через ssh-туннель в /home/backup-home
# tar cf - . | (cd /tmp/backup ; tar xf - ) копирование одной директории в другую с сохранением полномочий и линков

CDROM

# cd-paranoia -B Перенести аудио-треки с компакт-диска в wav-файлы.
# cd-paranoia -- Перенести три аудио-трека с компакт-диска в wav-файлы.
# cdrecord -v gracetime=2 dev=/dev/cdrom -eject blank=fast -force Очистить перезаписываемый компакт-диск.
# cdrecord -v dev=/dev/cdrom cd.iso Записать ISO-образ на компакт-диск.
# gzip -dc cd_iso.gz | cdrecord dev=/dev/cdrom - Записать сжатый ISO-образ на компакт-диск.
# cdrecord --scanbus Сканировать системную шину, чтобы найти идентификаторы каналов SCSI.
# dd if=/dev/hdc | md5sum Посчитать контрольную сумму MD5 на устройстве, например, компакт-диске.
# mkisofs /dev/cdrom > cd.iso Создать ISO-образ компакт-диска.
# mkisofs /dev/cdrom | gzip > cd_iso.gz Создать сжатый ISO-образ компакт-диска.
# mkisofs -J -allow-leading-dots -R -V Создать ISO-образ из содержимого директории.
# mount -o loop cd.iso /mnt/iso Смонтировать ISO-образ компакт-диска в файловую систему.

Сети (LAN / WiFi)

# dhclient eth0 включить на сетевом интерфейсе 'eth0' режим DHCP
# ethtool eth0 отобразить статистику по сетевому интерфейсу eth0
# host http://www.example.com разрешить имя http://www.example.org хоста в ip-адрес и наоборот
# hostname отобразить имя компьютера
# ifconfig eth0 отобразить настройку сетевой карты eth0
# ifconfig eth0 192.168.1.1 netmask 255.255.255.0 Настроить IP адрес и маску подсети для сетевого интерфейса eth0
# ifconfig eth0 promisc перевести интерфейс eth0 в promiscuous-режим для "отлова" пакетов (sniffing)
# ifdown eth0 отключить сетевой интерфейс 'eth0'
# ifup eth0 включить сетевой интерфейс 'eth0'
# ip link show отобразить статус связи всех сетевых интерфейсов
# iwconfig eth1 показать конфигурацию беспроводного сетевого интерфейса eth1
# iwlist scan просканировать эфир на предмет, доступности беспроводных точек доступа
# mii-tool eth0 отобразить статус связи для сетевого интерфейса 'eth0'
# netstat -tup отображает все установленные сетевые соединения по протоколам TCP и UDP без разрешения имён в ip-адреса и PID'ы и имена процессов, обеспечивающих эти соединения
# netstat -tupl отображает все сетевые соединения по протоколам TCP и UDP без разрешения имён в ip-адреса и PID'ы и имена процессов, слушающих порты
# netstat -rn показать таблицу маршрутизации, как командой "route -n"
# nslookup http://www.example.com разрешить имя http://www.example.org хоста в ip-адрес и наоборот
# route -n вывести локальную таблицу маршрутизации
# route add -net 0/0 gw IP_Gateway задать ip-адрес шлюза по умолчанию (default gateway)
# route add -net 192.168.0.0 netmask 255.255.0.0 gw 192.168.1.1 добавить статический маршрут в сеть 192.168.0.0/16 через шлюз с ip-адресом 192.168.1.1
# route del 0/0 gw IP_gateway удалить ip-адрес шлюза по умолчанию (default gateway)
# echo "1" > /proc/sys/net/ipv4/ip_forward разрешить пересылку пакетов (forwarding)
# tcpdump tcp port 80 отобразить весь трафик на TCP-порт 80 (обычно - HTTP)
# whois http://www.example.com

Microsoft Windows networks (samba)

# mount -t smbfs -o username=user,password=pass //WinClient/share /mnt/share смонтировать smb-ресурс, предоставленный на windows-машине, в локальную файловую систему
# nbtscan ip_addr разрешить netbios-имя nbtscan не во всех системах ставится по-умолчанию, возможно, придётся доустанавливать вручную. nmblookup включен в пакет samba
# nmblookup -A ip_addr разрешить netbios-имя nbtscan не во всех системах ставится по-умолчанию, возможно, придётся доустанавливать вручную. nmblookup включен в пакет samba
# smbclient -L ip_addr/hostname отобразить ресурсы, предоставленные в общий доступ на windows-машине
# smbget -Rr smb://ip_addr/share подобно wget может получить файлы с windows-машин через smb-протокол

IPTABLES (firewall)

# iptables -t filter -L отобразить все цепочки правил
# iptables -t nat -L отобразить все цепочки правил в NAT-таблице
# iptables -t filter -F очистить все цепочки правил в filter-таблице
# iptables -t nat -F очистить все цепочки правил в NAT-таблице
# iptables -t filter -X удалить все пользовательские цепочки правил в filter-таблице
# iptables -t filter -A INPUT -p tcp --dport telnet -j ACCEPT позволить входящее подключение telnet'ом
# iptables -t filter -A OUTPUT -p tcp --dport http -j DROP блокировать исходящие HTTP-соединения
# iptables -t filter -A FORWARD -p tcp --dport pop3 -j ACCEPT позволить "прокидывать" (forward) POP3-соединения
# iptables -t filter -A INPUT -j LOG --log-prefix включить журналирование ядром пакетов, проходящих через цепочку INPUT, и добавлением к сообщению префикса "DROP INPUT"
# iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE включить NAT (Network Address Translate) исходящих пакетов на интерфейс eth0. Допустимо при использовании с динамически выделяемыми ip-адресами.
# iptables -t nat -A PREROUTING -d 192.168.0.1 -p tcp -m tcp --dport 22 -j DNAT --to-destination 10.0.0.2:22 перенаправление пакетов, адресованных одному хосту, на другой хост

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

# free -m показать состояние оперативной памяти в мегабайтах
# kill -9 process_id "убить" процесс с PID process_id(номер, на "PS-EF") "на смерть" (без соблюдения целостности данных)
# kill -1 process_id заставить процесс с PID process_id(номер, на "PS-EF") перепрочитать файл конфигурации
# last reboot отобразить историю перезагрузок системы
# lsmod вывести загруженные модули ядра
# lsof -p process_id отобразить список файлов, открытых процессом с PID
# lsof /home/user1 отобразить список открытых файлов из директории /home/user1
# ps -eafw отобразить запущенные процессы, используемые ими ресурсы и другую полезную информацию (единожды)
# ps -e -o pid,args --forest вывести PID'ы и процессы в виде дерева
# pstree отобразить дерево процессов
# smartctl -A /dev/hda контроль состояния жёсткого диска /dev/hda через SMART
# smartctl -i /dev/hda проверить доступность SMART на жёстком диске /dev/hda
# strace -c ls >/dev/null вывести список системных вызовов, созданных и полученных процессом ls
# strace -f -e open ls >/dev/null вывести вызовы бибилотек
# tail /var/log/dmesg вывести десять последних записей из журнала загрузки ядра
# tail /var/log/messages вывести десять последних записей из системного журнала
# top отобразить запущенные процессы, используемые ими ресурсы и другую полезную информацию (с автоматическим обновлением данных)
# watch -n1 'cat /proc/interrupts' отображать прерывания в режиме реального времени

Другие полезные команды

# alias hh='history' назначить алиас hh команде history
# apropos ...keyword выводит список комманд, которые так или иначе относятся к ключевым словам. Полезно, когда вы знаете что делает программа, но не помните команду
# chsh
# chsh --list-shells
# gpg -c file1 шифрует файл file1 с помощью GNU Privacy Guard
# gpg file1.gpg дешифрует файл file1 с помощью GNU Privacy Guard
# ldd /usr/bin/ssh вывести список библиотек, необходимых для работы ssh
# man ping вызов руководства по работе с программой, в данном случае, - ping
# mkbootdisk --device /dev/fd0 `uname -r` создаёт загрузочный флоппи-диск
# wget -r http://www.example.com загружает рекурсивно содержимое сайта http://www.example.com
# wget -c http://www.example.com/file.iso загрузить файл http://www.example.com/file.iso с возможностью останова и продолжения в последствии
# echo 'wget -c http://www.example.com/files.iso' | at 09:00 начать закачку в указанное время
# whatis ...keyword отображает описание действий указанной программы
# who -a