Solusan

..:: Solusan – Otro blog más ::..

Reinstalación de Roundcube

Por Solusan el July 12, 2009 en Linux

Problema:

Queremos reinsalar Roundcube desde cPanel en un sistema que lo tiene implementado.

Basta con lanzar esta instrucción para que todo se estabilice.

/usr/local/cpanel/bin/update-roundcube --force

ソルサン。

Ayudanto a tunear /etc/my.cnf

Por Solusan el July 06, 2009 en Linux, Ubuntu

Un pequeño script que, al ejecutarlo, nos ayudará con la información que nos da darle forma según los requerimientos y recursos que tengamos en una máquina.

tuning-primer.tar

# wget -c http://www.solusan.com/wp-content/2009/07/tuning-primer.tar.gz
# tar xzvf tuning-primer.sh.zip
# chmod +x tuning-primer.sh.zip && ./tuning-primer.sh.zip

ソルサン。

Programador de tareas en Ubuntu (cron)

Por Solusan el July 06, 2009 en Linux, Ubuntu

En Ubuntu, cron es el “Administrador de tareas” en segundo plano (demonio) que ejecuta programas a intervalos regulares (por ejemplo, cada minuto, día, semana o mes). Los procesos que deben ejecutarse y la hora en la que deben hacerlo se especifican en el archivo crontab.

Los usuarios habilitados para crear su archivo crontab se especifican en el archivo cron.allow. De manera análoga, los que no lo tienen permitido figuran en /etc/cron.d/cron.deny, o /etc/cron.deny, dependiendo de la versión de unix.

Cómo programar una tarea en crontab

Nada mejor que un ejemplo del archivo crontab

skrdz@root:#crontab -e
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
HOME=/

# run-parts
01  * * * * root nice -n 19 run-parts /etc/cron.hourly
50  0 * * * root nice -n 19 run-parts /etc/cron.daily
22 4 * * 0 root nice -n 19 run-parts /etc/cron.weekly
42 4 1 * * root nice -n 19 run-parts /etc/cron.monthly

Para agregar, quitar o modificar tareas, hay que editar el crontab. Esto se hace con la orden crontab -e, que abrirá el editor definido en la variable de entorno EDITOR y cargará el archivo crontab correspondiente al usuario que está logueado.

Cada vez que se ejecuta el crontab, se envía un mail al usuario que aparece en la variable de entorno MAILTO, si está habilitado, indicándole la tarea realizada.

La sintaxis en sí…

El símbolo Numeral “#” es un comentario, todo lo que se encuentre después de ese carácter no será ejecutado por cron. El momento de ejecución se especifica de acuerdo con la siguiente tabla:

Minutos: (0-59)
Horas: (0-23)
Días: (1-31)
Mes: (1-12)
Día de la semana: (0-6), siendo 1=Lunes, 2=Martes, … 6=sábado y 0=Domingo
Para especificar todos los valores posibles de una variable se utiliza un asterisco (*).
La última columna corresponde al path absoluto del binario o script que se quiere ejecutar.

Por ejemplo:

24 12 * * 1 /usr/bin/who >> /home/hola.txt
Ejecuta la orden who todos los lunes a las 12:24 y guarda la salida en el archivo hola.txt

Para especificar dos o más valores en cada variable, estas deben estar separadas por comas, siguiendo con el ejemplo anterior:

0,24 * * * 1 /usr/bin/who >> /home/hola.txt

Ejecuta la orden who todos los lunes cada media hora y guarda la salida en el archivo hola.txt

Si queremos que se ejecute cada 15 minutos sería:

0,15,30,45 * * * * /usr/bin/who >> /home/quien.tex
ó
*/15 * * * * /usr/bin/who >> /home/quien.tex
En este ejemplo veremos como pasarle mas de un comando al cron y de paso como puede programarse una descarga:

30 21 * * * cd /media/sda7/dexter/distributions/isos;wget http://hola.com/archivo_a_descargar.loquesea

Este otro es para programar el apagado de la PC. En este caso todos los sábados a las 9:30 pm.

30 21 * * 6 /sbin/shutdown -h now

Espero que les haya servido!!! A mi me sirvió para programarle a moodle correr el script necesario para que envíe los correos de los foros o información importante a los estudiantes.

Vía: http://skrdz.wordpress.com/2007/08/31/programador-de-tareas-en-ubuntu-cron/

Borrando congelados

Por Solusan el July 06, 2009 en Linux

Una solución de mantener limpia la cola de exim, sobre todo cuando mueve cantidades ingentes de correo puede ser la inclusión en crontab de este pequeño script:

#!/bin/sh

/usr/sbin/exim -bpr | grep frozen | awk {'print $3'} | xargs /usr/sbin/exim -Mrm

Aunque a veces se nos quedan correos que están ‘mal formados’ para ello tira directamente del spool.

