Примитивная защита WordPress на Nginx

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

location ~ /wp-admin/admin-ajax.php {
allow all;
fastcgi_pass backend;
include fastcgi_params;
gzip_static on;
}

location ~ /wp-admin/.* {
allow ваш ip;
allow другой ip;
allow 127.0.0.1;
deny all;
fastcgi_pass backend;
include fastcgi_params;
gzip_static on;
access_log /var/log/nginx/wp-admin-access_log getip;
}

location ~* ^/(wp-content/uploads|wp-content/themes|wp-content/.*\.(php|php5)$
{
access_log /var/log/nginx/deny-access_log main;
deny all;
}

Простой backup с помощью rsync

Бекапом пренебрегать не стоит. Настрой один раз и спи спокойно.
Если у вас не большой объём данных, до 10 гигабайт, то rcync то, что ван нужно.
В моём случаи я делаю бекам сайтов.

BACKUP UNIT
cd ~/.ssh
ssh-keygen -t rsa -b 4096
cat id_rsa.pub | ssh USER@SERVER_IP "cat >> ~/.ssh/authorized_keys"

Создаём скрипт который будем запускать по кронтабу.
rsync -avz \
--exclude=/*/wp-content/w3tc/ \
--exclude=/*/cache/ \
--exclude=/*/wp-content/cache-tb/ \
--exclude=/*/wp-content/cache/ \
-e ssh USER@SERVER_IP:/path-to-www/ /path-to-storage/

—exclude исключаем директории которые не будут копироваться. В моём случае это сайты на WordPress.

Можно добавить опцию —delete, что бы удалялись файлы которые были удалены на сервере. Но если злоумышленник удалить ваш сайт, а бекап запуститься по крону, то файлы пропадут и у вас.

На этом всё.

Восстановление root в MySQL

Добавляем в my.cnf, секция [mysqld] строку:
skip-grant-tables
Перезапускаем базу и логинемя по рутом
mysql -u root mysql
Меняем пароль рута
UPDATE USER SET password=password('YOUR_NEW_PASS') WHERE USER='root' AND host='localhost';
Убираем из my.cnf «skip-grant-tables» и ещё раз перезапускаем базу.
Всё, дело сделано!

Как добавить русскую locale

Что бы wine поддерживал русский софт, частенько требуется добавить русскую локаль.

1. Для начало проверяем какие локали поддерживаются :
less /usr/share/i18n/SUPPORTED

2. добавляем нужную (например русскую) :
locale-gen ru_RU.cp1251 && locale-gen ru_RU.utf8

Вот и всё.

Nginx + Joomla + sh404sef

Nginx + Joomla + sh404sef

Знакомый ведёт пару блогов используя cms Joomla с плагином для ЧПУ sh404sef. При переезде на новый хостинг вылезла проблема связанная с обработкой ЧПУ. Ссылки в конце которых присутствовал слеш не обрабатывались и кидали ошибку. Все конфигурации которые предлагались в интернете для Joomla + sh404sef + nginx не давали положительных результатов. Пришлось писать своё.

Как запустить Joomla с плагином sh404sef на nginx:

    server {
    listen 11.22.33.44;
    server_name site.ru www.site.ru;
    root /www/site.ru;
    index index.php;

    location / {
    error_page 404 = @joomla;
    log_not_found off;
    }

    location @joomla {
    rewrite ^(.*)$ /index.php?q=$1 last;
    }

    location ~ .php$ {
    expires epoch;
    fastcgi_next_upstream error timeout http_500;
    fastcgi_intercept_errors on;
    fastcgi_pass 127.0.0.1:8888;
    fastcgi_index index.php;
    fastcgi_param SCRIPT_FILENAME /www/site.ru/$fastcgi_script_name;
    include fastcgi_params;
    }
    }

Рекурсивное удаление большого колличесва фалов

Понадобилось удалить статистику за 2007 год. Размер диска 140 гигабайт, 18 миллионов инодов были использованы, что составляет 100%.

[sourcecode language=»powershell»]# find . -maxdepth 3 -type d -name year_2007 -print0 -exec rm -rdf {} \;[/sourcecode]

Установка vnStat на FreeBSD. Консольный монитор трафика

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

Инсталлируем из портов VnStat
[sourcecode language=»powershell»]# cd /usr/ports/net/vnstat && make install clean && rehash[/sourcecode]

Теперь надо чуть-чуть поправить конфиг, указав ваш интерфейс.
[sourcecode language=»powershell»]# mv /usr/local/etc/vnstat.conf.sample /usr/local/etc/vnstat.conf
# vi /usr/local/etc/vnstat.conf[/sourcecode]

В моём случае:
[sourcecode language=»powershell»]Interface "bge0"
MaxBandwidth 100[/sourcecode]
Читать далее

Настройка Speed Duplex на FreeBSD

Проблема случилась на выделенном сервере в Канаде. Пропуская способность сервера ограничивалась 30 kBps. Общение с саппортом никаких результатов не принёсло.
Проблема оказалась в сетевых настройках.
[sourcecode language=»powershell»]
# ifconfig | grep media
media: Ethernet 10baseT/UTP
[/sourcecode]

Решение очень простое.
Добвавил в /etc/rc.conf следующие:

ifconfig_sk0="inet x.x.x.x netmask y.y.y.y media 100baseTX mediaopt full-duplex"

Делаее перезапускаем сеть.
[sourcecode language=»powershell»]
# /etc/rc.d/netif restart
[/sourcecode]