MeltIT
29Jan/102

Guía: Debian Linux Servidor de Descargas (torrent, jdownloader, ssh, samba, webserver) – Parte 2 Info Básica, Configuración y Programas


Iniciando el sistema:


Configuración de red

Comenzaremos con la configuración de la red, así podemos deshacernos del monitor y teclado, y administrar remotamente. La necesidad de una IP estática es por el hecho de que el servidor necesitamos que este siempre en la misma dirección, así lo encontraremos rápidamente. Esta guía de MeltIT explica como hacerlo. Lo único que hace falta luego de esto, es la instalación del servidor SSH y ya podremos desconectar teclado y monitor.

apt y utilización basica:

Como ya explique, apt, es el gestor de paquetes de Debian. Su uso es desde el usuario administrador (root). Lo más basico que hay que saber:

apt-get install nombre_del_paquete: Con este comando, descarga e instala un paquete.

apt-get remove nombre_del_paquete: Para eliminar un paquete del sistema.

apt-cache search descripción_o_nombre_del_paquete: Realiza una busqueda en la base de datos. Devuelve nombre del paquete - descripción. Muy útil para encontrar algún software.

Mantenimiento del servidor

apt nos facilita la tarea de mantenimiento, reduciendola a dos comandos (todos los comandos a continuación deben ser corridos como root):

apt-get update, que actualiza las listas de los repositorios (sitios de donde se descargan los paquetes), busca en internet actualizaciones de la lista de paquetes y las descarga.

apt-get upgrade, luego de apt-get update, con este se actualizan los paquetes a la ultima versión.

updatedb, para utilizar el comando locate nombre_de_archivo, genera una base de datos en base a los ficheros en el disco.

Instalación y configuración de openSSH, utilizando apt-get.

El servidor SSH es el encargado de inicio de sesión remoto por consola, lo cual es el eje central del control del servidor. A travez del SSH uno se conecta al servidor, e interactua como si estuviese en esa misma PC. A su vez, SSH, a contrario de telnet (otra forma de conectarse remotamente a un servidor por consola), brinda cifrado a la conexión, esto es, todos los datos están encriptados.

Procederemos a utilizar por primera vez el apt. apt-get install ssh, buscara el paquete SSH. A su vez, lo bueno de esto es que resuelve dependencias, esto es, todo lo que el programa necesite para funcionar, también será descargado, despreocupando al usuario y haciendo fácil la tarea de instalar y actualizar software. Pedirá una confirmación para descargar e instalar el programa y sus dependencias, le damos S de Sí, y aguardamos a que descargue e instale.

Conectándose al sistema de forma remota.

Aquí explicare como conectarse desde Windows. Utilizaremos PuTTY, que es un programa específicamente para esto. Desde otro linux, es tan simple como ir a una consola e indicar: ssh IP_DEL_SERVIDOR -l NOMBRE_DE_USUARIO_REMOTO. Es necesario indicar el nombre del usuario en el servidor, porque sino por defecto utilizara el nuestro de la computadora donde estemos.

Nos preguntara si queremos aceptar la clave, le ponemos que si.

Ponemos usuario y contraseña. Ya estamos logueados, el servidor esta funcionando con el servidor SSH. Ya podemos desconectar todo.

Nota importante: Antes de remover teclado y monitor, hay que ir al SETUP del BIOS, ya que en ciertos motherboard's esta habilitada la opción para que tire un error sino hay teclado conectado, y esto hay que deshabilitarlo, ya que no necesitamos de teclado.

Transfiriendo archivos entre el servidor utilizando SCP/SFTP:

Una vez instalado y funcionando el sistema, la forma básica de transferencia de archivos es el protocolo SCP ó SFTP. Utilizaremos estos, ya que, ademas de proveer una conexión segura, están incluidos en el SSH previamente utilizado.

Hay un cliente muy bueno para Windows, WinSCP.

El uso es simple, abrimos el WinSCP, indicamos la IP, el usuario y contraseña, y se nos abrira una interfaz bastante simple de utilizar, con drag&drop, y ya podremos copiar ficheros de y hacia el servidor.

Términos y comandos utiles en Linux:

