27 mar

Instalación de rutorrent

Bueno,

Voy a explicar como montar rutorrent + nginx +php-fpm, esta solución esta pensada sobretodo para la raspperry, ya que es muy liviano y la verdad es que después de mucho tiempo me parece de las mejores soluciones, también aprovechamos la instalacion con nginx+php-fpm que explique en el siguiente tutorial

rutorrent

Es una web que se integra con el cliente rtorret, de tal manera que lo hace muy amigable, yo personalmente estuve mucho tiempo jugando con rtorrent por consola, fue más montar el chirringo que lo que me aporto…

La web del proyecto es http://code.google.com/p/rutorrent/

Bueno pues explicado esto vamos al lio.

Primero de todo vamos actualizar el sistema operativo, todos los comandos están basados en debian.


sudo apt-get update && sudo apt-get upgrade

sudo apt-get install xmlrpc-api-utils

Ahora vamos a descargar el código de rutorrent, por defecto yo tengo el código de la web en /var/www.

cd /var/www/
wget http://rutorrent.googlecode.com/files/rutorrent-3.5.tar.gz
wget http://rutorrent-tadd-labels.googlecode.com/files/lbll-suite_0.8.1.tar.gz
wget http://rutorrent.googlecode.com/files/data-3.3.tar.gz
wget http://rutorrent.googlecode.com/files/erasedata-3.3.tar.gz
wget http://rutorrent.googlecode.com/files/ratio-3.3.tar.gz
wget http://rutorrent.googlecode.com/files/seedingtime-3.3.tar.gz
wget http://rutorrent.googlecode.com/files/tracklabels-3.3.tar.gz
wget http://srious.biz/nfo.tar.gz

tar xvfz rutorrent-3.5.tar.gz
rm -rf rutorrent-3.5.tar.gz
tar -zxvf lbll-suite_0.8.1.tar.gz
tar -zxvf data-3.3.tar.gz
tar -zxvf erasedata-3.3.tar.gz
tar -zxvf ratio-3.3.tar.gz
tar -zxvf seedingtime-3.3.tar.gz
tar -zxvf tracklabels-3.3.tar.gz
tar -zxvf nfo.tar.gz

mv lbll-suite data erasedata ratio seedingtime tracklabels nfo /var/www/rutorrent/plugins
rm lbll-suite_0.8.1.tar.gz data-3.3.tar.gz erasedata-3.3.tar.gz ratio-3.3.tar.gz seedingtime-3.3.tar.gz tracklabels-3.3.tar.gz nfo.tar.gz

Bueno con esto ya tenemos el código de la web, ahora debemos configurar rtorrent y nginx para que puedan trabajar con el, empezamos por rtorrent, nos iremos al fichero de configuración, recordar que si habéis seguido este post de instalación, deberías tener el fichero de configuración en la home de vuestro usuario, si no es así pues allá donde lo tengáis


vim  ~/.rtorrent.rc

Añadiremos al final del fichero la siguiente linea, y reiniciamos rtorrent, en el caso de no tener el script que puse en el post anterior, reiniciarlo como lo soléis hacer, la segunda linea es para que cargue los plugins de rutorrent cada vez que arranca rtorrent, es opcional, fijaros en las rutas y en el usuario que debe ser aquel con el que arranques rtorrent

scgi_port = 0.0.0.0:5000
execute = {sh,-c,/usr/bin/php /var/www/rutorrent/php/initplugins.php usuario &}
sudo /etc/init.d/rtorrentInit.sh restart

Ahora vamos a por el nginx, primero vamos a poner los parámetros de comunicación de scgi. Iremos y pegaremos lo siguiente

sudo vim /etc/nginx/scgi_params

scgi_param      REQUEST_METHOD          $request_method;
scgi_param      REQUEST_URI             $request_uri;
scgi_param      QUERY_STRING            $query_string;
scgi_param      CONTENT_TYPE            $content_type;

scgi_param      DOCUMENT_URI            $document_uri;
scgi_param      DOCUMENT_ROOT           $document_root;
scgi_param      SCGI                    1;
scgi_param      SERVER_PROTOCOL         $server_protocol;

scgi_param      REMOTE_ADDR             $remote_addr;
scgi_param      REMOTE_PORT             $remote_port;
scgi_param      SERVER_PORT             $server_port;
scgi_param      SERVER_NAME             $server_name;

Debemos activar el site, para que nginx lo haremos haciendo un ln del fichero rturront


ln -s /etc/nginx/sites-available/rutorrent /etc/nginx/sites-enabled/rutorrent

Y ahora vamos a configurar el nginx para que se entienda con todo. En el fichero de configuración  de nuestro site, añadimos.


sudo  vim /etc/nginx/sites-available/rutorrent
server {
 listen 80;
 root /var/www;
#client_max_body_size 4096M;
 listen 443 ssl;
location /rutorrent {
index index.php index.html;
auth_basic "Restricted";
auth_basic_user_file /var/www/rutorrent/.htpasswd;
}

location /RPC2 {
include /etc/nginx/scgi_params;
scgi_pass 127.0.0.1:5000;
}

location ~ .php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
include /etc/nginx/fastcgi_params;
try_files $uri =404;
fastcgi_param SCRIPT_FILENAME /var/www/$fastcgi_script_name;

}

