Прошедший год был весьма богатым на события в мире Linux (о главных событиях 2015 года мы поговорим чуть позже). Следующий год обещает быть ещё более интересным. Поэтому желаю вам хорошего настроения, длительного аптайма, побольше качественных и нужных программ. А я продолжу показывать вам, какими возможностями можно пользоваться в мире Linux, чтобы стать повелителем своего компьютера! Всего вам наилучшего!
четверг, 31 декабря 2015 г.
воскресенье, 27 декабря 2015 г.
четверг, 17 декабря 2015 г.
Комплексная оптимизация и ускорение системы для дома
В этой заметке опишу несколько способов оптимизации Linux на десктопе, для выполнения различных задач: от простого использования в качестве домашней мультимедийной системы до рабочей станции. Операционные системы семейства GNU/Linux работают превосходно на широком спектре оборудования и эффективно потребляют ресурсы, но это же является и недостатком: система должна работать везде, потому кое-какие специфичные для конкретного оборудования оптимизации отключаются. Поэтому хорошей практикой является "подгонка" системы под свой компьютер, которая может быть либо "косметической" (обычная настройка и включение нужных параметров), так и "хардкорная" (пересборка ядра или полностью всей системы, включение новых фич процессора, оптимизация флагами компилятора и т.д.).
вторник, 15 декабря 2015 г.
Zram и Zswap или как увеличить эффективность оперативной памяти
Данная статья будет актуальна для владельцев нетбуков, компьютеров с малым количеством оперативки, людей, которые запускают много ресурсоёмких приложений, которые в свою очередь потребляют много памяти и так далее. В ядре Linux не так давно появились две замечательные технологии - zram и zswap. Опишу что это и для чего:
пятница, 11 декабря 2015 г.
SteamOS: действительно ли медленнее Windows?
В сети активно ползут утверждения, что SteamOS значительно медленнее Windows, в частности Windows 10. Однако те тесты, вызывают много сомнений. Например были выставлены не оптимальные настройки графики, и много чего ещё. Поэтому я решил провести собственные тесты и выяснить, насколько SteamOS медленнее Windows в играх, и что именно этому способствует.
пятница, 4 декабря 2015 г.
вторник, 1 декабря 2015 г.
Собираем своё собственное ядро Linux
Иногда может потребоваться собрать своё собственное ядро Linux. Причины для этого могут быть следующими:
- вам нужно чистое ядро, без дистрибутивных патчей;
- вы хотите наложить собственные патчи (коих очень много);
- вы хотите собрать ядро под свою конфигурацию железа, выкинуть из него лишнее и/или заточить под определённые задачи;
- вы хотите включить в состав ядра эксперементальный драйвер или файловую систему, которой нет в "ванильном" ядре (например ZFS или Raiser 4);
пятница, 20 ноября 2015 г.
Русский Linux: обзор Российских дистрибутивов общего назначения
GNU/Linux - мультинациональная ОС. И каждая страна создаёт свои дистрибутивы, которые используются как на рабочих станциях, так и на серверах. Россия не отстаёт, и существует несколько хороших (и не очень) дистрибутивов Linux, о которых я расскажу. При этом я расскажу о наиболее известных и популярных дистрибутивах, которые хорошо развиваются и активно используются. Поехали!
среда, 18 ноября 2015 г.
Увеличиваем интернет-безопасность с помощью DNScrypt
Эта статья написана по просьбе одного из читателей блога. И должен сказать - тема весьма интересная.
В наше время, всё более остро встаёт вопрос о защите передаваемого трафика в сети Интернет. Очень многие могут позариться на ваши данные - от злоумышленников, который всеми силами будут хотеть заполучить ваши пароли к различным сервисам, до спецслужб, которые хотят знать всё о каждом вашем шаге. И на данное время, существует большое количество "средств самообороны" в Интернете. Об одном таком простом, но весьма эффективном средстве, пойдёт речь в этой статье - DNScrypt.
В наше время, всё более остро встаёт вопрос о защите передаваемого трафика в сети Интернет. Очень многие могут позариться на ваши данные - от злоумышленников, который всеми силами будут хотеть заполучить ваши пароли к различным сервисам, до спецслужб, которые хотят знать всё о каждом вашем шаге. И на данное время, существует большое количество "средств самообороны" в Интернете. Об одном таком простом, но весьма эффективном средстве, пойдёт речь в этой статье - DNScrypt.
понедельник, 16 ноября 2015 г.
OpenMediaVault - дистрибутив для создания файлового хранилища
В наше время, всё более и более популярными становятся сетевые файловые хранилища, или NAS (Network Attached Storage). Что представляет из себя NAS? Это компьютер, с весьма скромным железом, но имеющий в себе несколько жёстких дисков, объединённых в RAID-массив. Как правило, кроме функций хранения данных, NAS обладает весьма богатым функционалом, таким как торрент-сервер, сервер потокового вещания и куча всего другого.
суббота, 14 ноября 2015 г.
Создаём приватную сеть с помощью OpenVPN
OpenVPN — свободная реализация технологии Виртуальной
Частной Сети (VPN) с открытым исходным кодом для создания зашифрованных
каналов типа точка-точка или сервер-клиенты между компьютерами. Она
позволяет устанавливать соединения между компьютерами, находящимися за
NAT-firewall, без необходимости изменения их настроек. С помощью OpenVPN можно создать локальную сеть между удалёнными офисами поверх Интернета, а также обходить различные блокировки сайтов. Предположим, в центральном офисе есть сервер, который соединён с базами данных, хранилищами данных и т.д. И нужно организовать доступ ко всему этому, для удалённых филиалов этого офиса, находящихся в разных городах. Не будем терять время, приступим.
воскресенье, 8 ноября 2015 г.
Установка и настройка сервера терминалов
Что такое сервер терминалов? Предположим, нескольким сотрудникам в вашей организации, необходимо работать с весьма ресурсоёмким ПО, но их компьютеры этого не позволяют, а денег на закупку нового оборудования, у вас нет. Но у вас есть один весьма мощный сервер (или просто компьютер), и вы можете организовать на нём терминальный сервер. В результате, все ресурсоёмкие программы будут выполняться на сервере, а на компьютеры сотрудников (которые будут являться тонкими клиентами для сервера), будет передаваться изображение и управление.
понедельник, 2 ноября 2015 г.
Android File Transfer for Linux - утилита для работы с файлами Android-устройств
Android File Transfer for Linux — свободная и стабильная реализация
протокола MTP, который используется для многих современных мобильных
устройств. Может закачивать файлы любых размеров, не
тормозит и не виснет. В отличии от других реализаций MTP в Linux, AFTL работает значительно быстрее и стабильнее.
воскресенье, 4 октября 2015 г.
воскресенье, 27 сентября 2015 г.
четверг, 17 сентября 2015 г.
Во что поиграть в Linux?
Игры - это неотъемлемая часть любой операционной системы, и GNU/Linux - не исключение. Для многих людей, наличие тех или иных игр в операционной системе - решающий фактор для её использования. Именно поэтому заядлые геймеры сидят на Windows. Но это вовсе не означает, что игровая жизнь доступна только в Windows, ведь не за горами выход игровых консолей Steam Machines, и потому многие популярные игры портируются на Линукс, или выходят сразу с его поддержкой. Но обо всём по порядку. Здесь я хочу описать те игры и игровые сервисы, которые доступны на Linux. Начнём с самого главного.
вторник, 18 августа 2015 г.
AIDE - контроль целостности ваших файлов
AIDE (Advanced Intrusion Detection Enviornment, расширенная среда обнаружения вторжений) - инструмент для проверки целостности файлов. Он создаёт снимок состояния всех файлов в системе и сохраняет его в своей базе данных, что впоследствии может использоваться для определения модификации файлов (например злоумышленниками).
пятница, 7 августа 2015 г.
SteamOS 2: новая версия игрового дистрибутива
26 июня 2015 года, началось тестирование новой ветки игрового дистрибутива Linux SteamOS, под кодовым именем "Brewmaster" (как обычно, в честь персонажа игры Dota 2). Пока данная версия ещё очень сырая, и не рекомендуется для установки, а сама Valve рекомендует использовать SteamOS 1.0 "Alchemist". Тем не менее, оценить какие новшества ждут пользователя в новой версии, можно уже сейчас.
воскресенье, 2 августа 2015 г.
Обзор дистрибутивов для старого и слабого оборудования
В данной заметке, я опишу несколько хороших дистрибутивов, которые подойдут для старого ПК или ноутбука, или просто для не слишком мощного оборудования. Как вы наверняка знаете, в случае с Windows - это всегда XP. Её ставят на все старые и маломощные ПК. Но данная "ОС" не только морально устарела, но ещё и не поддерживается разработчиками ПО. Не будет обновлений безопасности, новые программы могут отказаться работать. В случае с Linux - вы всегда будете иметь актуальные версии нужных вам программ. Поехали!
Создание сервера на Debian 8
Приветствую! В данной заметке я опишу создание базовой серверной платформы, которая может использоваться для различных целей, будь то вэб-сайт, блог, почтовый сервер, прокси-сервер и так далее. В качестве основы, будет использоваться стабильный и надёжный дистрибутив Linux Debian 8.1. Хотя данная инструкция описывает создание сервера на Debian, она также подойдёт для Ubuntu Server.
воскресенье, 19 июля 2015 г.
Устанавливаем и настраиваем Android SDK и Android Studio в Debian 8
Android является самой популярной, открытой операционной системой, основанной на ядре Linux. С каждым днём на него выходят всё больше и больше различных приложений, разработка которых весьма прибыльное занятие. Освоить разработку ПО под Андроид не сложно. В сети полным полно различной литературы, плюс куча официальной документации от Google (которая, забегая вперёд, идёт в комплекте с SDK).
суббота, 18 июля 2015 г.
Усиливаем защиту системы от внешних вторжений
четверг, 16 июля 2015 г.
Собираем игровой движок Unreal Engine 4 (обновлено)
Игровой движок Unreal Engine 4 вышел 19 марта 2014 года. Компания Epic Games объявила, что движок будет бесплатным для всех (сначала с подпиской по $19 в месяц , потом и вовсе без неё, но при условии что прибыль не превышает $3000 в квартал), а также что его исходный код будет доступен в репозитории на GitHub. Движок помимо Windows, OS X и консолей 8 поколения, имеет полную и официальную поддержку Linux.
вторник, 14 июля 2015 г.
среда, 8 июля 2015 г.
LMDE 2 - Debian с мятным вкусом
Дистрибутив Linux Mint, является одним из самых популярных и простых для новичка, дистрибутивов. Он имеет огромное количество программ, входящие в базовую поставку мультимедиа кодеки, флеш плеер и многое другое. Ну и разумеется - большое сообщество. Оригинальный Linux Mint основан на Ubuntu. LMDE - это Linux Mint, основанный на пакетной базе Debian. Чем он хорош, мы рассмотрим в данной статье.
понедельник, 6 июля 2015 г.
Лучшие эмуляторы игровых консолей в Linux
В данной статье хочу рассказать о нескольких, на мой взгляд, лучших эмуляторов игровых консолей (от Денди до PS2). Эмулятор - это программа, которая позволяет запустить приложение, созданное для другой программной или аппаратной платформы.
суббота, 4 июля 2015 г.
Гайд по настройке PulseAudio. Часть 2.
В первой части, мы рассмотрели распространённые способы настройки звукового сервера PulseAudio. В продолжении, мы рассмотрим способы устранения возможных проблем со звуком, которые также могут пригодится для профилактики.
понедельник, 22 июня 2015 г.
Настройка разрешения экрана в консоли при использовании проприетарных видеодрайверов
Наверное вы заметили, что после установки проприетарного драйвера Nvidia или Ati, разрешение в консоли tty, а также во время начальной загрузки, стало очень низким. Всё дело в том, что проприетарные драйвера не поддерживают KMS (Kernel Modesetting) - важный компонент, который отвечает за переключение видеорежимов в ядре.
четверг, 11 июня 2015 г.
Гайд по настройке PulseAudio. Часть первая.
PulseAudio,
ранее известный как Polypaudio, - звуковой сервер для UNIX-подобных систем (Linux, BSD и прочих) и
Windows. Это замена звуковому серверу ESD с намного меньшим временем
задержки, лучшим качеством микширования и дискретизации и лучшей общей
архитектурой.
Вот некоторые возможности PulseAudio:
среда, 10 июня 2015 г.
Устраняем тормоза системы при операциях ввода-вывода, или вспомним о #12309
Баг #12309 - самый знаменитый баг в ядре Linux, довольно долго досаждавший пользователям Linux на десктопах. Сам баг исправлен в ядре Linux 3.3, но симптомы, похожие на таковые при 12309, могут проявляться на некоторых конфигурациях до сих пор. В сети можно найти много инструкций по лечению этих симптомов. Приведу в пример статью с сайта linux.org.ru, оригинал которой можно найти по ссылке с некоторыми дополнениями.
На самом деле 12309 — это не один, а несколько багов, смешанных в кучу. Можно выделить следующие случаи появления:
при копировании больших объемов данных с диска на диск (или с раздела на раздел одного диска);
при нехватке ОЗУ (и, соответственно, диком своппинге);
при копировании на USB-девайсы;
при использовании зашифрованных разделов;
Соответственно, фиксы тоже будут разные.
Сначала тест: восприимчива ли ваша система к 12309? введите в терминале:
dd if=/dev/zero of=/tmp/test bs=1M count=1M
и понаблюдайте за отзывчивостью системы. Если всё по-прежнему быстро - то читать статью можно разве что для профилактики и расширения кругозора.
Оптимистическое выделение памяти
Возможно, в научных программах какого-нибудь толка позволить выделить терабайт ОЗУ при наличии 3 Гб физической памяти и считается приемлемым, но на десктопе, где много процессов должны спокойно сосуществовать, такой расклад неприемлем — зажравшаяся программа спокойно вытеснит все остальное, после чего система практически остановится. Хуже всего то, что суть бага 12309 в том, что ядро принимает решения о том, какие страницы вытеснять, мягко говоря, неоптимально, а чинить это долго, муторно, и не в каждой ситуации решение будет приемлемым.
То есть стратегии вытеснения страниц нужно делать переключаемыми, а это работы на много времени не столько реализации, сколько тестирования.
Пока что же можно сделать так, чтобы на явно дикие запросы malloc() отвечал решительным отказом, и чтобы зажратость программы определялась на этапе выделения памяти, а не тогда, когда программа радостно вывалит туда пару гигабайт данных.
Для этого нужно прописать в /etc/sysctl.conf
vm.overcommit_memory = 2
Максимум памяти, который можно будет выделить, будет равен в сумме
объему свопа + некоторому проценту физической памяти. Этот процент по
умолчанию равен 50, но можно его несколько увеличить. Во всяком случае, я
выставил его в 80 и пока что катастроф нет.
vm.overcommit_ratio = 80
Подкачка нужна
Некоторые люди полагают, что если отключить своп, то 12309 исчезнет. А вот как бы не так. Своп (swap) — это хранилище анонимных страниц памяти. Код исполняемых программ и всяких библиотек не анонимен и по умолчанию не изменяем. В то время как на 32-битных системах исполняемый код зачастую зависим от позиции (начального адреса), что приводит к тому, что, во-первых, динамический линковщик проводит вычисление смещений каждый раз при загрузке и, соответственно, страницы кода анонимны (это несет с собой недостаток в виде наличия нескольких копий одной и той же библиотеки, но и преимущество в виде невозможности вытеснить страницы кода для освобождения памяти), то на 64-битных системах практически весь код линкуется в независимом от позиции виде (PIC).
Это означает, что, во-первых, загрузка такого кода — это фактически всего лишь mmap() на исполняемый файл, во-вторых, можно держать только одну копию страниц кода на каждый процесс, сколько раз его ни загружай. Это достоинства. Недостаток в том, что даже при отсутствии свопа ядро может в случае нехватки освободить память за счет страниц со спящим кодом. Когда код надо будет выполнять, поднимать его надо будет с диска, и хорошо бы тогда иметь место в очереди ввода-вывода, а то система встанет в неудобную позу, причем надолго.
Так как ядро, вообще-то, достаточно умное, чтобы сначала при возможности сбросить в своп анонимные страницы спящих процессов, то своп лучше все же иметь. Чаще всего доставать этих страниц надо будет меньше (особенно в случае Xorg и его драйверов, не путать с драйверами ядра).
Уменьшение размеров дисковых буферов
С одной стороны, отдавать под дисковые буферы практически всю свободную память — здравая идея. А с другой стороны, чем больше ОЗУ, на самом деле, тем сильнее это способно ударить в критической ситуации.
Это работает вот как. У ядра есть буфер файловой системы. Мы пишем много данных. Этот буфер заполняется грязными страницами, а потом выполняется системный вызов sync() и буфер сбрасывается на носитель. Чем больше буфер, тем больше данных надо будет сбрасывать. Все бы ничего, да вот когда кому-то вдруг вздумается выделить себе памяти, в первую очередь будут сбрасываться все эти буферы, и если при этом вдруг надо будет закачать страницы с исполняемым кодом, им опять-таки придется ждать в очереди. Опять слайдшоу, с возможной цепной реакцией.
То есть, кеш на чтение — это ничего так, а слишком большой кеш на запись способен встать поперек горла в критических случаях.
Есть еще одна неприятная особенность, связанная трудно сказать, с чем — возможно, с реализацией DMA, но вполне возможно, что не с ней, или не только с ней. Берем какой-нибудь медленный для записи носитель, типа той же USB-флешки, и пробуем записать на него данных побольше, фильм какой или что-то навроде. Мы увидим, что происходит это рывками — сначала заполняется буфер, сколько влезет, а потом весь сбрасывается, потом весь заполняется... и так далее. При этом суммарно потраченное время почему-то ощутимо больше, чем как если бы мы примонтировали носитель с -o sync, а скорость записи на, собственно, носитель невообразимо мала.
Но если уменьшить порог количества грязных блоков, после которого начнется их сброс на носитель, не до сверхмалых величин, но все же — это позволит проводить зачитку данных из источника и запись на носитель параллельными DMA-трансферами. Я у себя выставил этот объем равным 2 мегабайтам, что, с одной стороны, уменьшает количество перезаписей в случае частой смены маленьких файлов и значительно увеличивает скорость переноса больших объёмов данных. Возможно, если поиграться размером, можно найти оптимальное быстродействие, но не думаю, что буфер больше 16 мегабайт будет эффективным.
echo 2097152 >/proc/sys/vm/dirty_bytes
echo 2097152 >/proc/sys/vm/dirty_background_bytes
Для сохранения после перезагрузки, прописать в /etc/sysctl.conf
vm.dirty_bytes = 2097152
vm.dirty_background_bytes = 2097152
Стоит учесть, что кеши чтения файловой системы будут все так же занимать почти все свободное ОЗУ, но при этом запись будет осуществляться, как только блоков, помеченных на запись, наберется на 2 мегабайта.
Значение dirty_bytes должно делиться на 4096 нацело.
В результате, даже при переваривании больших объемов данных, система не заикается. Может затормозить сам процесс, который выделяет память, но отзывчивость системы не теряется.
Кеш файловых систем
Иногда бывает такая проблема: у вас относительно новое ядро, тесты с dd проходят на ура, а вот когда надо много маленьких файликов создавать/менять/убивать, например, командой dpkg, система встает колом и не может даже регистрами пошевелить.
Проблема в том, что метаинформация файловых систем тоже особым образом кешируется на уровне VFS. И это как раз хороший, годный кеш — метаинформация разбросана по диску очень в случайном порядке. Поэтому надо сказать, что если кеши и нужно сбрасывать, то кеш файловой системы — в последнюю очередь.
vm.vfs_cache_pressure = 50
По умолчанию оно почему-то 100, что просто безумно на десктопных нагрузках.
Прочие решения:
Установить параметр swappiness равным 10 или 5, чтобы подкачка задействовалась только при исчерпании 90 и 95% памяти соответственно:
sudo nano /etc/sysctl.conf
Добавить в конец vm.swappiness = 10
Сохранить и выполнить sudo sysctl -p
Сменить планировщик ввода-вывода. В такой ситуации рекомендуют использовать BFQ, но он не в основной ветке ядра, и его нужно добавлять в ядро
самому (в некоторых дистрибутивах, например Calculate Linux, BFQ по умолчанию). В остальных же случаях можно сменить планировщик на лету.
Перевесить системные прерывания на одно ядро (на многоядерном процессоре) скриптом:
#!/bin/sh
for interruption in `grep usb /proc/interrupts | awk '{print $1}'| sed 's/\://g'` ; do
echo 1 > /proc/irq/${interruption}/smp_affinity;
done
При самостоятельной сборке ядра, задействовать 100Hz таймер ядра и опцию No Force Preemption (Server) mode.
Выставить приоритет ionice для ядра 1 (realtime) для пространства пользователя (userspace) - 3.
Установить ядро с патчами для реализации режима реального времени (linux-lowlatency, есть по умолчанию в репозиториях
большинства дистрибутивов).
Подводя итог, можно отметить: самого бага давно нет, но на некоторых конфигурациях могут возникнуть его симптомы, по совершенно
разным причинам, от нехватки памяти до аппаратных проблем с дисками. Пугаться этого не стоит, ибо например в Windows, эта проблема
ещё более серьёзна, а самое главное - никак не решаемая. Система может с лёгкостью встать колом при копировании больших объёмов данных,
и её придётся перезагружать кнопкой Reset. Неоднократно с этим сталкивался. А вот симптомы 12309 удалось увидеть лишь при копировании фильма с
NTFS-раздела на старую, потрёпанную жизнью, флешку. И то потом проблему так и не удалось воспроизвести, потому списал на случайность.
Дополнительный материал:
Обзор планировщиков ввода-вывода
Статья о решении проблем с 12309 (на английском).
На самом деле 12309 — это не один, а несколько багов, смешанных в кучу. Можно выделить следующие случаи появления:
при копировании больших объемов данных с диска на диск (или с раздела на раздел одного диска);
при нехватке ОЗУ (и, соответственно, диком своппинге);
при копировании на USB-девайсы;
при использовании зашифрованных разделов;
Соответственно, фиксы тоже будут разные.
Сначала тест: восприимчива ли ваша система к 12309? введите в терминале:
dd if=/dev/zero of=/tmp/test bs=1M count=1M
и понаблюдайте за отзывчивостью системы. Если всё по-прежнему быстро - то читать статью можно разве что для профилактики и расширения кругозора.
Оптимистическое выделение памяти
Возможно, в научных программах какого-нибудь толка позволить выделить терабайт ОЗУ при наличии 3 Гб физической памяти и считается приемлемым, но на десктопе, где много процессов должны спокойно сосуществовать, такой расклад неприемлем — зажравшаяся программа спокойно вытеснит все остальное, после чего система практически остановится. Хуже всего то, что суть бага 12309 в том, что ядро принимает решения о том, какие страницы вытеснять, мягко говоря, неоптимально, а чинить это долго, муторно, и не в каждой ситуации решение будет приемлемым.
То есть стратегии вытеснения страниц нужно делать переключаемыми, а это работы на много времени не столько реализации, сколько тестирования.
Пока что же можно сделать так, чтобы на явно дикие запросы malloc() отвечал решительным отказом, и чтобы зажратость программы определялась на этапе выделения памяти, а не тогда, когда программа радостно вывалит туда пару гигабайт данных.
Для этого нужно прописать в /etc/sysctl.conf
vm.overcommit_memory = 2
Максимум памяти, который можно будет выделить, будет равен в сумме
объему свопа + некоторому проценту физической памяти. Этот процент по
умолчанию равен 50, но можно его несколько увеличить. Во всяком случае, я
выставил его в 80 и пока что катастроф нет.
vm.overcommit_ratio = 80
Подкачка нужна
Некоторые люди полагают, что если отключить своп, то 12309 исчезнет. А вот как бы не так. Своп (swap) — это хранилище анонимных страниц памяти. Код исполняемых программ и всяких библиотек не анонимен и по умолчанию не изменяем. В то время как на 32-битных системах исполняемый код зачастую зависим от позиции (начального адреса), что приводит к тому, что, во-первых, динамический линковщик проводит вычисление смещений каждый раз при загрузке и, соответственно, страницы кода анонимны (это несет с собой недостаток в виде наличия нескольких копий одной и той же библиотеки, но и преимущество в виде невозможности вытеснить страницы кода для освобождения памяти), то на 64-битных системах практически весь код линкуется в независимом от позиции виде (PIC).
Это означает, что, во-первых, загрузка такого кода — это фактически всего лишь mmap() на исполняемый файл, во-вторых, можно держать только одну копию страниц кода на каждый процесс, сколько раз его ни загружай. Это достоинства. Недостаток в том, что даже при отсутствии свопа ядро может в случае нехватки освободить память за счет страниц со спящим кодом. Когда код надо будет выполнять, поднимать его надо будет с диска, и хорошо бы тогда иметь место в очереди ввода-вывода, а то система встанет в неудобную позу, причем надолго.
Так как ядро, вообще-то, достаточно умное, чтобы сначала при возможности сбросить в своп анонимные страницы спящих процессов, то своп лучше все же иметь. Чаще всего доставать этих страниц надо будет меньше (особенно в случае Xorg и его драйверов, не путать с драйверами ядра).
Уменьшение размеров дисковых буферов
С одной стороны, отдавать под дисковые буферы практически всю свободную память — здравая идея. А с другой стороны, чем больше ОЗУ, на самом деле, тем сильнее это способно ударить в критической ситуации.
Это работает вот как. У ядра есть буфер файловой системы. Мы пишем много данных. Этот буфер заполняется грязными страницами, а потом выполняется системный вызов sync() и буфер сбрасывается на носитель. Чем больше буфер, тем больше данных надо будет сбрасывать. Все бы ничего, да вот когда кому-то вдруг вздумается выделить себе памяти, в первую очередь будут сбрасываться все эти буферы, и если при этом вдруг надо будет закачать страницы с исполняемым кодом, им опять-таки придется ждать в очереди. Опять слайдшоу, с возможной цепной реакцией.
То есть, кеш на чтение — это ничего так, а слишком большой кеш на запись способен встать поперек горла в критических случаях.
Есть еще одна неприятная особенность, связанная трудно сказать, с чем — возможно, с реализацией DMA, но вполне возможно, что не с ней, или не только с ней. Берем какой-нибудь медленный для записи носитель, типа той же USB-флешки, и пробуем записать на него данных побольше, фильм какой или что-то навроде. Мы увидим, что происходит это рывками — сначала заполняется буфер, сколько влезет, а потом весь сбрасывается, потом весь заполняется... и так далее. При этом суммарно потраченное время почему-то ощутимо больше, чем как если бы мы примонтировали носитель с -o sync, а скорость записи на, собственно, носитель невообразимо мала.
Но если уменьшить порог количества грязных блоков, после которого начнется их сброс на носитель, не до сверхмалых величин, но все же — это позволит проводить зачитку данных из источника и запись на носитель параллельными DMA-трансферами. Я у себя выставил этот объем равным 2 мегабайтам, что, с одной стороны, уменьшает количество перезаписей в случае частой смены маленьких файлов и значительно увеличивает скорость переноса больших объёмов данных. Возможно, если поиграться размером, можно найти оптимальное быстродействие, но не думаю, что буфер больше 16 мегабайт будет эффективным.
echo 2097152 >/proc/sys/vm/dirty_bytes
echo 2097152 >/proc/sys/vm/dirty_background_bytes
Для сохранения после перезагрузки, прописать в /etc/sysctl.conf
vm.dirty_bytes = 2097152
vm.dirty_background_bytes = 2097152
Стоит учесть, что кеши чтения файловой системы будут все так же занимать почти все свободное ОЗУ, но при этом запись будет осуществляться, как только блоков, помеченных на запись, наберется на 2 мегабайта.
Значение dirty_bytes должно делиться на 4096 нацело.
В результате, даже при переваривании больших объемов данных, система не заикается. Может затормозить сам процесс, который выделяет память, но отзывчивость системы не теряется.
Кеш файловых систем
Иногда бывает такая проблема: у вас относительно новое ядро, тесты с dd проходят на ура, а вот когда надо много маленьких файликов создавать/менять/убивать, например, командой dpkg, система встает колом и не может даже регистрами пошевелить.
Проблема в том, что метаинформация файловых систем тоже особым образом кешируется на уровне VFS. И это как раз хороший, годный кеш — метаинформация разбросана по диску очень в случайном порядке. Поэтому надо сказать, что если кеши и нужно сбрасывать, то кеш файловой системы — в последнюю очередь.
vm.vfs_cache_pressure = 50
По умолчанию оно почему-то 100, что просто безумно на десктопных нагрузках.
Прочие решения:
Установить параметр swappiness равным 10 или 5, чтобы подкачка задействовалась только при исчерпании 90 и 95% памяти соответственно:
sudo nano /etc/sysctl.conf
Добавить в конец vm.swappiness = 10
Сохранить и выполнить sudo sysctl -p
Сменить планировщик ввода-вывода. В такой ситуации рекомендуют использовать BFQ, но он не в основной ветке ядра, и его нужно добавлять в ядро
самому (в некоторых дистрибутивах, например Calculate Linux, BFQ по умолчанию). В остальных же случаях можно сменить планировщик на лету.
Перевесить системные прерывания на одно ядро (на многоядерном процессоре) скриптом:
#!/bin/sh
for interruption in `grep usb /proc/interrupts | awk '{print $1}'| sed 's/\://g'` ; do
echo 1 > /proc/irq/${interruption}/smp_affinity;
done
При самостоятельной сборке ядра, задействовать 100Hz таймер ядра и опцию No Force Preemption (Server) mode.
Выставить приоритет ionice для ядра 1 (realtime) для пространства пользователя (userspace) - 3.
Установить ядро с патчами для реализации режима реального времени (linux-lowlatency, есть по умолчанию в репозиториях
большинства дистрибутивов).
Подводя итог, можно отметить: самого бага давно нет, но на некоторых конфигурациях могут возникнуть его симптомы, по совершенно
разным причинам, от нехватки памяти до аппаратных проблем с дисками. Пугаться этого не стоит, ибо например в Windows, эта проблема
ещё более серьёзна, а самое главное - никак не решаемая. Система может с лёгкостью встать колом при копировании больших объёмов данных,
и её придётся перезагружать кнопкой Reset. Неоднократно с этим сталкивался. А вот симптомы 12309 удалось увидеть лишь при копировании фильма с
NTFS-раздела на старую, потрёпанную жизнью, флешку. И то потом проблему так и не удалось воспроизвести, потому списал на случайность.
Дополнительный материал:
Обзор планировщиков ввода-вывода
Статья о решении проблем с 12309 (на английском).
суббота, 6 июня 2015 г.
Установка Ubuntu на файловую систему Btrfs
Btrfs - продвинутая файловая система, разработанная компанией Oracle в
2007 году и опубликованная под лицензией GNU GPL. Изначально, целью было
создание достойного конкурента файловой системе ZFS, но впоследствии,
компания отошла от этого направления. Btrfs может похвастаться
следующими возможностями:
пятница, 5 июня 2015 г.
Подключение и настройка ИБП (Источника бесперебойного питания)
Многие
источники бесперебойного питания (далее
ИБП) имеют интерфейс для подключения к
компьютеру, для возможности безопасно
отключить его после исчерпания заряда
батареи. Как правило, это интерефейс
RS-232 (или COM-порт), но на некоторых моделях
также присутствует USB (а на новых он
единственный). У меня есть ИБП Ippon Back
Power Pro 600. Думаю многим он знаком:
среда, 3 июня 2015 г.
Установка и настройка Wine - программы для запуска приложений Windows
Wine (WINE Is Not an Emulator) – специальная программа, слой совместимости, для запуска Win32 приложений в UNIX-подобных системах. Проще говоря, эта штука позволяет запускать виндовые проги и игры в вашем уютном Линуксе :).
вторник, 2 июня 2015 г.
SteamOS
SteamOS
– это операционная система от компании
Valve, дистрибутив Linux, основанный на Debian
7 и ориентированый на использование в
консолях Valve "Steam Machines". Однако
возможна установка и на обычный ноутбук
или ПК (ведь по сути, Steam Machines это и есть
ПК). Данная ОС затачиватся разработчиками
именно для игр и мультимедиа, использует
стабильную и надёжную основу Debian и
платформу цифровой дистрибуции Steam
(разумеетяся и все его дополнительные
сервисы). Данная ОС имеет "под капотом":
понедельник, 1 июня 2015 г.
Steam в Linux
Steam
– это система цифровой доставки игрового
контента от компании Valve. Сейчас трудно
назвать Стим только магазином игр. Это
теперь целая вселенная (Steam Universe). Это и
магазин, и платформа для разработчиков,
и социальная сеть и многое другое. В
2012 году, клиент Стим вышел для Linux, и на
данный момент
Улучшение работы игр в Debian/Ubuntu/Linux Mint
Большинство
игр в Linux, расчитаны на работу в 32-х битной
системе. Следовательно, они могут не
работать или иметь проблемы с запуском
в 64-битных системах. Решение:
Обновление Debian 7 "Wheezy" до Debian 8 "Jessie"
27 апреля, вышла новая версия одного из самых популярных и стабильных дистрибутивов Linux - Debian 8, под кодовым именем "Jessie". Debian 7 "Wheezy" ещё довольно продолжительное время будет актуальным, но если вы хотите обновить свою систему до новой версии, не потеряв всех своих настроек - читаем дальше.
Раздача интернета 3G в локальную сеть
Бывает
такая ситуация, когда интернет подключён
через 3G модем, но в доме больше одного
компьютера. И всем нужен интернет. Выхода
из положения тут 3:
воскресенье, 31 мая 2015 г.
Установка Wine Staging (он же wine-compholio)
Wine Staging - это
специальная версия Wine, содержащая
возможности и багфиксы, которые пока
не могут быть приняты в основную ветку
Wine. После того, как некоторая фича в Wine
Staging покажется разработчикам Wine достаточно
стабильной и годной – её переносят в
основную ветку. Вот некоторые фичи,
доступные в Wine Staging:
Подписаться на:
Сообщения (Atom)