PostgreSQL: ограничиваем время выполнения запроса

Категории: Разработка
db=> set statement_timeout to 100;  
SET  
db=> select pg_sleep(110);  
ERROR:  canceling statement due to statement timeout  
db=> set statement_timeout to 0;  
SET  
db=> 

Первым выражением установим максимальное время выполнения запроса в миллисекундах. Вторым пойдет запрос, а третьим мы снимем ограничение на время выполнения (0 - значение по умолчанию).

Дока.

OpenSUSE и шрифты

Категории: HowTo

Сравнение шрифтов. Слева шрифт без нормально настроенного рендеринга, а справа - с нормально настроенным.

Сравнение шрифтов. Слева шрифт без нормально настроенного рендеринга, а справа - с нормально настроенным.

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

Как раз на картинке видно две ситуации:

  • слева дефолтный рендеринг шрифтов “искаропки”
  • справа - допиленный рендеринг infinality (который всячески нахваливают)

Осталось его лишь настроить.

zypper ar http://download.opensuse.org/repositories/home:/nick31:/INFINALITY-ULTIMATE/openSUSE_13.2/ subpixel  
zypper mr -p 98 subpixel  
zypper ref && sudo zypper dup  
zypper in libfreetype6 libfreetype6-32bit

К слову, репозитарий выше - это единственный рабочий репозитарий с обновляемым (с нормальной скоростью) freetype и другими плюшками.

После этого можно поставить шрифт ubuntu (он даже нормально выглядит) или cantarell.

Linux и запись вебкастов

Категории: HowTo

Довольно долго искал, чем же можно нормально писать вебинары.

В итоге остановился на vokoscreen.

Vokoscreen

Из достоинств:

  • выбор объект для записи (отдельный монитор, отдельное окно, область экрана);
  • выбор источника записи звука;
  • настройка формата получаемого видео (все равно видео потребует дальнешего редактирование, но приятно);
  • простой и безглючный интерфейс.

Да. Можно и из консоли писать, но при записи неудобно задавать набор опций, которые как раз дают возможность выбирать объект для захвата.

Даже если запись изначально прошла удачно, то итоговый файл все равно мало пригоден для аплоада на ютуб или куда-нибдь еще (для разрешения 1920х1080 и 60 минутах записи объем итогового файла перевалит далеко за 2 гига).

Поэтому можно воспользоваться кодемо ffmpeg. Для меня подошли следующие опции.

ffmpeg -i input.mkv -vcodec libx264 -strict -2 -crf 20 -threads 7 -r 25 output.mp4  

Где:

  • -i input.mkv - исходный файл
  • -vcodec libx264 - кодек видео x264
  • -strict -2 - этот набор опций включает поддержку эекспериментального энкодера aac
  • -crf 20 - опция энкодера, которая задает степень сжатия (в мануале - это квантование). от 0 до 51. 0 - лучшее качество картинки, а 51 - наихудшее.
  • -threads 7 - количество потоков (равно количество реально-виртуальных ядер минус один. в таком случае можно за компьютером еще что-то делать)
  • -r 25 - кадры в секунду для выходного видео
  • output.mp4 - куда пишем

Подробный мануал по кодирования x264.

JavaScript и области видимости

Категории: Разработка

Об этой особенности полезно иногда вспоминать.

// глобальная переменная, которую мы попытаемся дальше получить  
var bar = 42;

// Мозг предполагает, что до объявления bar в теле функциии глобальный bar будет доступен  
function simple_define() {  
 alert(bar);  
 var bar = 10;  
 alert(bar);  
}

// Но это не так. Функция выше на самом деле выглядит вот так  
function real_define() {  
 var bar;  
 alert(bar);  
 bar = 10;  
 alert(bar);  
}

// А что же с условиями? Разве они не создают локальные области видимости?  
function define_inside_if() {  
 if (true) {  
 var bar = -10;  
 }

alert(bar);  
}

// Ну а циклы?  
function define_inside_while() {  
 do {  
 var bar = 10;  
 } while (false);  
 alert(bar);  
}

// И переменные из for?  
function define_inside_for() {  
 for (var bar = 0; bar < 10; bar++);  
 alert(bar);  
}

/*  
 * Да. Это особенность js - компилятор собирает все объявления переменных текущей области видимости  
 * и выделяет под них все требуемые ресурсы сразу при входе в функцию.  
 */

Многопоточная компрессия и tar

Категории: HowTo

Сколько можно? :) Ядер все больше и больше, а

$ tar -cjf /mnt/_backup/`date '+%Y-%m-%d_%H-%M-%S'`.tbz2 /home

как работал в один поток, так и работает.

Есть два многопоточных решения:

  • pbzip2 - параллельный bzip
  • pigz - параллельный gzip
$ tar -c /home | pbzip2 -vc -9 -p7 /mnt/_backup/`date '+%Y-%m-%d_%H-%M-%S'`.tbz2

Опцией -p# можно управлять количеством ядер, которые будет использовать архиватор. Нормально - это N-1.

Аналогично и для gzip

$ tar -c /home | pigz -vc -9 -p7 /mnt/_backup/`date '+%Y-%m-%d_%H-%M-%S'`.tbz2

С удивлением открыл для себя, что - в bash по дефолту означает stdout. И

$ tar -cf - file

будет использовать в качестве файла stdout. :)