El sistema es case-sensitive. Esto significa, que por ej, puede haber en un directorio 4 archivos: hola, holA, HOLA, HoLA, y son todos distintos, esto es porque las mayusculas y minisculas si importan en los nombres, y en muchos programas tambien, asi como en los argumentos de los programas (argumentos son palabras separadas por espacio que se ponen luego del nombre del comando, ej, apt-get update, update es el argumento numero uno que se le paso a apt-get).

Cuando se utiliza ~/ para indicar un archivo, significa que es relativo al home dir, esto es, /home/nombre_usuario, por defecto. Entonces, si mi usuario es c4b3z0n sería:

~/ = /home/c4b3z0n/

~/.vnc/ = /home/c4b3z0n/.vnc/

Asimismo, utilizando cd (change dir, cambiar directorio), sin parámetros extra, es como hacer cd ~, el cual cambia el directorio actual.

pwd, print working directory, imprime el directorio de trabajo (directorio en el que te encontras). Al iniciar sesión, el directorio de trabajo es ~, con lo cual un pwd, informará /home/c4b3z0n, en mi caso.

ls es como dir en Windows, lista los archivos del directorio actual. Para listar archivos ocultos  ls -a. Los archivos ocultos comienzan con un . en el nombre, a contrario de Windows, donde Oculto es un atributo.

localhost, es la misma PC, equivale a la IP, 127.0.0.1, también conocida como loopback, o adaptador lo.

La mayoría de los comandos/programas, traen una ayuda de como usar, y un manual.

Generalmente, utilizando un comando y agregandole -h ó --help (tip: con un guión, -, se utilizan por lo general (convención), comandos de una letra, ej -h. Cuando se utilizan dos guiones, se utiliza la palabra completa, ej --help), obtendremos ayuda de su uso. Hay muchos casos en que -h significa human-readable (como en ls -h), lo que significa es que en vez de mostrar la información en bytes la muestra en KB, MB, ó GB.

Ejemplo, ping --help ó ping -h. Esto mostrara los argumentos de uso. En los argumentos, los que aparezcan entre [ ], significa que son opcionales. Sino son obligatorios. Otro caso es, por ej, programa [--opcional] [-A con_parametro] [-b|-c|-d] obligatorio. En este ultimo caso, programa recibe, --opcional, como totalment opcional. Luego, -A recibe un parametro adicional. Y -b, -c y -d, son opcionales, pero solo puede ser uno de ellos, no se combinan estos tres, pero si con --opcional y/o -A. obligatorio es obligatorio.

Por otro lado, para ver el manual de alguna aplicación o comando, se utiliza man. Ejemplo, man ifconfig, ó man ping. (De los manuales se sale con la letra q)

Control básico de procesos en una consola.

A primeras apariencias, una consola es single-task, no corre más de una aplicación en paralelo. Pero en realidad tenemos una sesión, y si podemos correr aplicaciones en paralelo. Cuando estemos en una tarea, ejemplo un "updatedb" ó haciendo un ping, con presionar:

Ctrl+C (control y la letra C al mismo tiempo), matar el proceso.
Ctrl+Z, la frenamos y mandamos a 'background', segundo plano.

Para reanudarla,

fg, "trayéndola" a primer plano nuevamente.

bg, para que siga corriendo en segundo plano.

Mediante el comando jobs, podemos ver el estado y tareas que halla en segundo plano. Asimismo, aquí veremos el número de tarea, que podemos utilizar para, traer a primer plano, reanudar, o matar el proceso. Ej, fg %1 ó bg %1. El % hace referencia a que es el numero de job. Para matar un proceso, hay tres formas. La primera ya la vimos, con Ctrl+C a un proceso en el primer plano. La seguna es mediante kill %numero_de_job, lo mismo que en fg y bg. Y por ultimo, kill pid. PID es Process ID. Es un identificador del sistema para cada proceso. Este lo obtenemos utilizando ps, para ver nuestros procesos activos. O ps aux, para ver todos los procesos activos del sistema.

Para iniciar un proceso directamente en segundo plano, basta con agregrar un & al final, y listo. Ejemplo, updatedb &. Asimismo, se pueden iniciar varios procesos juntos, updatedb & apt-get update.

Otra opción, es iniciar un programa cuando termina otro. Esto es, en el proceso de actualización, primero actualizamos la lista de paquetes, luego los paquetes, y por ultimo podemos actualizar la base de datos para busqueda de ficheros:

apt-get update && apt-get upgrade && updatedb

