Usando Linux para muchas cosas y disfrutando de videojuegos, en dispositivos moviles, consolas y pc. Using Linux for many things and enjoying video games, mobile devices, consoles and pc

Como instalar un servidor Debian 6 paso a paso

Como en gustos no hay disgustos (cierto?) hoy les mostrare como se instala un server Linux Debian 6, la version mas nueva a la fecha de hoy de este venerable linux, muy usado y base para el popular Ubuntu. Este ejemplo lo mostrare ejecutando virtualizado con KVM en un servidor de virtualizacion Proxmox pero igual se puede instalar en un servidor normal. Todo lo haremos desde la cuenta root en nuestro Proxmox

-Nos cambiamos al directorio de ISO en Proxmox
cd /var/lib/vz/template/iso/

-Descargamos el ISO
wget -c http://cdimage.debian.org/debian-cd/6.0.2.1/multi-arch/iso-cd/debian-6.0.2.1-amd64-i386-netinst.iso

-Creamos el server virtual en Proxmox y lo ejecutamos para que haga boot.


-Colocamos el CDROM en segundo orden de boot
-Iniciamos el server virtual
-Comenzamos a instalar
-Escogemos idioma de instalación
-País donde esta ubicado el servidor, en base a esto es la zona horaria
-Distribución del teclado que estamos usando
-Nombre o hostname del server


-Contraseña de root

-Creamos un usuario sin privilegios



-Particionamos el disco, sugiero usar LVM para mas adelante si es necesario poder agregar mas espacio con mas discos







-Escogemos el país de donde bajar paquetes, prefiero usar USA

-Si nuestro server esta detrás de un proxy saliendo a Internet, este es el momento de colocar su información


-Dependiendo para que usara su servidor, aquí puede marcar que grupos de paquetes instalar. Sugiero manejar servidores sin ambiente gráfico para un mejor rendimiento. En este caso solo instalo OpenSSH y los utilitarios normales de linux


-Reiniciamos el server ya instalado
-Nuestro server Debian 6 ya instalado

Disfrútenlo
Share/Bookmark

Estreno de Gears of war 3

Ayer 20 de septiembre fue el estreno mundial (aunque aqui en Colombia creo no fue entregado, alguien que me corrija si asi lo fue) del videojuego Gears of War 3, uno de los juegos punta de lanza de Xbox 360 y uno de mis preferidos.
Segun Epic la saga se culmina en esta entrega pero personalmente creo que Microsoft no va a dejar una serie tan exitosa y en 1 año o muy pronto tendremos noticias de nuevos proyectos sobre este mundo fascinante de humanos luchando por sobrevivir a esta plaga de extraterrestres llamados Locus.
Esta vez la maquina de mercadotecnia tan bien engrasada de Microsoft nos ofrecio 4 opciones para jugarlo, de la opcion mas economica que es el solo videojuego al mas caro que viene una hermosa xbox 360 aerografiada con motivos de GoW.

-Gears of War 3 standard
-Gears of War 3 limited edition
-Gears of War 3 epic edition
-Xbox 360 Gears of War limited edition console bundle

Yo espero jugarlo el fin de semana. Que cual compre?, pues la Epic Edition, y uds, son fans de la saga y cual compraron?
Share/Bookmark

BBB en Linux Ubuntu 10.04 server

Para que reunirnos físicamente si podemos hacer una videoconferencia compartiendo archivos, el "escritorio" de nuestro pc y dejarla grabada para después poder consultarla. Todo eso y mas nos permite BigBlueButton el cual les mostrare hoy como se instala y configura. Usaremos un server Ubuntu 10.04 (al día de hoy algunas dependencias aun no funcionan con Ubuntu 11.04 server)
La configuracion la haremos desde root

-Requerimientos
  • 2GB de memoria (mas es mejor)
  • Dual-Core o superior
  • Puertos abiertos: 80, 1935, 9123
  • 200GB de espacio libre en disco (o mas si vamos a grabar)
-Descargamos la llave y la instalamos
wget http://ubuntu.bigbluebutton.org/bigbluebutton.asc -O- | apt-key add -

-Activamos el repositorio multiverse
echo "deb http://us.archive.ubuntu.com/ubuntu/ lucid multiverse" | tee -a /etc/apt/sources.list

-Actualizamos, en caso de instalar un nuevo kernel, reiniciamos el server
apt-get update
apt-get dist-upgrade

-Instalamos Ruby
apt-get -y install zlib1g-dev libssl-dev libreadline5-dev libyaml-dev build-essential bison checkinstall libffi5 gcc checkinstall libreadline5 libyaml-0-2

cd /tmp
wget -c http://ftp.ruby-lang.org/pub/ruby/1.9/ruby-1.9.2-p290.tar.gz
tar xvzf ruby-1.9.2-p290.tar.gz
cd ruby-1.9.2-p290
./configure --prefix=/usr --program-suffix=1.9.2 --with-ruby-version=1.9.2 --disable-install-doc