location ~/.ht {
deny all;
}

Por ultimo añadiremos si quereis un password a través de .htpasswd, para que nos lo pida cuando accedamos a la web.

Debemos instalar el paquete apache2-utils, para disponer de la opción

htpasswd -cb .htpasswd usuario contraseña

Y copiamos el fichero que genero en la ruta donde le dijimos al nginx

cp -a  .htpasswd /var/www/rutorrent/.htpasswd

Le damos permisos a nginx

sudo chown -R www-data:www-data /var/www/rutorrent

Recargamos el nginx para la nueva configuración.

sudo /etc/init.d/nginx reload

Y accedemos por web http://ip/rutorrent

Ale a disfrutarlo

19 mar

Instalacion de VPN PPTP en debian

En este post vamos explicaremos como montar una VPN PPTP en debian, el motivo del PPTP es porque lo monte en la raspperry pi, y el ipsec no estaba disponible y por OpenVPN(la solución mas profesional) pues requiere de cliente y de más, por ello como la quería para casa, pues algo sencillo y funcional.

Dicho esto vamos al lio.

Primero de todo vamos a instalar los paquetes necesarios.


sudo apt-get install pptpd

Una vez instalado deberíamos tener ya todos los ficheros de configuración, para poderles meter mano.

Pues vamos a por ello

Primero vamos a modificar el fichero pptpd.conf


sudo vi /etc/pptpd.conf

Donde modificaremos las directrices siguientes


localip 192.168.1.100
remoteip 192.168.1.234-238

La primer pondremos en la ip donde escuchara nuestro servidor de VPN, y en la segunda la ip que se podrán asignar a los clientes que se conecten.

Vamos a por el siguiente, pptpd-options


sudo vi  /etc/ppp/pptpd-options

Configuramos o añadimos en el caso que no estén las siguientes lineas.


name nombredelaconexion
 require-mschap-v2
 require-mppe-128
 ms-dns 172.16.1.1
 proxyarp
 nodefaultroute
 lock

refuse-pap
refuse-chap
refuse-mschap

mtu 1490
mru 1490

nobsdcomp

Por ultimo vamos a configurar los usuario y accesos, esto lo hacemos en el fichero chap-secrets


sudo vi /etc/ppp/chap-secrets

# client        server  secret                  IP addresses
usuario   nombredelaconexion   contraseña      *

Reiniciamos es servicio y ya tendremos la vpn configurada, ahora debemos probar de conectarnos a ella desde cualquier cliente PPTP


sudo /etc/init.d/pptpd restart

Por último debemos activar net.ipv4.ip_forward = 1  en el fichero /etc/sysctl.conf

Por supuesto debemos abrir el puerto PPTP TCP 1723 en el router.

Ale a disfrutarlo!

12 mar

Instalación de Owncloud 4.5 + nginx + php-fpm en raspbian

Hace poco me compre una raspberry pi, y bueno intentando sacarle un poco mas de provecho monte un owncloud, lo primera vez lo hice con Apache+php, pero debido aque tengo alguno que otra cosa corriendo en la raspberry, pues se ahogaba nada más empezar…

Así que lo monte con lo siguiente:

Owncloud 4. 5 + nginx + php-fpm

Primero de todo vamos a instalar nginx y lo arrancamos


sudo apt-get install nginx

sudo /etc/init.d/nginx start

Podemos comprobar que el proceso se hizo correctamente haciendo una petición al puerto 80 de nuestra raspberry.

Ahora instalaremos el php-fpm


sudo apt-get install php5-fpm
sudo apt-get install php-xml-parser php5-intl
sudo apt-get install php5-sqlite smbclient curl libcurl3 php5-curl

Bueno pues ya tenemos instalado el tema, ahora lo que debemos hacer es que se empiecen hablar entre ellos dos, vaya que se lleven bien….

Primero vamos a configurar php5-fpm, iremos


sudo vim /etc/php5/fpm/php-fpm.conf

Aquí modificaremos las siguientes lineas según nuestra configuración, yo por ejemplo tengo añadido un usb a la raspberry, de tal manera que envío allí los logs de los servicios(por supuesto tiene que tener permisos el usuario para escribir), evitando que machaque a la tarjeta SD donde esta el SO.