El operador &&, hace que cuando termine el proceso, inicie el siguiente.

Instalación y configuracion de sudo:

sudo es una utilidad que permite ejecutar comandos como administrador, desde un usuario común. Es muy utilizado en Ubuntu, pero en Debian no viene por defecto. Hasta el final de la guía, será utilizado frecuentemente, y recomiendo su instalación por comodidad. En MeltIT esta publicado como instalarlo y configurarlo.

Descargas FTP/HTTP con wget:

wget, es una utilidad para descargar archivos de la web, mediante su URL. El uso básico es wget url, esto descarga al directorio actual, la url especificada. Tiene más modificadores, pero para descargar un archivo de la web basicamente, se utiliza la sintaxis mencionada.

Configuración y carpetas en red con SAMBA:

Con samba, se pueden poner carpetas en red, para que sean accesibles como carpetas compartidas por sistemas Windows. Guía en MeltIT.

Montando carpetas compartidas de la red Windows, con smbfs/cifs:

Hice una guía en MeltIT de como montar carpetas compartidas en PC's Windows, con smbfs/cifs.

VNCServer + fluxbox + uTorrent + JDownloader + GUI + X11 server + apps:

A partir de acá, la guía se basara en la instalación de un servidor vnc, donde correrá el servidor X que se accederá remotamente. Esto es, por la necesidad, en algunos casos, y posibilidades que da al sistema.

Instalación del servidor VNC y fluxbox - como acceder al servidor vnc:

Hay una guía publicada en MeltIT, que cubre este punto, y no debería haber problemas continuando desde esta.

Instalación de Java y JDownloader para RapidShare, MegaUpload, etc.

Ya publique en MeltIT una guía, esta bastante explicita como para entenderla perfectamente desde esta guía.

uTorrent con Web UI:

Es vital una Web UI (User Interface, intefaz de usuario) para los torrent, ya que de tener el .torrent en una PC, es una forma fácil de abrirlo en el servidor (mediante un click a Upload). Sino sería una tediosa tarea, la de transferir vía WinSCP, u otro, los archivos y luego abrirlos en el servidor, mediante PuTTY por ej.

Opte por uTorrent por ser la solución mas liviana y con Web UI integrada. Si bien es de windows, corre en Linux perfectamente con wine (un programa que se encarga de esto, correr aplicacions de windows en Linux). La guía en MeltIT.

29Jan/100

Guía: Debian Linux Servidor de Descargas (torrent, jdownloader, ssh, samba, webserver) – Parte 1 Instalación

¿Porque Debian?.

En base a las distribuciones que he probado, aunque han sido pocas, reduje mis opciones inicialmente a dos, Arch (ArchLinux) y Debian. Ambas vienen en formato de 'netinst', imagenes de CD muy pequeñas (menores a 200MB) y descargan todo por internet, para ser sistemas base.

Finalmente, opte por Debian. La filosofia de Arch, es configurar todo manualmente y entender como funciona. Debian tiene una filosofia de ser universal, disponibilidad de arquitecturas, gran cantidad de paquetes, es más simple de dejar andando. Un ArchLinux es interesante porque depende del usuario la configuración de paquetes, auto-arranque, pero exige una demanda de tiempo más importante a la hora de configurar, aunque deja mayores conocimientos.

La idea de esta guía es apuntar a usuarios novatos y que no se queden en el intento, asimismo hacerse con un servidor de descargas de manera rapida y efectiva, y tambien va a haber usuarios que no les interese aprender mucho de Linux y solo quieran el servidor, a quienes tambien va esta guia. De todas formas, Debian me sigue pareciendo una excelente distribución, y en mi tiempo en Linux, Arch me llevo a aprender otras cosas que en Debian no aprendí, por las auto configuraciones entre otras cosas. Si alguien realmente esta interesado, pegarle una hojeada a la wiki de Arch le podría interesar. De lo contrario, esta guia tratara de ser completa en términos de explicar, así como simple para quien solo desee dejar un servidor andando.

Preparación del sistema:

Hardware:

No se requiere un gran sistema para correr esto. En caso de que se este comprando una PC nueva, algo barato y básico a día de hoy, un Sempron 140, 1GB de ram, disco a gusto, yo soy fanático de 1TB+, pero es más por el bolsillo, motherboard, con video integrado bastara, un biostar barato. Monitor y teclado serán necesarios únicamente durante la instalación.