make
checkinstall -D -y --fstrans=no --nodoc --pkgname='ruby1.9.2' --pkgversion='1.9.2-p290' --provides='ruby' --requires='libc6,libffi5,libgdbm3,libncurses5,libreadline5,openssl,libyaml-0-2,zlib1g' --maintainer=brendan.ribera@gmail.com

update-alternatives --install /usr/bin/ruby ruby /usr/bin/ruby1.9.2 500 --slave   /usr/bin/ri   ri   /usr/bin/ri1.9.2 --slave   /usr/bin/irb  irb  /usr/bin/irb1.9.2 --slave   /usr/bin/gem  gem  /usr/bin/gem1.9.2 --slave   /usr/bin/erb  erb  /usr/bin/erb1.9.2 --slave   /usr/bin/rdoc rdoc /usr/bin/rdoc1.9.2

-Verificamos haya quedado instalado
ruby -v
ruby 1.9.2p290 (2011-07-09 revision 32553) [i686-linux]

gem -v
1.3.7

-Instalamos FreeSwitch
apt-get install bbb-freeswitch-config

-Instalamos BigBlueButton, hora de ir por café, postres o jugar un videojuego :-)
apt-get install bigbluebutton

-Aceptamos la licencia para usar ttf-mscorefonts


-Opcionalmente instalamos el demo. El mismo que aparece en el website de BBB
apt-get install bbb-demo

-Probamos un restart del servicio verificando todo este ok (no nos preocupemos por el warning)

bbb-conf --clean
# The following properties in /var/lib/tomcat6/webapps/bigbluebutton/WEB-INF/classes/bigbluebutton.properties have no value.
#     bigbluebutton.web.logoutURL
Doing a clean restart of BigBlueButton ...
 * Stopping Red5 Server red5                                                                                                                         [ OK ]
 * Stopping Tomcat servlet engine tomcat6                                                                                                            [ OK ]
Stopping nginx: nginx.
Killing: 20176
Stopping OpenOffice headless server.
Record and Playback monitoring stopped

Cleaning Log Files ...
 * could not access PID file for nginx
 * Red5 Server is not running.
 * Tomcat servlet engine is not running.

Starting FreeSWITCH
Error: stacksize 4194303 is too large: run ulimit -s 240 or run /opt/freeswitch/bin/freeswitch -waste.
auto-adjusting stack size for optimal performance...
30876 Backgrounding.
Waiting for FreeSWITCH to start: ...................
Starting OpenOffice headless server
Starting nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
configuration file /etc/nginx/nginx.conf test is successful
nginx.
 * Starting Red5 Server red5                                                                                                                                   Waiting for FreeSWITCH to start:

                                                                                                                                                     [ OK ]
 * Starting Tomcat servlet engine tomcat6                                                                                                            [ OK ]
Record and Playback monitoring started
Waiting for BigBlueButton to finish starting up (this may take a minute):  done


** Potential problems described below **
# The following properties in /var/lib/tomcat6/webapps/bigbluebutton/WEB-INF/classes/bigbluebutton.properties have no value.
#     bigbluebutton.web.logoutURL

-Siguiente comando de restart. Igual que con el comando anterior, hacer caso omiso del warning por bigbluebutton.web.logoutURL

bbb-conf --check

BigBlueButton Server 0.8-beta
                    Kernel version: 2.6.32-33-generic-pae
                      Distribution: Ubuntu 10.04.3 LTS (32-bit)
                            Memory: 2013 MB

/var/www/bigbluebutton/client/conf/config.xml (bbb-client)
          Port test (tunnel): xxx.xxx.xxx.xxx
                              Red5: xxx.xxx.xxx.xxx

/etc/nginx/sites-available/bigbluebutton (nginx)
                       server name: xxx.xxx.xxx.xxx
                              port: 80
                    bbb-client dir: /var/www/bigbluebutton

/var/lib/tomcat6/webapps/bigbluebutton/WEB-INF/classes/bigbluebutton.properties (bbb-web)
                      bbb-web host: xxx.xxx.xxx.xxx

/var/lib/tomcat6/webapps/demo/bbb_api_conf.jsp (API demos)
                  bbb-web-api host: xxx.xxx.xxx.xxx

/usr/share/red5/webapps/bigbluebutton/WEB-INF/red5-web.xml (red5)
                  voice conference: FreeSWITCH

/usr/local/bigbluebutton/core/scripts/slides.yml (record and playback)
                     playback host: xxx.xxx.xxx.xxx


** Potential problems described below **
# The following properties in /var/lib/tomcat6/webapps/bigbluebutton/WEB-INF/classes/bigbluebutton.properties have no value.
#     bigbluebutton.web.logoutURL

-Entramos a probar nuestro bbb server
http://ip-del-server/

Listo, ya tenemos un server BBB. Disfrútenlo

Share/Bookmark

Automatiza la eliminacion de mails con Courier-Imap