error_log = /mnt/usb/fpm-log/php5-fpm.log
log_level = warning
include=/etc/php5/fpm/pool.d/*.conf

Después en el php.ini configuraremos las opciones de subir ficheros

sudo vi /etc/php5/fpm/php.ini
file_uploads = On
upload_tmp_dir = /mnt/descargas/owncloud/tmp
upload_max_filesize = 4096M
max_file_uploads = 5000
memory_limit = 128M

Importante, el valor upload_max_filesize, ya que es uno de los dos que limitara el tamaño máximo de fichero que podremos subir, también deberemos mirar el valor de la memoria, ya que como bien sabemos nuestra raspberry no dispone de mucha, según el modelo que tengáis y la carga que tenga vuestro sistema asignar este valor.

Importante también el directorio donde vamos a subir el fichero temporal, pensar que si lo dejáis por defecto es probable que os quedéis sin memoria en el SD, bueno con este ya hemos acabado vamos a por el siguiente

En el www.conf, se define la ip de escucha del php-fpm y el puerto.

sudo vi  /etc/php5/fpm/pool.d/www.conf
listen.allowed_clients = 127.0.0.1
listen = 0.0.0.0:9000
pm.max_children = 5
pm.start_servers = 2
pm.min_spare_servers = 1
pm.max_spare_servers = 3

Los valores de pm, son importantes, después de hacer diferentes pruebas los que pongo son suficientes para tener un rendimiento decente, por cierto mi raspberry es el modelo de 512MB.

Ahora reiniciamos el fpm


sudo /etc/init.d/php5-fpm restart

Para configurar nginx iremos al fichero nginx.conf


sudo vi /etc/nginx/nginx.conf

Bueno, en el fichero de configuración pondremos mas o menos lo que a cada uno nos interese, yo personalmente solo modifique las lineas siguiente,

user www-data;
worker_processes 4;
pid /var/run/nginx.pid;

events {
worker_connections 768;
# multi_accept on;
}

Ahora vamos a configurar el site para owncloud en nginx.

cd /etc/nginx/sites-available/
sudo vi owncloud

Dentro del fichero de owncloud pondremos, (mirar las rutas y modificaras según vuestro entorno.)

server {
listen 80;
root /var/www;
client_max_body_size 4096M;
listen 443 ssl;
server_name ***.***.com;
ssl_certificate /etc/nginx/ssl/server.crt;
ssl_certificate_key /etc/nginx/ssl/server.key;
location ~ .php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
include /etc/nginx/fastcgi_params;
try_files $uri =404;
fastcgi_param SCRIPT_FILENAME /var/www/$fastcgi_script_name;

}

location ~ ^/owncloud/remote.php(/.*)$ {
fastcgi_split_path_info ^(.+.php)(/.*)$;
fastcgi_pass 127.0.0.1:9000;
include fastcgi_params;
#rewrite ^ https://$server_name$request_uri? permanent;
fastcgi_param HTTPS on;

}

# owncloud <a class="zem_slink" title="WebDAV" href="http://en.wikipedia.org/wiki/WebDAV" target="_blank" rel="wikipedia">WebDAV</a>
location @webdav {
fastcgi_split_path_info ^(.+.php)(/.*)$;
fastcgi_pass 127.0.0.1:9000; # or use php-fpm with: "unix:/var/run/php-fpm/php-fpm.sock;"
fastcgi_param SCRIPT_FILENAME /var/www/$fastcgi_script_name;
include fastcgi_params;
fastcgi_param HTTPS on;
}
}

Los puntos en negrita son los que hay que tener cuidado, ya que depende de cada entorno. Este valor “client_max_body_size 4096M;”, debe ser el mismo que pusimos en php, que es el tamaño maximo del fichero que vamos a permitir, la parte de webDAV es necesaria en el caso que queramos utilizar el cliente de owncloud.

Vamos a crear los certificados para las conexiones SSL.

Los pasos son:

  1. Generar la clave RSA
  2. Generar el CSR(aqui el Common Name debe ser el nombre del dominio)
  3. Eliminar la clave privada DES3
  4. General certificado autofirmado
  5. Poner las rutas en el fichero de owncloud
openssl genrsa -des3 -out server.key 1024
openssl req -new -key server.key -out server.csr

Country Name (2 letter code) []:
State or Province Name (full name) []:
Locality Name (eg, city) []:
Organization Name (eg, company) []:
Organizational Unit Name (eg, section) []:
Common Name (eg, your name or your server's hostname) []:
Email Address []:
Please enter the following 'extra' attributes
to be sent with your certificate request
A challenge password []:
An optional company name []:

cp server.key server.key.org
openssl rsa -in server.key.org -out server.key
openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt

Ahora vamos a crear el link simbólico del site.

sudo ln -s /etc/nginx/sites-available/owncloud /etc/nginx/sites-enabled/owncloud

Comprobamos que la configuración es correcta.

sudo -i
nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful

Por ultimo, pero no menos importante, vamos a bajar el owncloud

wget http://mirrors.owncloud.org/releases/owncloud-4.5.7.tar.bz2
tar zvfj owncloud-4.5.7.tar.bz2
mv owncloud /var/www/ && chown -R www-data:www-data /var/www/owncloud

Por ultimo accedemos a la url http://ip/owncloud y empezamos la configuración, recordar que durante la configuración podréis elegir el lugar donde dejará los archivos.

Eso es todo,

Ale a disfrutarlo!