En caso de tener Hardware en casa, cualquier PC vieja bastara. Algo como un Celeron 1000MHz, 256MB+ de RAM, esta bien. No tengo más detalles ni como testear, pero es cuestión de probar. Creo que lo más importante acá es el disco, porque define cuanto vamos a poder descargar. El hardware en si no tiene que ser tan potente.

Según free (comando que muestra la utilización de memoria), en un sistema con 128MB de RAM, el sistema, con vncserver, xterm, JDownloader y uTorrent corriendo, reporta 40MB de memoria disponible. Lo único, el JDownloader y el uTorrent sin descargas, pero para dar una idea.

Software:

Descarga de la imagen de cd: Vamos a descargar la imagen de CD netinst, que es la instalación de un sistema base y luego la obtención de paquetes via web. Las descargas se encuentran en la pagina de debian. Seleccionar la arquitectura correcta y de 180MB. La arquitectura sera generalmente i386 (para procesadores de 32bits), o amd64 para procesadores de 64bits. Si no estas seguro, seguramente sea i386.

Luego de descargada la imagen de CD (archivo .iso), solo queda grabarla. Se puede utilizar un software gratuito como ImgBurn. Recordar que hay que grabar la imagen de cd, y no grabar el archivo en el disco. En el ImgBurn, la opción es Burn Image to Disc.

Instalación del sistema operativo.

Preparación.

Ahora queda reiniciar la PC con el CD puesto. Si el CD no carga al iniciar la computadora, entonces hay que ir al SETUP del BIOS y buscar una opción donde se eligen prioridades (boot device priority) para la carga de las unidades y poner el CD en primer lugar.

Iniciando la instalación:

En el menú de instalación nos aparecerán una serie de opciones. En esta guía, vamos a optar por el Install común, que es una suerte de grafico, pero sin mouse, todo con el teclado.

En el primer paso, seleccionamos el idioma. Luego el país.

Ahora nos da la opción de elegir el tipo de teclado. En mi caso, acostumbro a utilizar el Español, otra opción puede ser el Latinoamericano.

El primer paso acerca de la red, es asignarle un nombre a la PC. En mi caso utilice "meltitdescargas".

Luego en dominio, no utilizamos nada ya que es innecesario para la red local.

Luego la red se intentará configurar automáticamente por DHCP. En la mayoria de los casos, la configuración será automática (router).

Particionado:

Lo básico a tener en cuenta, es que vamos a crear 3 particiones clave, estas son / (root, raíz en ingles), /home (directorio de los archivos de usuario), y un swap (partición de intercambio, algo como el pagefile.sys, la memoria virtual, de windows).

En Linux no se utilizan letras de unidad, sino que las distintas particiones tienen puntos de montaje. Sería algo como que en windows, las carpetas como Mis Documentos, en vez de ser, por ejemplo, C:\Mis Documentos, serían otra unidad, como D:, y al ingresar a C:\Mis Documentos, vemos el contenido de D:. En Linux por ej, si separamos /home del root, realmente podemos acceder desde /, a /home, pero el contenido de home, esta en otra partición/disco. Esto es útil por ejemplo si queremos cambiar de distribución, o reinstalar el sistema sin perder los datos de usuario. Tiene otros usos, como asignar distintos tipos de sistema de archivos. El caso de swap, puede ser un archivo o una partición independiente, en este caso utilizaremos una partición.

Ahora pasare a explicar en si que son estas particiones, y que espacio recomendado para estas:

/ - root, raiz: Acá se encontraran todos los archivos, programas, configuraciones, etc. En la guía utilice 2.5GB, lo cual es suficiente sino se va a instalar un entorno grafico. De ser posible, y para estar seguro, 10GB será más que suficiente, ya que lo que ocupara mucho espacio, serán los archivos de usuario, los cuales estarán en otra partición.

/home - archivos de usuario: Acá estarán todos los ficheros de los usuarios, descargas, configuraciones. Queremos utilizar todo el espacio posible así tenemos más lugar para descargas.