Hoy en día es común tener un smartphone, tablet o dispositivo conectado a internet desde el cual leemos o enviamos mails. Esto es muy útil y nos mantiene conectados pero pocos tienen la costumbre de ir borrando sus mails viejos enviados o de la papelera, quedando esta tarea para los que administramos los servidores ya que el espacio en disco no es un recurso infinito y siempre tiende a agotarse. Si tienen su email server con Courier aquí les mostrare como configurarlo para que automáticamente elimine mails en xx dias de las carpetas que uds deseen. Nuestro ejemplo sera con un servidor linux Centos y todo se realizara desde la cuenta root.

-Editamos. Todas las lineas que comienzan con # son comentarios
cd /usr/lib/courier-imap/etc/
vi imapd
#eliminar automaticamente
#Trash 3 dias
#Send 4 dias
#Drafts 2 dias
IMAP_EMPTYTRASH=Trash:3,Sent:4,Drafts:2

-Reiniciamos el servicio
service courier-imap restart

Con esto nuestros limites de espacio en los mailbox de los usuarios se mantendrán bien.
Si te resulto útil este articulo, se social, compártelo con otros por medio de los botones.
Disfrútenlo.
Share/Bookmark

Como instalar y configurar MySQL Workbench

Nota: En este URL podrás ver este articulo mas actualizado.

En anteriores artículos vimos como instalar MySQL Server en Cluster o como optimizarlo por medio de un script. Hoy veremos como instalar MySQL Workbench para monitorear y administrar nuestro server entre otras tareas.
Esta herramienta sirve para:

  • Diseño y modelado de bases de datos
  • Reemplazo de MySQL Query Browser
  • Administración de bases de datos, reemplazo de MySQL Administrator
Y la podemos descargar dependiendo de su OS desde este URL. En mi caso la descargare para Ubuntu Desktop 11.04

-Instalamos dependencias
sudo apt-get install libctemplate0 libmysqlclient16 libpython2.6 libzip1 python-paramiko mysql-client python-pysqlite2 mysql-common python2.6 mysql-client-5.1 libdbi-perl libdbd-mysql-perl mysql-client-core-5.1 python2.6-minimal libplrpc-perl libnet-daemon-perl

-Instalamos
sudo dpkg -i mysql-workbench-gpl-5.2.34-1ubu1010-i386.deb

-Así se ve al ejecutarlo
-Creamos una conexión, debemos tener permisos en ese server para conectarnos.



-Modificamos la sección para que la busque como MYSQLD

-Damos doble click para entrar a administrar 
 -Ya dentro
-Damos click en Home (Icono superior izquierdo en la ventana) y probamos a entrar al SQL Editor

Con esto ya tenemos una útil herramienta si gustas de hacer cambios a MySQL desde una interfaz amigable. Disfrútenlo
Share/Bookmark

Como hacer backup de equipos en tu LAN

A la hora de sacar backup de los equipos en nuestra LAN encontramos muchas opciones, la mayoría con un alto costo sin contar con el hardware que necesitamos para poder explotarlo.
Hoy les mostrare como instalar y configurar BackupPC para tomar backups de los pc, servidores de su red LAN y equipos a los que tengamos acceso vía internet.
Usaremos Centos 6 virtualizado actualizado a la fecha para esto.
Necesitaremos un disco o filesystem únicamente para la tarea de almacenar los backup, no es recomendado que este en el mismo filesystem /

-Para este server tengo 2 discos, sda y sdb, dejando este ultimo solo para backup's. Si cuando instalamos Centos ya teníamos el disco podemos configurar el montaje directo sobre /data y no necesitaremos los comandos mostrados debajo

mkdir /data
mount /dev/sdb /data
vi /etc/fstab
/dev/sdb                /data                   ext3    defaults        1 2

Salimos guardando

-Deshabilitamos SELinux, herramienta útil, pero que muchas veces nos da buenos dolores de cabeza.

vi /etc/selinux/config
SELINUX=disabled

Salimos guardando y reiniciamos el server.

-Instalamos dependencias
yum install perl-CPAN gcc make samba-client httpd

-Descargamos el tgz del BackupPC

wget -c http://downloads.sourceforge.net/project/backuppc/backuppc/3.2.1/BackupPC-3.2.1.tar.gz

-Descomprimimos el tgz y entramos en su directorio
tar xzvf BackupPC-3.2.1.tar.gz

-Instalamos módulos de perl necesitados contestando Y si nos pide instalar otro módulo

perl -MCPAN -e shell
install CPAN::DistnameInfo
install Compress::Zlib Archive::Zip XML::RSS File::RsyncP Net::FTP Net::FTP::AutoReconnect Digest::MD5


-Creamos un usuario sin privilegios para backuppc y le colocamos una contraseña. Recuerden que su información sera tan segura como tan segura sea su contraseña entre otras políticas de seguridad a seguir.
adduser backuppc
passwd backuppc
chown backuppc.backuppc /data

-Comenzamos a configurar BackupPC
cd BackupPC-3.2.1

