Recordar primeros pasos por Linux

0
21417

Primeros pasos por Linux

Muchas veces me escribe gente diciéndome que los tutoriales en
www.adictosaltrabajo.com son muy
avanzados.

Todo esto tiene una explicación:

En mi empresa, www.autentia.com nos
dedicamos a dar formación y soporte de desarrollo a otras empresas de
desarrollo de Software o a grandes empresas finales. Como podréis entender,
no nos contactan para cosas triviales sino que, bien porque su gente
cualificada está muy ocupada o porque acaban de llegar a estas tecnologías
(Java / J2EE / C++ / Linux / OpenSource), nos hacen encargos avanzados:
Arquitectura J2EE, auditorias de código, desarrollo de componentes a medida,
subcontratación de pequeños proyectos completos, etc.. Los conocimiento que
tenemos que manejar son avanzados ….

Hoy, que he empezado a repasar Linux (también impartimos cursos «básicos»), voy a aprovechar para capturar
unas pantallas que os puedan ayudar a repasar conceptos básicos en Linux (para
los que lo tengáis oxidado). No tienen muchas explicaciones porque
son muy visuales los ejemplos … simplemente os invito a reproducirlos …

Voy a usar la distribución Debian que viene como imagen en el emulador Qemu
(visitad el tutorial anterior

http://www.adictosaltrabajo.com/tutoriales/tutoriales.php?pagina=qemuwin
)…. espero que os sea útil.

Arranque y primeros comando

Una vez logados en Linux, como root (ya que lo acabamos de instalar) vamos ha
hacer unas primeras comprobaciones

Como sabréis, en Linux hay varios shell y vamos a repasar algunos conceptos
en este sentido

Para saber el tipo de shell en uso,  echo $SHELL

No debemos usar el usuario root como norma (por seguridad al igual que
no debemos usar el usuario administrador en Windows) por lo que debemos aprender crear uno

Creación de usuarios, usamos los comandos useradd y passwd

Una vez creado un usuario, para configurarle sus parámetros
particulares, usaremos el comando usermod. Recordar que con man usermod
nos
aparece la ayuda

Asignamos el directorio de arranque con la opción -d. Aunque os funcione un
trayecto relativo, aseguraos de usar un absoluto (el que no lea los texto que
pongo, se equivocará)

Lo suyo es que el directorio de usuario colgase de /home

No debemos olvidar que debemos asignar la propiedad de ese directorio al
usuario: usaremos el comando chown (cambiar propietario)

Jugar con el Shell

En Linux hay varios shell, recordamos conceptos básicos

  • Bourne Shell = sh es el shell original

  • bash es el shell por defecto en Linux

En linux hay muchas variable de entorno pre-establecidas,
debemos aprender a manejarnos.

Si ejecutamos el comando env, las veremos todas las variables de
entorno en nuestro Linux

Los comandos más básicos a usar serán ls, cd, find … que combinados
con las variables de entorno nos darán mucho juego

Peculiaridades

Estemos donde estemos, si usamos cd ~ (AltGr + 4) volveremos al
directorio $HOME

Con el comando alias podemos crear nuestros propios comandos. Siempre
me ha gustado asignar alias ll=»ls -lF –color». Así se puede ver de un
modo fácil los datos más importantes de un directorio.

Los comandos que vamos escribiendo los podemos recordar … o
bien pulsando la fecha superior del cursos (como en Windows).  Usando
history podemos ver la lista de comandos. Con el signo de admiración y el número
de orden invocaremos directamente al comando deseado

.

Hay otros comandos como sort, que nos pueden se muy útiles. Vemos en
el ejemplo como ordenar el fichero de contraseñas solo por el primer parámetro
identificando el separador

El comando awk es un comando curioso, que nos permite extraer una columna
concreta de un fichero (puede ser la entrada que le llega por una tubería)

awk ’{ print $2 }’ <  fichero

ls -lF | grep m | awk ’{ print $2 }’ <  fichero

Si queremos ver los nombres de los usuarios datos de alta en el
sistema, podríamos ejecutar un comando como este (indicando el carácter
separador):

cat passwd | awk -F’:’  ‘ {printf  $1}’

Comando de Disco

Para ver los discos montados podemos usar el comando df 
y para que sea legible por humanos, usaremos el comando -fu

Si queremos saber el espacio usado en disco por distintos
ficheros/directorio usaremos du -ha

 

Links a ficheros

Podemos establecer links a fichero y/o directorios (solo
débiles). Hay dos tipos de links, los fuertes y los débiles.

En los links fuertes, enganchamos con el identificador interno
del elemento apuntado (identificador de nodo). Esto significa que aunque se
cambie el nombre de recurso ligado, el link sigue siendo válido (evito ser más
técnico aposta) .

Los links fuertes se hacen con el comando ln nodoexistente
nombredellink
(no se puede hacer entre distintos sistemas de ficheros)

En la siguiente captura solo se trata de representar que cuando
realizamos un ls podemos ver que aumenta el contador de links al nodo
enlazado (obviamente se borrara el fichero cuando demos la orden y el contador
sea cero)