swap - area de intercambio: Este espacio en disco es utilizado con dos fines: Hibernación y una especie de memoria extra, por si el sistema se queda sin RAM. En sistemas con poca memoria, menos de 256MB, sería conveniente optar por 2x la memoria, 512MB de intercambio. Sistemas hasta 512MB, estimo que estarían bien con 1,5x la memoria. Y de 512MB para arriba, 1x. Esto es porque el mínimo para hibernar, es 1x. Y son "apenas" unos pocos MB que estamos destinando del disco. No significa que es completamente necesario, pero en caso de que suceda algo que requiera esta memoria extra, no habrá problemas.

Armando las particiones: Seleccionaremos particionado manual. Ahora seleccionaremos el disco a particionar.

El primer paso es eliminar todas las particiones, entrando a cada una en el menú y seleccionando eliminar. A menos que se quiera mantener alguna.

Primero crearemos la partición raíz. Seleccionamos el espacio libre. Tipo de partición, Primaria. Tamaño, 2.5GB, 5GB o 10GB, yo opte por 2.5GB. Ubicación, principio. Luego el punto de montaje debe ser /. Y la "marca de arranque", activada. Utilizar como: ext3. Este es el sistema de archivos, ext3 se usa bastante (actualmente se esta comenzando a utilizar ext4), otra opción que utilizo (en lo personal) es ReiserFS, pero en esta guía utilizare ext3.

Segunda partición, de intercambio. Nuevamente seleccionamos el espacio libre. Esta vez, utilizaremos partición lógica. Tamaño, como discutido anteriormente, yo utilizare 512MB. Ubicación, principio. Utilizar como: Área de intercambio.

Tercera partición, /home. Seleccionamos el espacio libre. Partición lógica. Tamaño, "max", como palabra clave para utilizar todo el espacio disponible. Ubicación, principio.

Utilizar como: ext3. Punto de montaje /home.

Finalmente, "Finalizar el particionado y escribir los cambios al disco". Pedirá confirmación, y las particiones ya quedaran creadas y formateadas.

Usuarios y contraseñas

En primera instancia, vamos a configurar la clave del superusuario (root), que es el administrador. Cabe destacar la importancia de esta contraseña, y que el uso de este usuario es solo para tareas administrativas.

Luego crearemos un usuario, el primer paso es indicar su nombre completo.

Luego nos mostrara el primer nombre, todo en minúscula, como nombre de usuario para iniciar sesión, podemos dejarlo o cambiarlo a gusto.

En tercera instancia, le crearemos la contraseña y su verificación.

Configuración del gestor de paquetes

Aca nos encontramos con una de las partes clave del sistema Debian, APT. Es un gestor de paquetes, que explicare más adelante, el cual es muy útil y fácil de utilizar.

Primero debemos seleccionar un país, si la ubicación es más cercana, deberíamos tener menos ping, y mejores velocidades.

Yo voy a seleccionar una réplica de Estados Unidos, porque me paso en cierta situación que seleccione una Argentina y no funciono, pero deberían andar todas.

Luego seleccionamos en efecto el servidor.

Si estamos utilizando un proxy, completamos los datos, sino continuamos.

Nos pregunta si queremos participar del popularity contest. Es indiferente, son unicamente estadisticas, aunque es colaborar la participación.

Luego seleccionamos los paquetes, solo utilizaremos "Sistema estandar".

Gestor de arranque

El siguiente paso, es la instalación del gestor de arranque GRUB, el cual se encargara de iniciar el sistema. El instalador solo pide confirmación y la instalación es automática.

Y la instalación ha finalizado. Retiramos el CD, reiniciamos y esta listo para iniciar el nuevo sistema.

La continuación de esta guía, aquí.

29Jan/101

Linux: Compartir carpetas con SAMBA.

samba, sirve para compartir carpetas con Windows y otras PC's en red. Se pueden dar permisos por directorio, etc. Esta es una introducción básica.

Voy a estar mostrando como hacer esto en Debian y Arch. Voy a indicar utilizando sudo, acá hay una guía, por si quieren instalarlo.

Instalando lo necesario:

Necesitaremos samba unicamente.

sudo apt-get install samba, en Debian.

sudo pacman -S samba, en ArchLinux.

Configurando usuarios:

Por cada usuario de samba, debe existir el usuario en el sistema. El comando para agregar usuarios en el sistema es sudo useradd nombre_usuario. Acá hare de muestra que tenemos el usuario ya andando, en mi caso es c4b3z0n.

La info, la encontre inicialmente aquí.

sudo nano /etc/samba/smb.conf, que es el archivo de configuración de samba.

