(from ci4e.ru)
Представляю страничку для веб-разработчиков:
Найти сами шрифты - дело нехитрое, их в сети хватает, причем не только коммерческих, но и совершенно "свободных". Найти-то я их нашел, причем, по заявлениям авторов (распространителей) шрифты были русифицированы (в наборе имелись соответствующие глифы). Но устанавливать их в своей системе совсем не хотелось. Да и далеко не у всех пользоватетлей они есть.
Так что надо было найти возможность подгружать шрифты с сервера... Эта задачка тоже доволно быстро нашла свое решение. Заодно там же обнаружилась ссылка на замечательный ресурс, позволяющий на основе одного имеющегося шрифтового файла сгенерировать полный комплект шрифтов в форматах TTF, OTF, EOT, SVG и WOFF, необходимый для кроссбраузерной загрузки шрифта с сервера! Получаемый от @FONT-FACE GENERATOR архивчик содержит все необходимые файлы шрифтов и тестовую страничку с набором символов, примером контента с использованием заданного шрифта и подробные инструкции по подключению шрифта к вашей страничке.
Так появилась мысль сделать тестовую страничку, лишенную перечисленных недостатков. А чуть позже эта мысль материализовалась.
Опыт: Linux
Эта табличка взята с ресурса linuxgude.it. Отформатирована "под себя", с прицелом в дальнейшем оставлять свои комменты по использованию команд. ;)
Клик по имени команды (выделена цветом) открывает соответствующую страничку opennet.ru
Информация о системе arch, cal, cat, clock, date, dmidecode, hdparm, lspci, lsusb, uname | |||
arch | вывести архитектуру компьютера | ||
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 | отобразить архитектуру компьютера | ||
uname -r | отобразить используемую версию ядра | ||
Выключение, Перезагрузка и Выход из системы init, logout, reboot, shutdown, telinit | |||
init 0 | выключить систему | ||
logout | покинуть сессию | ||
reboot | перезагрузка | ||
shutdown -h now | выключить систему | ||
shutdown -h 16:30 & | запланированное выключение системы на 16 часов 30 минут | ||
shutdown -c | отмена запланированного выключения системы | ||
shutdown -r now | перезагрузка | ||
telinit 0 | выключить систему | ||
Файлы и папки cd, cp, iconv, find, ln, ls, lstree, mkdir, mv, pwd, rm, rmdir, touch, tree | |||
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 | Изменение размеров всех изображений в папке, передача утилите "convert" из ImageMagick для создания уменьшенных копий изображений (предварительный просмотр) | ||
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, locate, whereis, which | |||
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, mount, umount | |||
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, dpkg-query, du, ls, rpm | |||
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, groupadd, groupdel, groupmod, grpck, newgrp, passwd, pwck, useradd, userdel, usermod | |||
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, chmod, chown, find, ls | |||
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, lsattr | |||
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, bzip2, gunzip, gzip, rar, tar, unrar, unzip, zip | |||
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, rpm2cpio,rpmbuild | |||
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 | |||
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 | |||
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, apt-cdrom, apt-get | |||
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 и т.д.) pacman | |||
pacman -S name | установить пакет 'name' и зависимые от него пакеты | ||
pacman -R name | для пакетного менеджера pacman: удаление пакета с названием "name", всех его файлов | ||
Просмотр содержимого файлов cat, head, less, more, tac, tail | |||
cat file1 | Отобразить содержимое файла начиная с первой строки | ||
head -2 file1 | Отобразить две первые строки файла | ||
less file1 | Аналогична команде "more" но позволяет перемещаться по содержимому вперед и назад | ||
more file1 | Отобразить содержимое файла постранично | ||
tac file1 | Отобразить содержимое файла начиная с последней строки | ||
tail -2 file1 | Отобразить две последнии строки файла | ||
tail -f /var/log/messages | Отобразить в реальном времени что добавляется в фаил | ||
Манипуляции с текстом cat, echo, comm, diff, grep, paste, sdiff, sed, sort | |||
cat example.txt | awk 'NR%2==1' | при выводе содержимого файла, не выводить чётные строки файла | ||
cat -n file1 | пронумеровать строки при выводе содержимого файла | ||
echo a b c | awk '{print $1}' | вывести первую колонку. Разделение, по-умолчанию, по проблелу/пробелам или символу/символам табуляции | ||
echo a b c | awk '{print $1,$3}' | вывести первую и треью колонки. Разделение, по-умолчанию, по проблелу/пробелам или символу/символам табуляции | ||
echo 'word' | tr '[:lower:]' '[:upper:]' | преобразовать символы из нижнего регистра в верхний | ||
comm -1 file1 file2 | сравнить содержимое двух файлов, не отображая строки принадлежащие файлу 'file1' | ||
comm -2 file1 file2 | сравнить содержимое двух файлов, не отображая строки принадлежащие файлу 'file2' | ||
comm -3 file1 file2 | сравнить содержимое двух файлов, удаляя строки встречающиеся в обоих файлах | ||
diff file1 file2 | сравнить два файла | ||
sdiff 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 в виде таблицы с разделителем "+" | ||
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 | отсортировать содержимое двух файлов, отображая только повторяющиеся строки | ||
Преобразование наборов символов и файловых форматов recode, dos2unix, unix2dos | |||
recode ..HTML < page.txt > page.html | конвертировать содержимое тестового файла page.txt в html-файл page.html | ||
recode -l | more | вывести список доступных форматов | ||
dos2unix filedos.txt fileunix.txt | конвертировать файл текстового формата из MSDOS в UNIX (разница в символах возврата коретки) | ||
unix2dos fileunix.txt filedos.txt | конвертировать файл текстового формата из UNIX в MSDOS (разница в символах возврата коретки) | ||
Анализ файловой системы badblocks, dosfsck, e2fsck, fsck | |||
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, mke2fs, mkfs, mkswap | |||
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, swapon | |||
mkswap /dev/hda3 | создание swap-пространства на разделе hda3 | ||
swapon /dev/hda3 | активировать swap-пространство, расположенное на разделе hda3 | ||
swapon /dev/hda2 /dev/hdb3 | активировать swap-пространства, расположенные на разделах hda2 и hdb3 | ||
Создание резервных копий (Backup) find, dd, dump, restore, rsync, tar | |||
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, cdrecord, gzip, dd, mkisofs, mount | |||
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, ethtool, host, hostname, ifconfig, ifdown, ifup, ip, iwconfig, iwlist, mii-tool, netstat, nslookup, route, echo, tcpdump, whois | |||
dhclient eth0 | включить на сетевом интерфейсе 'eth0' режим DHCP | ||
ethtool eth0 | отобразить статистику по сетевому интерфейсу eth0 | ||
host www.example.com | разрешить имя 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 www.example.com | разрешить имя 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 www.example.com | Выдаёт результаты для whois (регистратор домена, владелец сервера, проч.) | ||
Microsoft Windows networks (samba) mount, nbtscan,nmblookup smbclient, smbget | |||
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 | |||
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, kill, last, lsmod, lsof, ps, pstree, smartctl, strace, tail, top, watch | |||
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, apropos, chsh, gpg, ldd, man, mkbootdisk, wget, echo, whatis, who | |||
alias hh='history' | назначить алиас hh команде history | ||
apropos ...keyword | выводит список комманд, которые так или иначе относятся к ключевым словам. Полезно, когда вы знаете что делает программа, но не помните команду | ||
chsh | изменить командную оболочку (на след. логин в системе) | ||
chsh --list-shells | Отображение командных оболочек (не работает в Ubuntu), заменяется "less /etc/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 www.example.com | загружает рекурсивно содержимое сайта www.example.com | ||
wget -c www.example.com/file.iso | загрузить файл www.example.com/file.iso с возможностью останова и продолжения в последствии | ||
echo 'wget -c www.example.com/files.iso' | at 09:00 | начать закачку в указанное время | ||
whatis ...keyword | отображает описание действий указанной программы | ||
who -a | показывает пользователей, залогинившихся на данной машине, выводит: время последней загрузки системы, мёртвые (зомби) - процессы, процессы логина в ОС, активные процессы, созданные init (демоны), уровень выполнения, последнюю дату смены настроек часов |
Опыт: Полиграфия
Опыт: Кофе
Опыт: Каши
А это - подробные рекмендации по варке самых разных продуктов, да еще и с таймером!
Доки: Шаблоны договоров/инструкций
Опыт: Видеонаблюдение
Опыт: Плоттеры
Canon ipf605
.Рисование: Студия "Дед и внуча" 😉