Si cambiamos de nombre el fichero original, no pasa nada porque
realmente se está enlazando al nodo interno

Los enlaces débiles vienen a ser como los accesos directos en Windows,
enlazamos a un nombre. si cambiamos el nombre del fichero enlazado, perdemos el
link (además esto no incrementa el contador de referencia a un nodo).

Para hacer links débiles se usa el comando ln -s nodoexistente
nombredellink

Si reestablecemos el nombre del fichero, el link vuelve a
funcionar

Copiar y mover directorios y ficheros

Para el que trabaje en entornos Windows, el sistema de ficheros
de Linux puede ser un poco complejo.

Hay que diferenciar que en Windows tenemos distintas árboles
(uno por cada unidad física o lógica). En Linux tenemos un solo árbol sobre el
que montamos los distintos discos.

Si queremos copiar y/o mover los datos de un disco físico a otro
… no es tan sencillo como en Windows (estos son temas avanzados).

Os invito a que investiguéis en este aspecto … aunque os dejo un par de
comando a investigar

cp -a /directorio/origen /directorio/destino (en caso de no existir
enlaces)

find . -depth -print0 | afio -p -xv -0a (en caso de existir
links)
 

También investigar el comando cpio

Programación con shell-script

Una de las cosas más agradecidas que tiene Unix, es que con el Shell se
pueden hacer verdaderos programas avanzados con unos conocimientos relativamente
básicos.

Con el editor vi (o vim en la actualidad) podemos escribir un pequeño
script.

Con chmod +x podemos asignar privilegios de ejecución al fichero. Os
recomiendo que uséis ls -F para ver fácilmente los ficheros ejecutables

Los comentarios en los Shell-scritps se hacen con #

Dentro de un Scritp, la tilde invertida nos sirve para indicar que queremos
obtener el resultado de la ejecución de un comando.

Este es el conjunto de variables disponibles dentro de nuestros
scripts:

  • $# – Cantidad de parámetros que el script recibe.
    $* – Todos los parámetros recibidos separados por $IFS (espacio por
    defecto).
    $- Opciones que se pasaron al script durante su ejecución.
    $$ – Identificación del proceso del intérprete de comandos.
    $? – Código de retorno del último programa ejecutado
    $! – Identificación del proceso del último comando que se ejecutó en segundo
    plano.
    $0 – Nombre del script.

Hacer un menú con un Shell es trivial con las instrucciones case ..

Como en cualquier lenguaje disponemos de un if y podemos hacer comprobaciones
con las opciones:

-b fichero = Comprueba si fichero es un dispositivo orientado a bloques
-c fichero = Comprueba si fichero es un dispositivo orientado a caracteres
-d fichero = Comprueba si fichero es un directorio
-f fichero = Comprueba si fichero es un fichero normal
-r fichero = Comprueba si fichero es legible por el proceso
-w fichero = Comprueba si fichero es escribible por el proceso
-x fichero = Comprueba si fichero es ejecutable

Con el comando read podemos leer lo que el usuario nos
escriba. Podemos usar las redirecciones para procesar el contenido de un
fichero.

Como en casi todos los lenguajes, disponemos de arrays ..

Podemos inicializar variables y operar con ellas de un modo
numérico con los dobles paréntesis (si le echamos un poco de imaginación,
veremos los bucles for desde otra perspectiva en los shell de Unix)

Con echo -e activamos el procesamiento de las secuencias
de escape como \n para una nueva línea

Procesos

Con el comando ps podemos ver los procesos activos. Podemos ver el árbol de procesos
activos con pstree.

Ver estado de la memoria con el comando top

 

Programación de tareas en Linux

Un comando o conjunto de comando se puede ejecutar de un modo inmediato o de
un modo diferido.

Con el comando at, podemos definir cuando queremos que se ejecute un
comando

Si queremos que se ejecuten comandos de un modo periódico, podemos usar el
cron
, a través del comando crontab

No olvidar que es muy posible que no se ejecuten los comandos si se han
configurados opciones de seguridad (el usuario debe estar en el fichero /etc/crontab.r/cron.allow,
si este existe)

Otras configuraciones

¿De donde sale la variable PATH en Linux?

more /etc/profile

Definición del prompt /etc/bash.bashrc

 

Salir ordenadamente de Linux

# shutdown -h now

# poweroff -i -f

Conclusiones

En Internet hay miles de manuales y tutoriales … os indico algunos de
ellos para que sigáis investigando…

Links Interesantes

http://www.sinuh.org/content/view/94/27/

http://www.adictosaltrabajo.com/indexg.php?noimages=SI&pagina=listacat&id=20
(en www.adictosaltrabajo.com )

http://www.wernitz.net/docs_debian/


http://www.tldp.org/LDP/abs/html/

 

 

DEJA UNA RESPUESTA

Por favor ingrese su comentario!

He leído y acepto la política de privacidad

Por favor ingrese su nombre aquí

Información básica acerca de la protección de datos

  • Responsable:
  • Finalidad:
  • Legitimación:
  • Destinatarios:
  • Derechos:
  • Más información: Puedes ampliar información acerca de la protección de datos en el siguiente enlace:política de privacidad