En la parte de Authentication, donde dice security = user, va a estar comentada la línea. Hay que descomentarla. Esto hace que samba pida usuario y contraseña para acceder a las carpetas/archivos.

Debajo de esa línea, agregar: username map = /etc/samba/smbusers, que indica un archivo de configuración donde estaran los usuarios del sistema relacionados a los usuarios de samba, esto es, se pueden utilizar distintos nombres en samba para acceder a las carpetas.

sudo smbpasswd -a <nombre_usuario>, para crearle una contraseña al usuario.

sudo nano /etc/samba/smbusers, y aquí el formato es: <nombre_usuario_sistema> = "<nombre_usuario_samba>". Ejemplo, en mi caso, voy a darle a c4b3z0n el nombre "archivos".

c4b3z0n = "archivos".

Ya esta listo el usuario(s).

Compartiendo los directorios home:

En la parte Share Definitions, donde dice [homes], debe quedar algo así:

[homes]
comment = Home Directories
read only = yes
browseable = no
valid users = %S

#para poder escribir,  descomentar la siguiente linea y comentar el read only
#writeable = yes

Compartiendo directorios:

Al final del archivo, agregamos:

[nombre_para_compartir]
comment = Un comentario para el directorio
read only = no
writeable = yes
path = /usr/some/dir
valid users = usuario otrousuario

nombre_para_compartir: El nombre con el cual aparecera el directorio, reemplazar.

comment: Es un comentario, realmente no es necesario.

read only: Define si es solo lectura el acceso. Debe ser lo contrario a writeable. yes ó no.

writeable: Define si se puede escribir en el directorio. Debe ser lo contrario a read only. yes ó no.

path: Define el directorio a compartir. Recordar que el usuario debe tener permisos para poder acceder/modificar ese directorio (el usuario del sistema).

valid users: Usuarios validos para el recurso compartido, enumerados por espacio.

Estas son opciones básicas para compartir directorios con samba.

Filed under: Basics, Linux, Server 1 Comment
29Jan/103

Montar carpetas compartidas de Windows en Linux con smbfs/cifs.

Si tenemos computadoras en la red con Windows y queremos leer los archivos de estas, debemos montar las carpetas con smbfs/cifs.

Archivos necesarios: en Debian: sudo apt-get install samba. De preguntar por un grupo de trabajo (WORKGROUP), usar el que tiene las PC's de Windows. En ArchLinux: sudo pacman -S samba.

Información necesaria:

En ambos casos, necesitaremos cierta información:

Tipo de sistema de archivos: cifs. Es el que utilizamos para carpetas compartidas en red.

Opciones: Puede ser opcional, es un nombre de usuario y contraseña en la computadora destino, en caso de necesitarse. username=usuario,password=contraseña. En mi caso, usuario c4b3z0n, contraseña 12345678.

Recurso: El formato es //host/carpeta. Es donde se encuentra la carpeta que deseamos montar. El host es la IP destino. Dando de ejemplo la carpeta compartida "documentos" en el host "10.0.0.18": //10.0.0.18/documentos.

Destino: Carpeta en la cual accederemos al recurso remoto. De ejemplo, una carpeta, /mnt/documentos_windows. Debe existir, sino debemos crearla antes. Generalmente, se utiliza el directorio /mnt/ para montar, no es necesario, pero acá vamos a mostrar utilizando este.

sudo mkdir mnt/documentos_windows, la carpeta destino debe existir, asique la creamos.

Montando carpetas temporalmente - mount:

Utilizare mount, para demostrar como montar temporalmente. Debe ser ejecutado como root. La sintaxis que utilizaremos es mount [-t tipo_sistema_de_archivos] [-o opciones] recurso destino.

sudo mount -t cifs -o username=c4b3z0n,password=12345678 //10.0.0.18/documentos /mnt/documentos_windows

luego, cd /mnt/documentos_windows y con ls, nos deberían aparecer las carpetas y archivos correctamente.

Montando carpetas de forma automatica - /etc/fstab:

sudo nano /etc/fstab

El archivo /etc/fstab, es el que se lee y utiliza en el comando mount -a, que se realiza al inicio del sistema. El formato lo vemos en el archivo, comentado:

<file system (recurso) > < mount point (destino) > < type (tipo sistema de archivos) > < options (opciones) > < dump > < pass >

