Copyright
Copyright © José
Luis Lara Carrascal 2010-2013 
Sumario
Introducción
Preliminares
Libtorrent-rasterbar
QBittorrent
Configurar el cortafuegos para qBittorrent
Iniciamos qBittorrent
Enlaces
Introducción
QBittorrent es la alternativa open source al cliente bitTorrent, uTorrent, con el beneficio para los usuarios de GNU/Linux de que es multiplataforma. Escrito en Qt4, es utilizado por muchas distribuciones pequeñas como el cliente predefinido para el protocolo BitTorrent.
En este manual trataremos su instalación desde cero,
además de la instalación de su principal dependencia, la
librería Libtorrent-rasterbar. Incluyendo también la configuración del cortafuegos en algunas de las principales distribuciones GNU/Linux, para habilitar el puerto correspondiente requerido para que qBittorrent pueda funcionar sin ningún problema.
Preliminares
1) Comprobar que la ruta de instalación de los binarios del programa la tenemos en nuestro PATH
Abrimos una ventana de terminal y ejecutamos el siguiente comando,
[jose@Fedora-18 ~]$ echo $PATH
/usr/lib/qt-3.3/bin:/usr/local/bin:/usr/bin:/bin:/usr/local/sbin:/usr/sbin:/sbin:/home/jose/bin
|
Si no aparece entre las rutas mostradas el directorio /usr/local/bin, abrimos un editor de texto y añadimos lo siguiente,
#!/bin/sh
export PATH=/usr/local/bin:$PATH |
Lo guardamos con el nombre variables.sh, y lo instalamos en /etc/profile.d.
$ su
# install -m755 variables.sh /etc/profile.d
|
Tenemos que cerrar el emulador de terminal y volverlo a abrir para que
la variable de entorno aplicada sea efectiva. Es conveniente guardar
una copia de este script para posteriores
instalaciones de nuestro sistema, teniendo en cuenta que es el que se
va a utilizar a partir de ahora en todos los manuales de esta web, para
establecer variables de entorno globales, excepto en aquellas que
sólo afectan al usuario, en las que se utilizará el
archivo de configuración personal, ~/.bashrc.
La ventaja de utilizar el directorio /etc/profile.d es que es común a todas las distribuciones y nos evita tener que editar otros archivos del sistema como por ejemplo, /etc/profile.
2) Establecer la variable 'PKG_CONFIG_PATH' requerida por el programa pkg-config
Establecemos la correspondiente variable de entorno para que el programa pkg-config
encuentre los archivos de referencia (*.pc) de las dependencias
requeridas en los procesos de compilación en curso, que se
instalarán en /usr/local/lib/pkgconfig.
En el archivo que hemos creado anteriormente (variables.sh) añadimos lo que está en rojo:
#!/bin/sh
export PATH=/usr/local/bin:$PATH
export
PKG_CONFIG_PATH=/usr/local/lib/pkgconfig:$PKG_CONFIG_PATH |
3) Comprobar que el directorio /usr/local/lib está incluido en /etc/ld.so.conf
En este apartado, no todas las distribuciones incluyen los directorios de las librerías compartidas a cachear por ldconfig en el archivo de configuración, /etc/ld.so.conf, también utilizan el directorio /etc/ld.so.conf.d, por lo que su edición sólo será necesaria en el caso de que el comando ldconfig no cachee las librerías compartidas ubicadas en /usr/local/lib, en ese caso, abrimos con un editor de texto, el archivo de configuración /etc/ld.so.conf y añadimos la ruta correspondiente. Un ejemplo:
/usr/X11R6/lib/Xaw3d
/usr/X11R6/lib
/usr/lib/Xaw3d
/usr/i386-suse-linux/lib
/usr/local/lib
/opt/kde3/lib
include /etc/ld.so.conf.d/*.conf |
4) Comprobar que la variable de entorno 'XDG_DATA_DIRS' incluye el directorio /usr/local/share
Esta variable se aplica para que los archivos desktop
ubicados en un directorio específico del sistema puedan ser
leídos por los menús de entornos gráficos
como XFce 4, o
paneles como LXPanel o Fbpanel.
Este aspecto es bastante delicado porque cada distribución es un
mundo y lo mejor que podemos hacer es establecer una variable de
entorno global que incluya todos los directorios predefinidos del
sistema que incluyen archivos desktop, siempre y cuando el directorio /usr/local/share
no esté incluido por defecto en la distribución de turno.
Para saberlo basta abrir el menú de aplicaciones en cualquiera
de los programas antes comentados y comprobar que aparece la entrada
correspondiente a la aplicación tratada en este manual. Si no es
así, en el mismo archivo /etc/profile.d/variables.sh, añadimos lo que está en rojo:
#!/bin/sh
export PATH=/usr/local/bin:$PATH
export
PKG_CONFIG_PATH=/usr/local/lib/pkgconfig:$PKG_CONFIG_PATH
export XDG_DATA_DIRS=/usr/share:/usr/local/share:$XDG_DATA_DIRS |
5) Desinstalar versiones anteriores del programa ubicadas en el directorio /usr
Aún en el caso de que la versión a compilar la vayamos a
instalar en el mismo directorio que la que proporciona la
distribución, siempre se debe desinstalar previamente la versión antigua, para evitar conflictos innecesarios.
Libtorrent-rasterbar
Libtorrent-rasterbar es una implementación en C++ del protocolo BitTorrent.
Instalación
Dependencias
Herramientas
de Compilación
Entre paréntesis la
versión con la que se ha compilado Libtorrent-rasterbar
para la elaboración de este documento.
* GCC - (4.7.2)
* Gawk - (4.0.2)
* M4 - (1.4.16)
* Libtool - (2.4.2)
* Make - (3.82)
* Automake - (1.13.1)
* Autoconf - (2.69)
* Pkg-config - (0.28)
Librerías
de Desarrollo
* Boost - (1.52.0)
* OpenSSL - (1.0.1e)
* Zlib - (1.2.7)
Descarga
libtorrent-rasterbar-0.16.9.tar.gz
Optimizaciones
$ export
{CFLAGS,CXXFLAGS}='-O3 -march=barcelona -mtune=barcelona'
|
| Donde pone barcelona
se indica el procesador respectivo de cada sistema
seleccionándolo de la siguiente tabla: |
* La opción '-march=' establece el procesador mínimo con el que funcionará el programa compilado, la opción '-mtune=' el procesador específico para el que será optimizado.
* Los valores separados por comas, son equivalentes, es decir, que lo mismo da poner '-march=k8' que '-march=athlon64'.
* En versiones de GCC 3.2.x e inferiores se utiliza la opción '-mcpu=' en lugar de '-mtune='.
|
| Valores |
CPU |
| generic |
Produce un código
binario optimizado para la mayor parte de procesadores existentes.
Utilizar este valor si no sabemos el nombre del procesador que
tenemos en nuestro equipo. Este valor sólo es aplicable en
la opción '-mtune='. Esta opción está disponible a
partir de GCC 4.2.x. |
| i386 |
Intel i386.
|
| i486 |
Intel i486. |
| i586, pentium |
Intel Pentium sin soporte de instrucciones MMX. |
| pentium-mmx |
Intel PentiumMMX basado en Pentium con soporte de instrucciones MMX. |
| pentiumpro |
Intel PentiumPro. |
| i686 |
Produce un código binario optimizado para la mayor parte de
procesadores compatibles con la serie 80686 de Intel. Todos los actuales lo son. |
| pentium2 |
Intel Pentium2 basado en PentiumPro con soporte de instrucciones MMX. |
| pentium3, pentium3m |
Intel Pentium3 basado en PentiumPro con soporte de instrucciones MMX y SSE. |
| pentium-m |
Versión de bajo
consumo de Intel Pentium3 con soporte de instrucciones MMX, SSE y SSE2.
Utilizado por los portátiles Centrino. |
| pentium4, pentium4m |
Intel Pentium4 con soporte de instrucciones MMX, SSE y SSE2. |
| prescott |
Versión mejorada de Intel Pentium4 con soporte de instrucciones MMX, SSE, SSE2 y SSE3. |
| nocona |
Versión mejorada de Intel Pentium4 con extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2 y SSE3. |
| core2 |
Intel Core2 con
extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2, SSE3 y
SSSE3. Esta opción está disponible a partir de GCC 4.3.x. |
| corei7 |
Intel Core i7 con
extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2, SSE3,
SSSE3, SSE4.1 y SSE4.2. Soporta también los procesadores Intel
Core i3 e i5. Esta opción está disponible a partir
de GCC 4.6.x. |
| corei7-avx |
Intel Core i7 con
extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2, SSE3,
SSSE3, SSE4.1, SSE4.2, AVX, AES y PCLMUL. Soporta también los
procesadores Intel Core i3 e i5. Esta opción está
disponible a partir de GCC 4.6.x. |
| core-avx-i |
Intel Core (ivyBridge) con
extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2, SSE3,
SSSE3, SSE4.1, SSE4.2, AVX, AES, PCLMUL, FSGSBASE, RDRND y F16C. Esta opción está disponible a partir
de GCC 4.7.x. |
| core-avx2 |
Intel Core (Haswell). Esta opción está disponible a partir
de GCC 4.7.x. |
| atom |
Intel Atom con extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2, SSE3 y SSSE3. Esta opción está
disponible a partir de GCC 4.5.x. |
| k6 |
AMD K6 con soporte de instrucciones MMX. |
| k6-2, k6-3 |
Versiones mejoradas de AMD K6 con soporte de instrucciones MMX y 3DNow!. |
| athlon, athlon-tbird |
AMD Athlon con soporte de instrucciones MMX, 3DNow!, enhanced 3DNow! y SSE prefetch. |
| athlon4, athlon-xp, athlon-mp |
Versiones mejoradas de AMD Athlon con soporte de instrucciones MMX, 3DNow!, enhanced 3DNow! y full SSE. |
| k8, opteron, athlon64, athlon-fx |
Procesadores basados en
AMD K8 core con soporte de instrucciones x86-64 (MMX, SSE, SSE2,
3DNow!, enhanced 3DNow! y extensiones 64-bit). |
| k8-sse3, opteron-sse3, athlon64-sse3 |
Versiones mejoradas de
AMD K8 core con soporte de instrucciones SSE3. Esta opción
está disponible a partir de GCC 4.3.x. |
| amdfam10, barcelona |
Procesadores basados en
AMD Family 10h core con soporte de instrucciones x86-64 (MMX, SSE,
SSE2, SSE3, SSE4A, 3DNow!, enhanced 3DNow!, ABM y extensiones
64-bit). Esta opción está disponible a partir de GCC 4.3.x. |
| btver1 |
Procesadores basados en
AMD Family 14h core con soporte de instrucciones x86-64 (MMX, SSE,
SSE2, SSE3, SSE4A, CX16, ABM y extensiones 64-bit). Esta opción está disponible a partir
de GCC 4.6.x. |
| bdver1 |
Procesadores basados en
AMD Family 15h core con soporte de instrucciones x86-64 (FMA4, AVX, XOP, LWP, AES, PCL_MUL, CX16, MMX, SSE,
SSE2, SSE3, SSE4A, SSSE3, SSE4.1, SSE4.2, ABM y extensiones
64-bit). Esta opción está disponible a partir
de GCC 4.7.x. |
| bdver2 |
Procesadores basados en
AMD Family 15h core con soporte de instrucciones x86-64 (BMI, TBM, F16C, FMA, LWP, AVX, XOP, LWP, AES, PCL_MUL, CX16, MMX, SSE,
SSE2, SSE3, SSE4A, SSSE3, SSE4.1, SSE4.2, ABM y extensiones
64-bit). Esta opción está disponible a partir
de GCC 4.7.x. |
| winchip-c6 |
IDT Winchip C6, que equivale a un i486 con soporte de instrucciones MMX. |
| winchip2 |
IDT Winchip2, que equivale a un i486 con soporte de instrucciones MMX y 3DNow!. |
| c3 |
Via C3 con soporte de instrucciones MMX y 3DNow!. |
| c3-2 |
Via C3-2 con soporte de instrucciones MMX y SSE. |
| geode |
AMD integrado con soporte de instrucciones MMX y 3DNow!. Esta opción está disponible a partir de GCC 4.3.x. |
| native |
Produce un código
binario optimizado para el procesador que tengamos en nuestro sistema,
siendo éste detectado utilizando la instrucción cpuid.
Procesadores antiguos pueden no ser detectados utilizando este valor.
Esta opción está disponible a
partir de GCC 4.2.x. |
Extracción
y
Configuración 
| Información general sobre el uso de los comandos |
En los comandos largos, seleccionar el comando desde su comienzo, omitiendo el símbolo ($ o #) y el espacio que existe entre éste y el comando. Una vez lo hemos seleccionado, pegarlo con el botón central del ratón sobre la
línea de comandos de la terminal, y darle a intro o enter. El comando se queda grabado en el historial de bash, por lo que podemos buscarlo con las flechas arriba y abajo del teclado para poder utilizarlo posteriormente, hasta que desaparezca del historial, si no volvemos a ejecutarlo y utilizamos otros comandos.
La barra inclinada hacia la izquierda (\) que aparece al final de la línea de algunos comandos, sirve para cortar el comando y poder seguir escribiéndolo en la siguiente línea. Cuando seleccionamos un comando cortado, y lo pegamos en la línea de comandos, la línea o líneas siguientes al comando de inicio aparecerán con el símbolo inicial (>), que indica la continuación del comando introducido en la siguiente línea. Le damos a intro o enter, y éste se ejecutará sin ningún problema. En el historial de bash, el comando aparecerá todo junto,
sin saltos de línea.
Los comandos de bucle que empiezan por for y terminan en done, hay que seleccionarlos desde for hasta done inclusive. Y luego realizar la misma operación de copiado y pegado que se explica en el comienzo de esta nota de
información.
|
$ tar zxvf libtorrent-rasterbar-0.16.9.tar.gz
$ cd libtorrent-rasterbar-0.16.9
$ export LDFLAGS="-Wl,-rpath,/opt/gcc-4.7.2/lib -lstdc++"
$ ./configure --disable-dependency-tracking
|
Explicación
de los comandos
export LDFLAGS="-Wl,-rpath,/opt/gcc-4.7.2/lib -lstdc++" : Si compilamos Libtorrent-rasterbar con una versión de GCC
que no es la principal del sistema, es decir, que la tenemos ubicada en
otro directorio, tenemos que añadir la variable de entorno de la versión de libstdc++.so
del compilador que vayamos a utilizar, porque de lo contrario,
será imposible la compilación de la librería, al no existir
ninguna referencia a esta librería en los archivos Makefile generados, con lo que, cuando se vaya a generar los binarios correspondientes, el enlazador dinámico ld, buscará la primera que encuentre, normalmente la que está en /usr/lib,
produciendo un error, al no ser la del compilador utilizado.
En este
caso y siguiendo el manual de instalación de GCC, la ruta correcta para GCC 4.7.2 es /opt/gcc-4.7.2/lib, a la que se le añade el nombre genérico (requerido por ld) de la librería, -lstdc++, si la versión a utilizar la tenemos en otro directorio, tendremos que cambiar sólo la ruta, /opt/gcc-4.7.2/lib por la de la librería del compilador en cuestión.
--disable-dependency-tracking
:
Acelera el tiempo de compilación.
Compilación
Parámetros de compilación opcionales
-j2
: Si tenemos un procesador de doble núcleo (dual-core), y el kernel
está optimizado para el mismo y es SMP, con este parámetro
aumentaremos el número de procesos de compilación
simultáneos a un nivel de 2 y aceleraremos el tiempo de compilación del programa de forma considerable.
-j4
: Lo mismo que arriba pero con procesadores de 4 núcleos (quad-core).
Instalación
como root
$ su
# make install-strip
# ldconfig -v |
Desinstalación
como root
1)
MODO TRADICIONAL
En el directorio de compilación
ejecutamos el siguiente comando como root:
2)
MODO MANUALINUX
El principal inconveniente del comando anterior es
que
tenermos que tener el directorio de compilación en nuestro
sistema para poder desinstalar el programa. En algunos casos esto
supone muchos megas de espacio en disco. Con el paquete de scripts que
pongo a continuación logramos evitar
el único inconveniente que tiene la compilación
de
programas, y es el tema de la desinstalación de los mismos
sin
la necesidad de tener obligatoriamente una copia de las fuentes
compiladas.
libtorrent-rasterbar-0.16.9-scripts.tar.gz
$ su
# tar zxvf libtorrent-rasterbar-0.16.9-scripts.tar.gz
# cd libtorrent-rasterbar-0.16.9-scripts
# ./Desinstalar_libtorrent-rasterbar-0.16.9 |
Copia de Seguridad
como root
Con este otro script creamos una copia de seguridad de los binarios
compilados, recreando la estructura de directorios de los mismos en un
directorio de copias de seguridad (copibin)
que se crea en el directorio /var. Cuando se haya creado el paquete comprimido de
los binarios podemos copiarlo como usuario a nuestro home
y borrar el que ha creado el script de respaldo, teniendo en cuenta que si queremos
volver a restaurar la copia, tendremos que volver a copiarlo al lugar
donde se ha creado.
$ su
# tar zxvf libtorrent-rasterbar-0.16.9-scripts.tar.gz
# cd libtorrent-rasterbar-0.16.9-scripts
# ./Respaldar_libtorrent-rasterbar-0.16.9 |
Restaurar la Copia de
Seguridad
como root
Y con este otro script (que se copia de forma automática
cuando
creamos la copia de respaldo del programa) restauramos la copia de
seguridad como root cuando resulte necesario.
$ su
# cd /var/copibin/restaurar_copias
# ./Restaurar_libtorrent-rasterbar-0.16.9
|
QBittorrent
Instalación
Dependencias
Herramientas de Compilación
Entre paréntesis la
versión con la que se ha compilado qBittorrent
para la elaboración de este documento.
* GCC - (4.7.2)
* Make - (3.82)
* Pkg-config - (0.28)
Librerías
de Desarrollo
*
Xorg o XFree86 - (Xorg 7.7 / xorg-server 1.14.0)
* Qt4 - (4.8.0)
* Libtorrent-rasterbar - (0.16.9)
* Boost - (1.52.0)
* GeoIP - (1.4.8)
Descarga
qbittorrent-3.0.9.tar.xz
Extracción 
| Información general sobre el uso de los comandos |
En los comandos largos, seleccionar el comando desde su comienzo, omitiendo el símbolo ($ o #) y el espacio que existe entre éste y el comando. Una vez lo hemos seleccionado, pegarlo con el botón central del ratón sobre la
línea de comandos de la terminal, y darle a intro o enter. El comando se queda grabado en el historial de bash, por lo que podemos buscarlo con las flechas arriba y abajo del teclado para poder utilizarlo posteriormente, hasta que desaparezca del historial, si no volvemos a ejecutarlo y utilizamos otros comandos.
La barra inclinada hacia la izquierda (\) que aparece al final de la línea de algunos comandos, sirve para cortar el comando y poder seguir escribiéndolo en la siguiente línea. Cuando seleccionamos un comando cortado, y lo pegamos en la línea de comandos, la línea o líneas siguientes al comando de inicio aparecerán con el símbolo inicial (>), que indica la continuación del comando introducido en la siguiente línea. Le damos a intro o enter, y éste se ejecutará sin ningún problema. En el historial de bash, el comando aparecerá todo junto,
sin saltos de línea.
Los comandos de bucle que empiezan por for y terminan en done, hay que seleccionarlos desde for hasta done inclusive. Y luego realizar la misma operación de copiado y pegado que se explica en el comienzo de esta nota de
información.
|
$ tar Jxvf qbittorrent-3.0.9.tar.xz
$ cd qbittorrent-3.0.9
|
Optimizaciones
$ sed -e '3s:thread:thread release:' -e '3aQMAKE_CXXFLAGS_RELEASE = -O3 -march=barcelona -mtune=barcelona' \
-i src/src.pro
|
| Donde pone barcelona
se indica el procesador respectivo de cada sistema
seleccionándolo de la siguiente tabla: |
* La opción '-march=' establece el procesador mínimo con el que funcionará el programa compilado, la opción '-mtune=' el procesador específico para el que será optimizado.
* Los valores separados por comas, son equivalentes, es decir, que lo mismo da poner '-march=k8' que '-march=athlon64'.
* En versiones de GCC 3.2.x e inferiores se utiliza la opción '-mcpu=' en lugar de '-mtune='.
|
| Valores |
CPU |
| generic |
Produce un código
binario optimizado para la mayor parte de procesadores existentes.
Utilizar este valor si no sabemos el nombre del procesador que
tenemos en nuestro equipo. Este valor sólo es aplicable en
la opción '-mtune='. Esta opción está disponible a
partir de GCC 4.2.x. |
| i386 |
Intel i386.
|
| i486 |
Intel i486. |
| i586, pentium |
Intel Pentium sin soporte de instrucciones MMX. |
| pentium-mmx |
Intel PentiumMMX basado en Pentium con soporte de instrucciones MMX. |
| pentiumpro |
Intel PentiumPro. |
| i686 |
Produce un código binario optimizado para la mayor parte de
procesadores compatibles con la serie 80686 de Intel. Todos los actuales lo son. |
| pentium2 |
Intel Pentium2 basado en PentiumPro con soporte de instrucciones MMX. |
| pentium3, pentium3m |
Intel Pentium3 basado en PentiumPro con soporte de instrucciones MMX y SSE. |
| pentium-m |
Versión de bajo
consumo de Intel Pentium3 con soporte de instrucciones MMX, SSE y SSE2.
Utilizado por los portátiles Centrino. |
| pentium4, pentium4m |
Intel Pentium4 con soporte de instrucciones MMX, SSE y SSE2. |
| prescott |
Versión mejorada de Intel Pentium4 con soporte de instrucciones MMX, SSE, SSE2 y SSE3. |
| nocona |
Versión mejorada de Intel Pentium4 con extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2 y SSE3. |
| core2 |
Intel Core2 con
extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2, SSE3 y
SSSE3. Esta opción está disponible a partir de GCC 4.3.x. |
| corei7 |
Intel Core i7 con
extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2, SSE3,
SSSE3, SSE4.1 y SSE4.2. Soporta también los procesadores Intel
Core i3 e i5. Esta opción está disponible a partir
de GCC 4.6.x. |
| corei7-avx |
Intel Core i7 con
extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2, SSE3,
SSSE3, SSE4.1, SSE4.2, AVX, AES y PCLMUL. Soporta también los
procesadores Intel Core i3 e i5. Esta opción está
disponible a partir de GCC 4.6.x. |
| core-avx-i |
Intel Core (ivyBridge) con
extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2, SSE3,
SSSE3, SSE4.1, SSE4.2, AVX, AES, PCLMUL, FSGSBASE, RDRND y F16C. Esta opción está disponible a partir
de GCC 4.7.x. |
| core-avx2 |
Intel Core (Haswell). Esta opción está disponible a partir
de GCC 4.7.x. |
| atom |
Intel Atom con extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2, SSE3 y SSSE3. Esta opción está
disponible a partir de GCC 4.5.x. |
| k6 |
AMD K6 con soporte de instrucciones MMX. |
| k6-2, k6-3 |
Versiones mejoradas de AMD K6 con soporte de instrucciones MMX y 3DNow!. |
| athlon, athlon-tbird |
AMD Athlon con soporte de instrucciones MMX, 3DNow!, enhanced 3DNow! y SSE prefetch. |
| athlon4, athlon-xp, athlon-mp |
Versiones mejoradas de AMD Athlon con soporte de instrucciones MMX, 3DNow!, enhanced 3DNow! y full SSE. |
| k8, opteron, athlon64, athlon-fx |
Procesadores basados en
AMD K8 core con soporte de instrucciones x86-64 (MMX, SSE, SSE2,
3DNow!, enhanced 3DNow! y extensiones 64-bit). |
| k8-sse3, opteron-sse3, athlon64-sse3 |
Versiones mejoradas de
AMD K8 core con soporte de instrucciones SSE3. Esta opción
está disponible a partir de GCC 4.3.x. |
| amdfam10, barcelona |
Procesadores basados en
AMD Family 10h core con soporte de instrucciones x86-64 (MMX, SSE,
SSE2, SSE3, SSE4A, 3DNow!, enhanced 3DNow!, ABM y extensiones
64-bit). Esta opción está disponible a partir de GCC 4.3.x. |
| btver1 |
Procesadores basados en
AMD Family 14h core con soporte de instrucciones x86-64 (MMX, SSE,
SSE2, SSE3, SSE4A, CX16, ABM y extensiones 64-bit). Esta opción está disponible a partir
de GCC 4.6.x. |
| bdver1 |
Procesadores basados en
AMD Family 15h core con soporte de instrucciones x86-64 (FMA4, AVX, XOP, LWP, AES, PCL_MUL, CX16, MMX, SSE,
SSE2, SSE3, SSE4A, SSSE3, SSE4.1, SSE4.2, ABM y extensiones
64-bit). Esta opción está disponible a partir
de GCC 4.7.x. |
| bdver2 |
Procesadores basados en
AMD Family 15h core con soporte de instrucciones x86-64 (BMI, TBM, F16C, FMA, LWP, AVX, XOP, LWP, AES, PCL_MUL, CX16, MMX, SSE,
SSE2, SSE3, SSE4A, SSSE3, SSE4.1, SSE4.2, ABM y extensiones
64-bit). Esta opción está disponible a partir
de GCC 4.7.x. |
| winchip-c6 |
IDT Winchip C6, que equivale a un i486 con soporte de instrucciones MMX. |
| winchip2 |
IDT Winchip2, que equivale a un i486 con soporte de instrucciones MMX y 3DNow!. |
| c3 |
Via C3 con soporte de instrucciones MMX y 3DNow!. |
| c3-2 |
Via C3-2 con soporte de instrucciones MMX y SSE. |
| geode |
AMD integrado con soporte de instrucciones MMX y 3DNow!. Esta opción está disponible a partir de GCC 4.3.x. |
| native |
Produce un código
binario optimizado para el procesador que tengamos en nuestro sistema,
siendo éste detectado utilizando la instrucción cpuid.
Procesadores antiguos pueden no ser detectados utilizando este valor.
Esta opción está disponible a
partir de GCC 4.2.x. |
Configuración
$ ./configure
$ sed -i 's:-lboost_thread:& -Wl,-rpath,/opt/gcc-4.7.2/lib -lstdc++:' conf.pri
|
Explicación de los
comandos
sed -i 's:-lboost_thread:& -Wl,-rpath,/opt/gcc-4.7.2/lib -lstdc++:' conf.pri : Si compilamos qBittorrent con una versión de GCC
que no es la principal del sistema, es decir, que la tenemos ubicada en
otro directorio, tenemos que añadir la variable de entorno de la versión de libstdc++.so
del compilador que vayamos a utilizar, porque de lo contrario,
será imposible la compilación del programa, al no existir
ninguna referencia a esta librería en los archivos Makefile generados, con lo que, cuando se vaya a generar el binario qbittorrent, el enlazador dinámico ld, buscará la primera que encuentre, normalmente la que está en /usr/lib,
produciendo un error, al no ser la del compilador utilizado.
En este
caso y siguiendo el manual de instalación de GCC, la ruta correcta para GCC 4.7.2 es /opt/gcc-4.7.2/lib, a la que se le añade el nombre genérico (requerido por ld) de la librería, -lstdc++, si la versión a utilizar la tenemos en otro directorio, tendremos que cambiar sólo la ruta, /opt/gcc-4.7.2/lib por la de la librería del compilador en cuestión. En el caso particular de qBittorrent se edita el archivo conf.pri mediante el uso del comando sed.
Compilación
Parámetros de compilación opcionales
Instalación como root
Directorios de configuración personal
| ~/.config/qBittorrent |
Es el directorio de configuración personal de qBittorrent en nuestro home. |
| ~/.local/share/data/qBittorrent |
Es el directorio de datos de qBittorrent en nuestro home. |
| ~/.cache/qBittorrent |
Es el directorio de caché de qBittorrent en nuestro home. |
Directorio de descarga predefinido
| ~/qBT_dir |
Es el directorio predefinido de descarga de los archivos torrent en nuestro home. Su ubicación se puede cambiar en las opciones del programa. |
Desinstalación
como root
1) MODO TRADICIONAL
En el directorio de compilación ejecutamos el siguiente comando como root:
2) MODO MANUALINUX
qbittorrent-3.0.9-scripts.tar.gz
$ su
# tar zxvf qbittorrent-3.0.9-scripts.tar.gz
# cd qbittorrent-3.0.9-scripts
# ./Desinstalar_qbittorrent-3.0.9 |
Copia de Seguridad
como root
$ su
# tar zxvf qbittorrent-3.0.9-scripts.tar.gz
# cd qbittorrent-3.0.9-scripts
# ./Respaldar_qbittorrent-3.0.9 |
Restaurar la Copia de Seguridad
como root
$ su
# cd /var/copibin/restaurar_copias
# ./Restaurar_qbittorrent-3.0.9
|
Configurar el cortafuegos para qBittorrent
A continuación pongo algunos ejemplos de configuración del cortafuegos de GNU/Linux, para habilitar el puerto correspondiente para poder trabajar con qBittorrent. No es nada recomendable utilizar el puerto predefinido, porque algunos ISP
suelen restringir las conexiones por el mismo. En los ejemplos que
pongo a continuación el puerto utilizado es el 58846.
Puerto que
tendremos que poner en las opciones del programa relacionadas con la
conexión a internet y habilitar también en el router en
el caso de que utilicemos uno para nuestra conexión a internet.
1) Arno's IPTABLES firewall
Es el script que utilizo para configurar y activar el cortafuegos en mi sistema,
muy recomendable en distribuciones que no traen una herramienta
gráfica para este cometido, o para usuarios que ya tienen una
cierta experiencia en el uso de GNU/Linux.
Abrimos como root, con un editor de texto el archivo de configuración, /etc/arno-iptables-firewall/custom-rules, y añadimos lo que está en azul, en rojo el número de puerto:
# Put any custom (iptables) rules here down below:
##################################################
#BITTORRENT
iptables -A INPUT -p tcp --destination-port 58846 -j ACCEPT
iptables -A OUTPUT -p tcp --source-port 58846 -j ACCEPT |
Lo guardamos y reiniciamos el script para actualizar las reglas del cortafuegos.
$ su
# /etc/init.d/arno-iptables-firewall restart |
2) System-config-firewall (Fedora)
Es el programa utilizado por la distribución Fedora para configurar el cortafuegos.
Si estamos en Gnome, seleccionamos en la barra superior, Sistema >> Administración >> Cortafuego. Se ejecutará el programa, y en el mismo, nos vamos a Archivos de Reglas Personalizadas. Para que esta opción esté habilitada tenemos que seleccionar Opciones >> Nivel del Conocimiento del Usuario >> Experto.
Abrimos un editor de texto y añadimos la regla correspondiente,
#BITTORRENT
-A INPUT -p tcp --destination-port 58846 -j ACCEPT
-A OUTPUT -p tcp --source-port 58846 -j ACCEPT |
Lo guardamos con el nombre reglas-iptables.txt, en nuestro home, en el ejemplo, en el directorio Documentos. Hacemos clic en Añadir, y se mostrará una ventana de diálogo. Buscamos el archivo creado con las reglas y seleccionamos en el apartado Tabla del Cortafuegos, la opción filter.
Finalmente hacemos clic en Aceptar y en Aplicar de la interfaz de configuración del cortafuegos.
3) YaST (openSUSE)
Si estamos en KDE, seleccionamos desde el menú del mismo, Sistema >> YaST (Configuración del administrador). Y una vez en éste, nos vamos a Seguridad y usuarios >> Cortafuegos.
Se abrirá la ventana de configuración del cortafuegos, hacemos clic en Reglas Personalizadas y luego en Añadir.
Dejamos el cuadro de diálogo de configuración de la regla
igual que el que aparece en la captura de pantalla y hacemos clic en
Añadir. Luego en Siguiente y en Terminar y las reglas
quedarán configuradas para el puerto indicado.
Iniciamos qBittorrent
Sólo
nos
queda teclear en una terminal o en un lanzador el comando qbittorrent,
y el programa aparecerá en la pantalla.
Enlaces
http://qbittorrent.sourceforge.net >> La
web de qBittorrent.
|