вторник, 19 ноября 2013 г.

POSTGRES backup and restore

Важно!!!
Все операции с базами производятся в зависимости от настроек  доступа в файле
/etc/postgresql/9.3/main/pg_hba.conf
для без парольного доступа необходимо установить режим TRUST


Возможна необходимость смены пароля пользователю postgress
ALTER USER postgres PASSWORD 'newpassword';

Full backup:
pg_dumpall > outfile

with compress:
pg_dumpall -U postgres|gzip > pg_homer_dump151224.gz

database backup:
pg_dump dbname outfile

Full restore:
psql -f infile postgres 

database restore:
psql dbname < infile 
with campress:
gunzip -c pg_homer_dump_prod201224.gz | psql homer_config -U postgres

С одного сервера на другой
pg_dump -h host1 dbname | psql -h host2 dbname

с использованием архивации

свернуть
pg_dump dbname | gzip > filename.gz
развернуть
gunzip -c filename.gz | psql dbname
или
cat filename.gz | gunzip | psql dbname

Процесс  дампа довольно сильно грузят ЦПУ,  поэтому лучше  его ограничить по ресурсам
cpulimit  -e  pg_dumpPID  --limit=50 -z
cpulimit  -e  gzip  --limit=50 -z

Полный вариант
pg_dump  -U username   --host 127.0.0.1 --port 5432 dbname | gzip > dbname.gz


/usr/bin/pg_basebackup -U postgres -D /tmp/pg_backup -Ft -z -Xf


понедельник, 18 ноября 2013 г.

просто munin

В начале как положено

sudo aptitude update 
1) sudo aptitude install munin munin-node

2) создаем   /var/www/munin

3) Обязательно задать

htmldir /var/www/munin
в munin.conf

3) edit /etc/apache2/conf-available/munin.conf

Alias /munin /var/www/munin
<Directory /var/www/munin>
        Require local
        Options None
#       Order allow, deny
 #      Allow from all

        Require all granted
        Options FollowSymLinks SymLinksIfOwnerMatch

</Directory>

4)  делаем reset
/etc/init.d/apache2  restart
/etc/init.d/munin  restart
/etc/init.d/munin-node restart
Должны появится файлы в
/var/www/munin

5) для авто-запуска

update-rc.d munin-node defaults




понедельник, 28 октября 2013 г.

Беглый осмотр коммутатора DES-3028

Особенность !! удалять символы (shif+backspace)

DES-3028:4#create account admin <username 15>  создать аккаунт с правами пользователя


DES-3028:4#save all         - сохранить все настройки в флеш
Command: save all

Saving all configurations and log information to NV-RAM...... Done.
Success.



DES-3028:4#show ipif   сетевые настройки

IP Interface Settings
Interface Name          : System
IP Address              : 10.2.10.138     (MANUAL)
Subnet Mask             : 255.255.254.0
VLAN Name               : managment
Admin. State            : Enabled
Link Status             : Link UP
Member Ports            : 25-28
DHCP Option12 State     : Disabled
DHCP Option12 Host Name :
Total Entries  : 1



DES-3028:4#show switch


Device Type        : DES-3028 Fast Ethernet Switch
MAC Address        : 84-C9-B2-71-9D-43
IP Address         : 10.2.10.138 (Manual)
VLAN Name          : managment
Subnet Mask        : 255.255.254.0
Default Gateway    : 10.2.11.1
Boot PROM Version  : Build 1.00.B06
Firmware Version   : Build 2.31.B02
Hardware Version   : A2

DES-3028:4#show ports

Port   State/          Settings             Connection           Address
        MDI       Speed/Duplex/FlowCtrl  Speed/Duplex/FlowCtrl    Learning
 -----  --------  ---------------------  ---------------------    --------
 1      Enabled   Auto/Disabled          10M/Half/None            Enabled
        Auto
 2      Enabled   Auto/Disabled          LinkDown                 Enabled
        Auto
 3      Enabled   Auto/Disabled          LinkDown                 Enabled
        Auto
 4      Enabled   Auto/Disabled          LinkDown                 Enabled

DES-3028:5#show ports description    - подписи к портам


DES-3028:4#show vlan   <vlan_name 32>  просмотреть настроеные вланы


VID             : 777         VLAN Name       : voip2
VLAN Type       : Static      Advertisement   : Enabled
Member Ports    : 1,26
Static Ports    : 1,26
Current Tagged Ports   : 26
Current Untagged Ports : 1
Static Tagged Ports    : 26
Static Untagged Ports  : 1
Forbidden Ports        :