Son separados por un TAB ó ESPACIO. dump y pass los utilizaremos en 0 ambos.

Lo cual nos queda en:

//10.0.0.18/documentos    /mnt/documentos_windows      cifs      username=c4b3z0n,password=12345678     0      0

Para aplicar estos cambios, sudo mount -a. Al iniciar el sistema, automáticamente se montaran las carpetas aquí configuradas.

Nuevamente, cd  /mnt/documentos_windows y con ls deberíamos ver todos los archivos y carpetas.

Filed under: Basics, Linux, Software 3 Comments
29Jan/100

Instalación de sudo en Debian y Arch Linux

sudo es una utilidad que permite ejecutar comandos como administrador, desde un usuario común. Es muy utilizado en Ubuntu, ya que por defecto no se puede iniciar sesión con root.

apt-get install sudo, en Debian. pacman -S sudo, en ArchLinux.

Luego de esto, debemos agregar nuestro usuario para que pueda utilizarlo. Para editar la configuración, hay que utilizar visudo. Esto nos abrirá el editor de texto nano con el archivo cargado (o con vi talvez). Tenemos que agregar, debajo de la linea que empieza con "root", lo siguiente:

nombre_de_usuario ALL=(ALL) ALL

En mi caso queda como c4b3z0n ALL=(ALL) ALL. Guardamos y salimos (F2, con nano). Y ya prescindimos de iniciar sesión como root.

La utilización es simple, nada más hay que anteponer sudo al comando, y ya esta. Ejemplo, sudo /etc/init.d/networking restart y la primera vez nos va a pedir la contraseña, luego por unos minutos no la va a requerir más, o hasta el siguiente login.

Para que no requiera contraseña sudo (en ningun momento), se puede utilizar el modificador NOPASSWD, y la línea quedará así:

nombre_de_usuario ALL=NOPASSWD: ALL

Nota: Para cambiar en Arch el editor de vi a nano, hay que cambiar la variable de entorno EDITOR. Para hacer esto, export EDITOR=nano, y ya esta.


Filed under: Basics, Linux, Software No Comments
28Jan/108

Linux: Configuración Internet/IP manual (permanente y temporal) – route, nameserver, interfaces, ifconfig, gateway

Iniciamos sesión con root, ya que estaremos realizando actividades administrativas.

Si tenemos DHCP, podemos extraer los datos de configuración del mismo. Para verificar si tenemos internet, bastara con hacer ping 8.8.8.8, que son unos DNS de Google, y seguramente hará el ping correctamente, si es que estamos correctamente conectados a internet y configurado por DHCP. De no tener DHCP, se deberían tener los datos para configurar, más abajo explica como. Escribimos ifconfig y nos aparecerán varios datos. Buscamos dentro de eth0 probablemente, o eth1 si se tienen dos placas de red puede llegar a ser (recordar esto). eth0 y eth1, son las interfaces, las placas de red. Lo que nos interesa es: inet addr, Mask. Y para terminar de obtener datos, utilizaremos route, que nos dirá el router (gateway, linea donde el destination es default, en mi caso 10.0.0.2), y ya tendremos todo lo necesario para configurar la IP. Para una configuración estática se necesitan estos datos, para un cambio de IP, se necesitan menos, si es que se desea que sea temporal.

Procederemos a establecer la configuración. Generalmente, la IP será, por ejemplo:

Si tenemos un Mask (netmask, mascara de subred) de 255.255.255.0, y una inet addr como 192.168.0.XXX (es indiferente el valor del ultimo campo), entonces podemos solo cambiar el ultimo octeto (se le dice así a cada valor entre los puntos). Y el valor debe ser entre 1 y 254 inclusive. Visto de otra forma, los octetos que en la mascara sean de 255, deben permanecer iguales.

En mi caso, mi IP era 10.0.0.9, y mi mask 255.255.255.0, entonces utilizo 10.0.0.201 [Es un numero alto 201, ya que mi router tiene DHCP, y es posible que si prendo una PC cuando el servidor este apagado, la .9 sea utilizada por otra PC, otra buena practica sería limitar el rango DHCP del router, pero eso es otro tema]. Recordar que esta IP no puede ser igual a ninguna en la red, ni como la del router.

Nota: En los archivos, desde un # hacia el final de esa línea, es un comentario, significa que la maquina no lo interpreta, es únicamente para ayudar al usuario.