# cd /var/spool/exim/
# rm */message-id*

Tunning my.cnf

Por Solusan el July 06, 2009 en MySQL

Un ejemplo más de los mil que puedes encontrar en la red para darle un poco de vitaminas a tu servidor MySQL.

[mysqld]
datadir=/var/lib/mysql
safe-show-database
old_passwords
back_log = 15
skip-innodb
max_connections = 200
key_buffer = 256M
myisam_sort_buffer_size = 128M
join_buffer_size = 1M
read_buffer_size = 16M
sort_buffer_size = 32M
table_cache = 2048
thread_cache_size = 784
wait_timeout = 15
connect_timeout = 10
tmp_table_size = 64M
max_heap_table_size = 64M
max_allowed_packet = 8M
max_connect_errors = 10
read_rnd_buffer_size = 524288
bulk_insert_buffer_size = 8M
query_cache_limit = 2M
query_cache_size = 712M
query_cache_type = 1
query_prealloc_size = 163840
query_alloc_block_size = 32768
default-storage-engine = MyISAM

[mysqld_safe]
# err-log=/var/log/mysqld.log
# pid-file=/var/lib/mysql/mysql.pid
open_files_limit = 8192

[mysqldump]
quick
max_allowed_packet = 16M

[mysql]
no-auto-rehash

[isamchk]
key_buffer = 128M
sort_buffer_size = 128M
read_buffer = 16M
write_buffer = 16M

[myisamchk]
key_buffer = 128M
sort_buffer_size = 128M
read_buffer = 2M
write_buffer = 2M

Para comprobar que no se te descalabra el server echa un vistazo con estás tres instrucciones:

ps aux | grep -c mysql
ps aux | grep -c httpd
free -m

Si no tira mucho o nada de SWAP es que vamos bien ;)

ps aux | grep -c mysql
94

ps aux | grep -c httpd
98

free -m
total used free shared buffers cached
Mem: 2020 1357 662 0 128 770
-/+ buffers/cache: 458 1562
Swap: 0 0 0

ソルサン。

Actualizar todas las bbdd del server

Por Solusan el July 06, 2009 en Linux

TIP para con una linea sóla actualizar todas las bbdd de MySQL del server.

mysqlcheck -uda_admin -p -ro --all-databases

Análisis de memoria swap

Por Solusan el July 03, 2009 en Linux

Un pequeño tip para saber que cargas ha tenido la SWAP de forma que podamos hacernos una idea de cómo está de sana la máquina.

root@elserver [~]# sar -qrB -t 1400  -f /var/log/sa/sa02 | tail -n35
Average:       474251   1600573     77.14    130909    803944   2040212         0      0.00         0

12:30:01 PM   runq-sz  plist-sz   ldavg-1   ldavg-5  ldavg-15
12:50:02 PM         2       169      0.34      0.57      0.54
01:20:01 PM         2       193      0.87      0.80      0.67
01:40:01 PM         3       189      0.94      1.15      0.88
02:00:01 PM         4       186      0.78      1.14      1.04
02:30:01 PM         6       267      0.88      0.79      0.91
02:50:01 PM         4       170      0.53      0.64      0.81
03:10:01 PM         3       188      1.00      1.00      0.92
03:40:01 PM         3       187      1.38      1.21      1.05
04:00:01 PM         7       193      1.90      1.49      1.15
04:20:01 PM         2       179      1.13      0.97      0.99
04:50:01 PM         3       176      1.02      1.36      1.19
05:10:02 PM         7       209      1.00      0.91      0.99
05:30:01 PM         6       185      0.41      0.46      0.67
06:00:01 PM         7       182      0.75      0.59      0.56
06:20:01 PM         3       202      0.40      0.48      0.54
06:40:01 PM         3       204      0.89      0.84      0.68
07:10:01 PM         3       189      0.32      0.37      0.44
07:30:01 PM         5       194      1.09      1.06      0.79
07:50:01 PM         4       183      0.54      0.77      0.77
08:20:01 PM         3       162      0.24      0.32      0.42
08:40:01 PM         4       172      0.21      0.38      0.42
09:00:01 PM         5       170      0.25      0.34      0.38
09:30:01 PM         5       164      0.29      0.30      0.33

09:30:01 PM   runq-sz  plist-sz   ldavg-1   ldavg-5  ldavg-15
09:50:01 PM         2       176      1.20      0.74      0.59
10:10:01 PM         3       169      1.13      0.73      0.60
10:40:01 PM         3       171      0.29      0.43      0.51
11:00:02 PM         5       201      0.82      1.04      0.85
11:20:01 PM         2       192      0.67      0.70      0.75
11:50:01 PM         2       184      0.40      0.79      0.78
Average:            4       186      0.75      0.77      0.73