Total Entries  : 1


DES-3028:4#create vlan  VLANNAME  tag VLANID  создать новый влан
DES-3028:4#config vlan vlanid 400 advertisement enable
DES-3028:4#config vlan voip2 add tagged  <portlist>  добавить влан с тегированием на порт

все что связано с портами можно указывать  в виде  (1-n)  т.е. диапазон портов

DES-3028:4#config vlan voip2 add untagged <portlist>  добавить влан без тегирования на порт

DES-3028:4#show fdb port 1   показать маки на порту

DES-3028:4#show fdb vlan   показать маки в влане

DES-3028:4#show fdb mac_address 00-1D-7E-D5-F7-22      искать мак на портах

DES-3028:4#clear address_binding dhcp_snoop binding_entry ports all   отключить ограничения на портах на автоматическое получение мака

DES-3028:5#config ports 5 speed 100_full
DES-3028:5#show error ports 5
DES-3028:5#clear counters ports 5
DES-3028:5#cable_diag ports 2
DES-3028:5#sh log

DES-3028:5#cable_diag ports 5
Command: cable_diag ports 5

 Perform Cable Diagnostics ...

 Port   Type      Link Status          Test Result          Cable Length (M)
 ----  -------  --------------  -------------------------  -----------------
  5      FE        Link Down     Pair2 Open      at 52  M          -

Покинуть консоль
logout




среда, 2 октября 2013 г.

kamailio логирование и дебагинг

В основном конфиге указать log_facility
/etc/kamailio.conf

debug=3 # debug level, 1 is low and 4 is high (lots of output)
log_facility=LOG_LOCAL7
loadmodule "/usr/local/lib/kamailio/modules/xlog.so"

Добавить
/etc/rsyslog.conf
# Kamailio (OpenSER) messages, make sure this spacing is done with tabs, spaces may cause errors local7.*        -/var/log/kamailio

Создать файл
touch /var/log/kamailio

Перезапустить kamailio и rsyslog





понедельник, 16 сентября 2013 г.

Приемчики MySQL

Зайти в консоль рутом
#mysql -uroot -p
Посмотреть базы
mysql> show databases;
Выбрать нужную базу
mysql> use databasename;
Посмотреть список таблиц
mysql> show tables;
Просмотреть таблицу
mysql> describe tablename;
Создать базу
mysql> CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] db_name
Удалить базу
mysql> DROP {DATABASE | SCHEMA} [IF EXISTS] db_name
Добавить пользователя:
mysql> CREATE USER  jeffrey@localhost   IDENTIFIED BY "mypass"; 
удалить пользователя:drop user opensips2@localhost;
Дать доступ пользователю
mysql> GRANT ALL ON db1.* TO 'jeffrey'@'localhost';
сменить пароль
mysql> update user set password=PASSWORD("new_password_here") where User='root';
Обновить
mysql> flush privileges;
Посмотреть колонки
mysql> select table_name,column_name,data_type from information_schema.columns where table_schema='sedberg' and table_name like 'elp%' order by column_name;
пример
mysql> select src,clid,dst,calldate  from cdr where  dst='121' and src='903';
Посмотреть колличесвто записей в таблице:
SELECT count(*) FROM table_name;
Все записи из таблицы
SELECT * FROM table_name;
Выбор нескольких полей из таблицы
SELECT name, last_name FROM person;
Показать часть таблицы, 3 строки начиная с 2й
SELECT * FROM table_name LIMIT 2,3;
Упорядочить по одной из колонок:
SELECT * FROM person ORDER BY number; 
где number - номер  или имя столбца
упорядочить в обратном порядке
SELECT * FROM person ORDER BY number DESC;
выбрать строки со значением
SELECT * FROM person WHERE name='Дима';
Выбрать похожую строку
SELECT * FROM person WHERE name LIKE 'Di%';
SELECT * FROM person WHERE name LIKE '%na' ORDER BY number ;
SELECT * from person where age in (12,15,18);

SELECT * FROM person WHERE name IS NULL; найти пустые значения?
SELECT * FROM person WHERE name BETWEEN x AND y OR z>max;
Выбрать уникальные значения в колонке
SELECT DISTINCT site FROM table_name;
пример:   select distinct user_agent  from location;
Максимально и мин значения
select max(age) from person;
select name, min(age) from person;