Editando resolv.conf - nameserver - servidores dns:

nano /etc/resolv.conf

En este archivo, agregaremos los nameservers, o servidores DNS.

La sintaxis es simple, en cada linea agregamos nameserver ip_servidor.

En esta guía utilizare los Servidores DNS de Google. El motivo, son fáciles de recordar y tienen buen ping. Realmente se pueden utilizar cualquiera, los del ISP, o otra alternativa gratuita.

El fichero (/etc/resolv.conf) nos quedara así:

nameserver 8.8.8.8
nameserver 8.8.4.4

Luego de editarlo, nada más con guardar, ya se aplican los cambios. Presionamos F2 para Guardar y Salir (ó Ctrl+O), S de Sí para confirmar, y luego Enter, para guardar el fichero en la misma ubicación. El programa saldrá automáticamente con F2, sino Ctrl+X para salir.

Abajo explicare como realizar cambios permanentes o temporales (hasta reinicio). Realmente no hay necesidad de cambiar los nameserver's y este paso es necesario para ambos metodos explicados abajo.

Editando interfaces - configuración permanente:

nano /etc/network/interfaces

En primera instancia, agregaremos un # al inicio de la línea iface eth0 inet dhcp, de esta forma deshabilitamos la configuración automática por DHCP.

Ya tenemos todos los datos para configurar la IP, procedemos a agregarlos al archivo:

iface eth0 inet static
address 10.0.0.201 # La IP que elaboramos y la cual sera la del servidor de ahora en más
netmask 255.255.255.0 # La Mask que habiamos rescatado anteriormente de ifconfig
gateway 10.0.0.2 # Lo obtuvimos del comando route

Hemos terminado de configurar la red de forma permanente. Procedemos a reinicializarla para refrescar los cambios: /etc/init.d/networking restart

Para probar, bastara con ifconfig, route, y un ping google.com (para finalizar este ultimo, Ctrl+C). Si todo es satisfactorio, veremos ifconfig con la IP que configuramos, route con el router, y el ping sera correcto. Es importante que el ping sea a un dominio, para verificar si el DNS funciona, porque si hacemos ping a una IP, como sea 8.8.8.8, puede estar mal configurado el DNS y sin embargo el ping lo hace, porque no tiene que resolver ningún nombre de dominio.

Configuración temporal y/o parcial (hasta reinicio) - ifconfig + route:

La configuración puede ser parcial, en el caso de que el sistema ya este correctamente configurado por DHCP. En ese caso, un cambio de IP nada más alcanzara.

Este proceso consta de dos partes, configurar la ip, y agregar el gateway. Sintaxis de ifconfig: ifconfig interface [ip] [netmask xxx.xxx.xxx.xxx]. Entre [] significa opcional. Entonces, podemos configurar en una línea o dos. Siendo la ip 10.0.0.201, el netmask 255.255.255.0 y la interfaz eth0:

ifconfig eth0 10.0.0.201 y ifconfig eth0 netmask 255.255.255.0

ó en una línea: ifconfig eth0 10.0.0.201 netmask 255.255.255.0

Cabe destacar, que se puede hacer solo la configuración de la IP o del netmask, no es obligatorio que sean ambos. Si ya esta configurado por DHCP, entonces únicamente con el cambio de IP alcanza.

Para tener en cuenta, ifconfig eth0 down, por ejemplo, deshabilita la interfaz eth0. Para habilitarla nuevamente, ifconfig eth0 up.

La sintaxis de route que vamos a ver es básica, para agregar y eliminar el default gw (default gateway, puerta de enlace predeterminada). Estoy mostrando con 10.0.0.2 como gateway.

Para agregar default gw: route add default gw ip

Para eliminar default gw: route del default gw ip

Aplicado en mi caso: route add default gw 10.0.0.2


Posibles errores:

Network is unreachable: El problema es el gateway, un ping al area local debería funcionar y uno a un host externo, como 8.8.8.8, no.

Unknown host (example.com): El problema son los DNS, no se puede resolver el dominio. Tambien puede ser porque el dominio no existe, ó el gateway esta mal configurado y no se puede resolver el dominio.

Recordar que acá muestro nada más que el concepto minimo para configurar una red, ifconfig de por si tiene más opciones, y lo mismo con interfaces.