perl configure.pl
Is this a new installation or upgrade for BackupPC?  If this is
an upgrade please tell me the full path of the existing BackupPC
configuration file (eg: /etc/BackupPC/config.pl).  Otherwise, just
hit return.

--> Full path to existing main config.pl []?

I found the following locations for these programs:

    bzip2        => /usr/bin/bzip2
    cat          => /bin/cat
    df           => /bin/df
    gtar/tar     => /bin/gtar
    gzip         => /bin/gzip
    hostname     => /bin/hostname
    nmblookup    => /usr/bin/nmblookup
    par2         =>
    perl         => /usr/bin/perl
    ping         => /bin/ping
    rsync        => /usr/bin/rsync
    sendmail     => /usr/sbin/sendmail
    smbclient    => /usr/bin/smbclient
    split        => /usr/bin/split
    ssh/ssh2     => /usr/bin/ssh

--> Are these paths correct? [y]?y
Please tell me the hostname of the machine that BackupPC will run on.

--> BackupPC will run on host [bck.test.com]?

BackupPC should run as a dedicated user with limited privileges.  You
need to create a user.  This user will need read/write permission on
the main data directory and read/execute permission on the install
directory (these directories will be setup shortly).

The primary group for this user should also be chosen carefully.
The data directories and files will have group read permission,
so group members can access backup files.

--> BackupPC should run as user [backuppc]?

Please specify an install directory for BackupPC.  This is where the
BackupPC scripts, library and documentation will be installed.

--> Install directory (full path) [/usr/local/BackupPC]? /home/backuppc
Please specify a data directory for BackupPC.  This is where all the
PC backup data is stored.  This file system needs to be big enough to
accommodate all the PCs you expect to backup (eg: at least several GB
per machine).

--> Data directory (full path) [/data/BackupPC]?

BackupPC can compress pool files, providing around a 40% reduction in pool
size (your mileage may vary). Specify the compression level (0 turns
off compression, and 1 to 9 represent good/fastest to best/slowest).
The recommended values are 0 (off) or 3 (reasonable compression and speed).
Increasing the compression level to 5 will use around 20% more cpu time
and give perhaps 2-3% more compression.

--> Compression level [3]?7
BackupPC has a powerful CGI perl interface that runs under Apache.
A single executable needs to be installed in a cgi-bin directory.
This executable needs to run as set-uid backuppc, or
it can be run under mod_perl with Apache running as user backuppc.

Leave this path empty if you don't want to install the CGI interface.

--> CGI bin directory (full path) []? /var/www/cgi-bin

BackupPC's CGI script needs to display various PNG/GIF images that
should be stored where Apache can serve them.  They should be placed
somewhere under Apache's DocumentRoot.  BackupPC also needs to know
the URL to access these images.  Example:

    Apache image directory:  /var/www/htdocs/BackupPC
    URL for image directory: /BackupPC

The URL for the image directory should start with a slash.