Создать таблицу с колонкой id
create table cdr (id int not null);
Добавить колонку к таблице
ALTER TABLE cdr ADD email VARCHAR(60); (cdr - таблица , email - имя колонки)
ALTER TABLE cdr ADD email VARCHAR(60) AFTER name;
ALTER TABLE cdr ADD email VARCHAR(60) FIRST;

Сменить ТИП данных в столбце
ALTER TABLE table_name MODIFY col_name new_type;
ALTER TABLE users MODIFY active_time1_stop varchar(128)
Удалить столбец
ALTER TABLE x DROP COLUMN a;Изменить значение, "вставить" новые данные
INSERT INTO table_name(site, description) values ('sitename', 'our site-the best')
Изменить значение в нужном поле
UPDATE table_name set site = 'domain.com' where id = '3'
Удалить запись с определенным полем
DELETE from table_name where id = '3'Сложные запросы
SELECT DISTINCT last_name FROM person, address WHERE person.adress_no = address.address_no AND city LIKE 'L%';
или
SELECT DISTINCT last_name FROM person p, address adr WHERE p.adress_no = adr.address_no AND city LIKE 'L%';
SELECT heroes.char_name, heroes.count, char_templates.ClassName FROM char_templates, heroes WHERE char_templates.ClassId = heroes.class_id Order by char_templates.ClassName;
или
SELECT char_name, count, ClassName FROM heroes left join char_templates on heroes.class_id=char_templates.ClassId;
Выборки по двум таблицам
select * from cdr,cdr2 where cdr.age=cdr2.age;


SELECT * FROM `cdr` WHERE (`calldate` BETWEEN '2013-09-14 00:00:00' AND '2013-09-16 00:00:00') and (`dst`= "2330101" or `dst`= "2330102" or `dst`= "914" or `dst`= "915" or `dst`= "2330111" or `dst`= "2331122")
посчитать среднее по одному из столбцов
select calldate,clid,src,dst,uniqueid,billsec,duration,AVG(billsec) as sum  from cdr where src=904;
сумма
select calldate,clid,src,dst,uniqueid,billsec,duration,SUM(billsec) as sum  from cdr where src=904;

Показать колличество звонков за месяц в рабочее время прямо в консоль

mysql -u asterisk -pPassword -D cdr_pbx  -e 'select COUNT(*) from cdr where calldate like "2014-08-%" AND (TIME(calldate) between "09:00:00" AND "18:00:00") AND clid like "%WNet%";'


The preceding sections provide password-resetting instructions for Windows and Unix systems. Alternatively, on any platform, you can set the new password using the mysql client (but this approach is less secure):



Stop mysqld and restart it with the --skip-grant-tables option. This enables anyone to connect without a password and with all privileges. Because this is insecure, you might want to use --skip-grant-tables in conjunction with --skip-networking to prevent remote clients from connecting.


Connect to the mysqld server with this command:shell> mysql



Issue the following statements in the mysql client. Replace the password with the password that you want to use.mysql> UPDATE mysql.user SET Password=PASSWORD('MyNewPass') -> WHERE User='root'; mysql> FLUSH PRIVILEGES;


The FLUSH statement tells the server to reload the grant tables into memory so that it notices the password change.

You should now be able to connect to the MySQL server as root using the new password. Stop the server, then restart it normally (without the --skip-grant-tables and --skip-networking options).


Посмотреть последние строки в таблице;

mysql> select * from CDR2 ORDER BY SETUP_TIME DESC limit 10;

Показать размер базы в МБ
SELECT table_schema "cdr", sum( data_length + index_length ) / 1024 / 1024 "Data Base Size in MB"  FROM information_schema.TABLES GROUP BY table_schema ; 

INSERT Products(ProductName, Manufacturer, ProductCount, Price)
VALUES ('iPhone X', 'Apple', 5, 76000);


четверг, 8 августа 2013 г.

Проверка и оптимизация всех MySQL


Хорошая MySQL утилита, mysqlcheck, с помощью её можно выполнить сразу несколько полезных операций над всеми базами данных. Команду нужно запускать от суперпользователя root.

Восстановление & Оптимизация
mysqlcheck -A  -p

Только ввостановление
mysqlcheck -Ar -p

Только оптимизация
mysqlcheck -Ao -p

Описание аргументов:
-A – Проверить на ошибки все Mysql базы данных
-r – Отремонтировать все Mysql базы данных
-o – Оптимизировать все Mysql базы данных
-p – Для доступа к базе используєтся пароль