--> Apache image directory (full path) []? /var/www/icons
--> URL for image directory (omit http://host; starts with '/') []? /icons

Ok, we're about to:

  - install the binaries, lib and docs in /home/backuppc,
  - create the data directory /data/BackupPC,
  - create/update the config.pl file /etc/BackupPC/config.pl,
  - optionally install the cgi-bin interface.

--> Do you want to continue? [y]?y
Created /home/backuppc/bin
Created /home/backuppc/doc
Created /home/backuppc/lib/BackupPC/CGI
Created /home/backuppc/lib/BackupPC/Config
Created /home/backuppc/lib/BackupPC/Lang
Created /home/backuppc/lib/BackupPC/Storage
Created /home/backuppc/lib/BackupPC/Xfer
Created /home/backuppc/lib/BackupPC/Zip
Created /home/backuppc/lib/Net/FTP
Created /data/BackupPC
Created /data/BackupPC/pool
Created /data/BackupPC/cpool
Created /data/BackupPC/pc
Created /data/BackupPC/trash
Created /etc/BackupPC
Created /var/log/BackupPC
Installing binaries in /home/backuppc/bin
Installing library in /home/backuppc/lib
Installing images in /var/www/icons
Making init.d scripts
Making Apache configuration file for suid-perl
Installing docs in /home/backuppc/doc
Installing config.pl and hosts in /etc/BackupPC
PING localhost.localdomain (127.0.0.1) 56(84) bytes of data.
64 bytes from localhost.localdomain (127.0.0.1): icmp_seq=1 ttl=64 time=0.029 ms

--- localhost.localdomain ping statistics ---
1 packets transmitted, 1 received, 0% packet loss, time 0ms
rtt min/avg/max/mdev = 0.029/0.029/0.029/0.000 ms
Installing cgi script BackupPC_Admin in /var/www/cgi-bin

Ok, it looks like we are finished.  There are several more things you
will need to do:

  - Browse through the config file, /etc/BackupPC/config.pl,
    and make sure all the settings are correct.  In particular,
    you will need to set $Conf{CgiAdminUsers} so you have
    administration privileges in the CGI interface.

  - Edit the list of hosts to backup in /etc/BackupPC/hosts.

  - Read the documentation in /home/backuppc/doc/BackupPC.html.
    Please pay special attention to the security section.

  - Verify that the CGI script BackupPC_Admin runs correctly.  You might
    need to change the permissions or group ownership of BackupPC_Admin.
    If this is an upgrade and you are using mod_perl, you will need
    to restart Apache.  Otherwise it will have stale code.

  - BackupPC should be ready to start.  Don't forget to run it
    as user backuppc!  The installation also contains an
    init.d/backuppc script that can be copied to /etc/init.d
    so that BackupPC can auto-start on boot.  This will also enable
    administrative users to start the server from the CGI interface.
    See init.d/README.

Enjoy!

-Modificamos el default config.pl. Las lineas que comienzan con # son comentarios y las $Conf son variables con valores

cd /etc/BackupPC
vi config.pl
$Conf{MaxBackupPCNightlyJobs} = 4;
$Conf{MaxOldLogFiles} = 5;
# Rango ip manejado dentro nuestra LAN
$Conf{DHCPAddressRanges} = [
  {
    'first' => 2,
    'ipAddrBase' => '192.168.1',
    'last' => 254
  }
];
$Conf{ServerInitdPath} = '/etc/init.d/backuppc';

$Conf{ServerInitdStartCmd} = '$sshPath -q -x -l root $serverHost $serverInitdPath start < /dev/null >& /dev/null';

$Conf{FullKeepCnt} = 4;
#Dias que se guardara un backup completo
$Conf{FullAgeMax}     = 30;
$Conf{RestoreInfoKeepCnt} = 5;
$Conf{ArchiveInfoKeepCnt} = 5;
$Conf{XferMethod} = 'rsyncd';
#Nombre del recurso compartido para copiar por rsync
$Conf{RsyncShareName} = 'docs';
#usuario
$Conf{RsyncdUserName} = 'backup';
#Contraseña, cambiarlo a algo mas seguro
$Conf{RsyncdPasswd} = 'contraseña';
$Conf{ArchiveComp} = 'bzip2';
$Conf{PingMaxMsec} = 80;
$Conf{MaxOldPerPCLogFiles} = 5;
#email al que enviar notificaciones, administrador
$Conf{EMailAdminUserName} = 'administrador@email.com';
#dominio que se sumara a una cuenta para crear un email para un usuario que se le este tomando backup, ejemplo, pepito@email.com seria para el usuario pepito
$Conf{EMailUserDestDomain} = '@email.com';
$Conf{EMailHeaders} = <<EOF;
MIME-Version: 1.0
Content-Type: text/plain; charset="iso-8859-1"
EOF
#usuarios administradores
$Conf{CgiAdminUsers}     = 'cabrera';
#En caso de resolverse el domain dentro de la LAN, colocar el hostname del server, sino, como en este caso, la ip
$Conf{CgiURL} = 'http://192.168.3.1/cgi-bin/BackupPC_Admin';
$Conf{CgiDateFormatMMDD} = 0;

Salimos guardando

-Modificamos hosts. Los campos de izquierda a derecha son, hostname del equipo (en el caso de equipos windows, el nombre que se ve cuando vamos por entorno de red), 0 si es ip estática fija o 1 si es DHCP y la ultima columna son los nombres de los administradores del backup de ese equipo. El primer usuario listado sera el que recibirá los emails de notificaciones sobre ese backup

vi hosts
pc1   0    pepito cabrera
pc2   1    pepe cabrera

Salimos guardando

-Los equipos que tengamos con ip estatica debemos colocarlos en /etc/hosts
vi /etc/hosts
192.168.3.2 pc1

Salimos guardando

-Hacemos un link a cgi-bin
ln -s /var/www/cgi-bin/ /var/www/html/BackupPC

-Creamos un grupo para los admin y aseguramos el directorio
cd /var/www/cgi-bin
vi group
admin: cabrera,admin2

Salimos guardando

vi .htaccess
AuthGroupFile /var/www/cgi-bin/group
AuthUserFile /var/www/cgi-bin/.htpasswd
AuthType basic
AuthName "access"
require valid-user

Salimos guardando

-Creamos nuestro fichero de contraseñas. La primera vez usamos el parámetro c para crear el archivo, después solo m para agregar con MD5

htpasswd -cm /var/www/cgi-bin/.htpasswd cabrera

htpasswd -m /var/www/cgi-bin/.htpasswd admin2

-Copiamos el script de inicio y lo activamos
cd /root/BackupPC-3.2.1/init.d
cp linux-backuppc /etc/init.d/backuppc
chmod 755 /etc/init.d/backuppc
chkconfig backuppc on

-Modificamos apache para que ejecute con permisos de backuppc

vi /etc/httpd/conf/httpd.conf
Timeout 120
StartServers         2
MaxClients         150
User backuppc
Group backuppc
#email del admin
ServerAdmin cabrera@test.com

<Directory />
    Options FollowSymLinks
    AllowOverride all
</Directory>
DirectoryIndex index.html index.htm index.html.var
<Directory "/var/www/icons">
    Options Indexes MultiViews
    AllowOverride None
    Order allow,deny
    Allow from all
</Directory>
#<Directory "/var/www/cgi-bin">
#    AllowOverride None
#    Options None
#    Order allow,deny
#    Allow from all
#</Directory>
<Directory /var/www/cgi-bin/>
    SetHandler perl-script
    PerlResponseHandler ModPerl::Registry
    PerlOptions +ParseHeaders
    Options +ExecCGI
    AllowOverride Indexes AuthConfig


    Order deny,allow
#    Deny from all
#    Allow from 192.168.1.
    AuthName "Backup Admin"
    AuthType Basic
    AuthUserFile /var/www/cgi-bin
    Require valid-user
</Directory>
IndexOptions FancyIndexing VersionSort NameWidth=* HTMLTable

Salimos guardando y reiniciamos el servicio

service httpd restart

-Creamos un directorio para los conf de cada equipo. En la medida que vayamos agregando equipos para sacarle backups, debemos crear un config.pl para ese equipo.

cd /etc/BackupPC
mkdir pc

cp config.pl pc/pc1
cp config.pl pc/pc2
chown -R backuppc.backuppc /etc/BackupPC/

-Configuramos samba para encontrar a los pc windows en la LAN
cd /etc/samba
vi smb.conf
 [global]
        workgroup = test
        netbios name = bck
        server string = bck
        obey pam restrictions = Yes
        pam password change = Yes
        passwd program = /usr/bin/passwd %u
        passwd chat = *New*password* %n\n *Retype*new*password* %n\n *passwd:*all*authentication*tokens*updated*successfully*
        unix password sync = Yes
        log file = /var/log/samba/%m.log
        max log size = 0
        socket options = TCP_NODELAY SO_RCVBUF=8192 SO_SNDBUF=8192
        os level = 70
        local master = no
        preferred master = no
        domain master = no
        dns proxy = No
;       wins support = Yes
;       remote browse sync = 192.168.2.255
        hosts allow = 192.168. 127.
        password server = None
        security = SHARE
;       printing = cups

Salimos guardando e iniciamos el servicio
service smb restart
chkconfig smb on

-Iniciamos el servicio de backuppc
service backuppc start

-Probamos la interfaz web
http://192.168.3.1/cgi-bin/BackupPC_Admin
-Elegimos un equipo desde el combobox de la izquierda y vemos los backups que tenga, en este caso, aun no tiene ninguno



-Volvemos a la consola y probamos un backup desde el usuario backuppc

su -l backuppc
cd bin
./BackupPC_dump -fv pc1
Name server doesn't know about pc1; trying NetBios
cmdSystemOrEval: about to system /usr/bin/nmblookup pc1
cmdSystemOrEval: finished: got output querying pc1 on 192.168.3.255
192.168.3.222 pc1<00>

NetBiosHostIPFind: found IP address 192.168.3.222 for host pc1
cmdSystemOrEval: about to system /bin/ping -c 1 -w 3 192.168.3.222
cmdSystemOrEval: finished: got output PING 192.168.3.222 (192.168.3.222) 56(84) bytes of data.
64 bytes from 192.168.3.222: icmp_seq=1 ttl=128 time=1.33 ms

--- 192.168.3.222 ping statistics ---
1 packets transmitted, 1 received, 0% packet loss, time 1ms
rtt min/avg/max/mdev = 1.337/1.337/1.337/0.000 ms

cmdSystemOrEval: about to system /bin/ping -c 1 -w 3 192.168.3.222
cmdSystemOrEval: finished: got output PING 192.168.3.222 (192.168.3.222) 56(84) bytes of data.
64 bytes from 192.168.3.222: icmp_seq=1 ttl=128 time=1.24 ms

--- 192.168.3.222 ping statistics ---
1 packets transmitted, 1 received, 0% packet loss, time 1ms
rtt min/avg/max/mdev = 1.245/1.245/1.245/0.000 ms

CheckHostAlive: returning 1.245
cmdSystemOrEval: about to system /usr/bin/nmblookup -A 192.168.3.222
cmdSystemOrEval: finished: got output Looking up status of 192.168.3.222
    PC1         <20> -         M <ACTIVE>
    PC1         <00> -         M <ACTIVE>
    TEST          <00> - <GROUP> M <ACTIVE>
    TEST          <1e> - <GROUP> M <ACTIVE>

    MAC Address = 68-A3-C4-75-54-06


NetBiosInfoGet: success, returning host pc1, user
full backup started for directory docs
started full dump, share=docs

....

Y listo, ya tenemos nuestro servidor de BackupPC funcionando, en la medida que pasen los dias podremos ver la lista de backups completos y parciales.
Disfrutenlo
Share/Bookmark

Configurando Perl en Linux Centos

Hoy les mostrare como configurar Perl en un servidor Centos 6 para después poder usarlo con aplicaciones que lo requieren. Centos 6 debe estar actualizado a la fecha de hoy y todos los comandos los ejecutaremos desde root.




-Instalamos requerimientos
yum install lynx make gcc

-Descargamos ncftp como requerimiento y lo instalamos
wget -c ftp://ftp.univie.ac.at/systems/linux/fedora/epel/6/i386/ncftp-3.2.4-1.el6.i686.rpm
rpm -i ncftp-3.2.4-1.el6.i686.rpm
rm ncftp-3.2.4-1.el6.i686.rpm

-Comenzamos a configurar Perl con sus módulos respondiendo Y si nos pide instalar otros modulos como dependencias.

perl -MCPAN -e shell
install CPAN
reload cpan

-Instalamos  mas módulos necesarios respondiendo Y si nos pide instalar otros módulos como dependencias.

install CPAN::Meta Test::Pod Test::Pod::Coverage  Test::Perl::Critic
install install Compress::Zlib Archive::Zip
exit

Con esto nos queda configurado perl con sus módulos mas comunes, próximamente lo usaremos en otros proyectos.
Si te resulto útil este articulo, se social, compártelo con otros por medio de los botones.
Disfrútenlo.
Share/Bookmark

Como habilitar apache server para sitios moviles

Hoy en dia es muy comun que naveguemos desde nuestros telefonos  smartphone's, ipad, ipod, tablet, etc. igual que en nuestro PC. Por eso muchos sitios virtuales estan haciendo una version 'mobil' para adaptar el sitio a estas pantallas, por lo general mas pequeñas y hacer la navegacion mas eficiente sin que el usuario se cance y cierre la pagina.
Esta vez veremos como configurar un web server apache para que dependiendo el dispositivo del usuario muestre nuestro sitio web normal o una versión ligera.
Usaremos un server Linux Centos 6 con web server apache instalado y actualizado a la fecha. Todo los cambios los haremos desde la cuenta root.

Tenemos 2 versiones del web site:
1- www.test.com o test.com (sitio normal)
DocumentRoot: /var/www/html/test

2- m.test.com                        (sitio móvil)
DocumentRoot: /var/www/html/mtest

-Verificamos los rpm http instalados, en caso de no tenerlos, los instalamos con yum

rpm -qa|grep http*
httpd-tools-2.2.15-5.el6.centos.i686
httpd-2.2.15-5.el6.centos.i686

-Verificamos tengamos habilitado el modulo rewrite

cd /etc/httpd/conf
grep rewrite_module *
httpd.conf:LoadModule rewrite_module modules/mod_rewrite.so

-Habilitamos el uso de vhost y creamos 2, uno para el sitio normal y otro para el móvil

cd /etc/httpd/conf
vi httpd.conf
NameVirtualHost *:80
<VirtualHost *:80>
    ServerName www.test.com
    DocumentRoot /var/www/html/test
</VirtualHost>
<VirtualHost *:80>
    ServerName test.com
    DocumentRoot /var/www/html/test
</VirtualHost>
<VirtualHost *:80>
    ServerName m.test.com
    DocumentRoot /var/www/html/mtest
</VirtualHost>

Salimos guardando
-Creamos los dos escenarios. Comenzamos con el conf del sitio normal www.test.com

vi /etc/httpd/conf.d/test.conf
<Directory /var/www/html/test/>
   AllowOverride All 
</Directory>
<IfModule mod_rewrite.c>
  RewriteEngine On 
  RewriteCond %{HTTP_USER_AGENT} "android|blackberry|googlebot-mobile|iemobile|ipad|iphone|ipod|opera mobile|palmos|webos" [NC] 
  RewriteRule ^$ http://m.test.com/ [L,R=302] 
</IfModule>

Salimos guardando

-Hacemos el conf del sitio móvil negando la condición anterior del sitio normal

vi /etc/httpd/conf.d/mtest.conf
<Directory /var/www/html/mtest/>
   AllowOverride All 
</Directory>

<IfModule mod_rewrite.c>
  RewriteEngine On 
  RewriteCond %{HTTP_USER_AGENT} "!(android|blackberry|googlebot-mobile|iemobile|ipad|iphone|ipod|opera mobile|palmos|webos)" [NC] 
  RewriteRule ^$ http://www.test.com/ [L,R=302] 
</IfModule>

Salimos guardando
-Reiniciamos el servicio apache
service httpd restart
 
En este URL tenemos la version de este articulo con un servidor Debian/Ubuntu. Espero les sea útil.
 

Share/Bookmark

Necesitas el paquete de idioma Spanish 1.7 para Joomla 1.7

En anteriores artículos mostré como instalar Joomla 1.7, un popular CMS para nuestro sitio web opensource. Inicialmente viene con el idioma Ingles en-GB por lo cual hoy les mostrare como agregar el pack Spanish es-ES para Joomla 1.7.

-Descargamos a nuestro PC el pack Spanish es-ES
wget -c http://joomlacode.org/gf/download/frsrelease/15297/66591/es-ES_joomla_lang_full_170v1.tar.gz

-Entramos a la interfaz administrativa de Joomla y vamos a Extension Manager para agregar el pack de idioma
-Agregamos el pack dando click en el botón Browse y lo instalamos dando click en Upload & Install
-Regresamos al Control Panel inicial de Joomla y entramos a Languaje Manager
-Activamos Spanish como Default en Installed - Site y según nuestra preferencia también en Installed - Administration. Con esto cambiamos Joomla a Español pero no los artículos escritos ya en Ingles a no ser que nuestro site sea bilingüe y hayan sido escritos en varios idiomas.
Disfrutenlo




Share/Bookmark

Como instalar y configurar Community Builder 1.7 en Joomla 1.7

Estas creando tu sitio web y te gusta la filosofía de red social para tus clientes, amigos o fan's. Para esto existe Community Builder, un software que se agrega para darle este toque "mágico" a Joomla. Hoy veremos como se instala y configura la versión gratuita. Se recomienda hacer un backup de su db y configuración de Joomla si ya ha hecho cambios.

-Comenzamos descargando el paquete desde este link. Lo descargamos y descomprimimos en un directorio temporal en nuestro pc. Para esto debemos registrarnos en el sitio creándonos una cuenta.

-Verificamos si php esta listo para aceptar ficheros mayores a 2MB, para esto editamos y cambiamos si es el caso php.ini
vi /etc/php.ini
upload_max_filesize = 16M

service httpd restart

-Nos logeamos a la interfaz administrativa de joomla como admin

-Instalaremos las extensiones desde Extensions - Extension Manager. Usamos la opción Upload Package File para navegar al directorio temporal donde descomprimimos CB e instalamos en el siguiente orden (en caso de error verifiquemos PHP acepte mas de 4MB):

-com_comprofiler.zip
-mod_cblogin.zip
-mod_comprofilerModerator
-mod_comprofilerOnline




-Si todo marcha bien, debemos ver algo parecido.

-Nos aparece un nuevo menu en Components, el menu Community Builder
-Entramos a Components - Community Builder - Configuration y verificamos tengamos la ultima versión liberada por los desarrolladores.


-Comenzamos a configurar CB.
-CB login reemplaza el modulo Login default de Joomla. Activamos CB_Login entrando a Extensions - Module Manager
-Entramos al modulo CB login dandole click

-Modificamos Position colocando position-7 y Status published
-Modificamos mas abajo a la derecha CB Pluggins integration Yes



-Guardamos y cerramos. Seguidamente deshabilitamos el modulo de Login default de Joomla y Login (Atomic Template), para esto los marcamos con un checkmark a la izquierda y seguidamente le damos click al botón Unpublish. OJO, deben pasar de estado Publish verde a Unpublish rojo


-Terminamos de deshabilitar el modulo login de Joomla cambiándonos al menu Menus - Main Menu y deshabilitando login, click en el checkmark a la izquierda y click al boton Unpublish

-Modificamos el acceso al perfil del usuario registrado enlazandolo a CB Profile. Entramos a Menus - User Menu y damos click en Your Profile
-Cambiamos Menu Item Type
-Escogemos User Profile de comprofiler
-Guardamos y cerramos los cambios.
OJO, En Joomla CMS es obligatorio tener un menu Profile o Perfil de usuario apuntando al profile o perfil de usuario. Es de tener en cuenta que en Joomla 1.6 y 1.7 hay un bug que hace que aunque escogemos bien User Profile, nos muestra Logout despues en la caja de texto. Ignorar esto, ya se esta trabajando en este bug.


NOTA: Al instalar y configurar CB no debemos seguir manejando los usuarios por medio del modulo User Manager (Manejo de Usuarios) de Joomla, sino con la opción Components - Community Builder - User Management de no seguir esta recomendacion podemos dañar la db para el uso de CB

Con CB podemos cambiar la forma CMS de Joomla, en próximos artículos les daré mas ideas.
Share/Bookmark

Tu eres la resistencia

Mañana 6 de septiembre se lanza en el mundo Resistance 3, una de las sagas emblemáticas de Sony para Playstation 3. Se ha filtrado que Insomniac, estudio desarrollador, por el momento no hará una 4ta entrega, así que en este episodio finaliza por el momento la historia o quien sabe, nos deja esperando un desenlace por venir en una secuela o al mejor estilo de Star Wars, una precuela.
Si aun no ha separado su copia legal, puede hacerlo aquí en el país en Panamericana o en alguno de los sitios de Sony.
Si puedes traerlo de USA, hay varios sitios con promociones, como Amazon, BestBuy, por nombrar algunos. Y recuerda, tu eres la resistencia...
Share/Bookmark