1
0
mirror of https://github.com/jlevy/the-art-of-command-line.git synced 2024-12-14 10:53:03 +02:00
the-art-of-command-line/README-es.md

526 lines
34 KiB
Markdown
Raw Normal View History

[ Languages:
2015-11-03 10:11:24 +02:00
[English](README.md), [Español](README-es.md), [日本語](README-ja.md), [한국어](README-ko.md), [Português](README-pt.md), [Русский](README-ru.md), [Slovenščina](README-sl.md), [Українська](README-uk.md), [中文](README-zh.md)
]
2015-06-24 19:58:46 +02:00
# El Arte del Terminal
2015-07-03 20:52:22 +02:00
[![Join the chat at https://gitter.im/jlevy/the-art-of-command-line](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/jlevy/the-art-of-command-line?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
2015-06-24 19:58:46 +02:00
- [Meta](#meta)
- [Fundamentos](#basics)
- [Uso diario](#everyday-use)
2015-07-21 21:31:02 +02:00
- [Procesamiento archivos y datos](#processing-files-and-data)
2015-06-24 19:58:46 +02:00
- [Depuración del sistema](#system-debugging)
- [One-liners](#one-liners)
- [Obscuro pero útil](#obscure-but-useful)
2015-07-15 20:47:35 +02:00
- [Solo para MacOS X](#macos-x-only)
2015-06-24 19:58:46 +02:00
- [Más recursos](#more-resources)
- [Advertencia](#disclaimer)
![curl -s 'https://raw.githubusercontent.com/jlevy/the-art-of-command-line/master/README.md' | egrep -o '`\w+`' | tr -d '`' | cowsay -W50](cowsay.png)
2015-10-24 18:08:39 +02:00
La fluidez en el terminal es una destreza a menudo abandonada y considerada arcaica, pero esta mejora su flexibilidad y productividad como ingeniero en formas obvia y sutil. Esta es una selección de notas y consejos al usar el terminal que encontramos útiles al trabajar en Linux. Algunos consejos son elementales y algunos bastante específicos, sofisticados u oscuros. Esta página no es larga, pero si puedes usar y recordar todos los puntos aquí mostrados, sabrás un montón.
2015-06-24 19:58:46 +02:00
2015-10-24 18:08:39 +02:00
Este trabajo es el resultado de [muchos autores y traductores](AUTHORS.md).
La mayor parte
[originalmente](http://www.quora.com/What-are-some-lesser-known-but-useful-Unix-commands)
[apareció](http://www.quora.com/What-are-the-most-useful-Swiss-army-knife-one-liners-on-Unix)
2015-06-24 19:58:46 +02:00
en [Quora](http://www.quora.com/What-are-some-time-saving-tips-that-every-Linux-user-should-know),
2015-10-24 18:08:39 +02:00
pero debido al interés mostrado, parecía valer la pena usar Github, donde personas más talentosas que el author original pudiendo fácilmente sugerir mejoras. Si ve un error o algo que podría ser mejor, por favor, crea un issue o PR! (Por supuesto primero revisa la sección meta de PRs/issues.)
2015-06-24 19:58:46 +02:00
## Meta
Alcance:
- Esta guía es tanto para principiantes como para experimentados. Los objetivos son *diversidad* (todo importa), *especificidad* (dar ejemplos concretos del caso más común), y *concisión* (evitar cosas que no son esenciales o insignificantes que puedas buscar fácilmente en otro lugar). Cada consejo es esencial en alguna situación o significativamente puede ahorrar tiempo comparado con otras alternativas.
2015-07-15 20:47:35 +02:00
- Esta escrito para Linux, con excepción de la sección "[Solo para MacOS X](#macos-x-only)". Muchos de los otros puntos aplican o pueden ser instalados en otros Unices o MacOS (o incluso Cygwin).
2015-07-07 20:47:36 +02:00
- Se enfoca en Bash interactivo, aunque muchos de los consejos se aplican para otros shells y al Bash scripting por lo general.
- Incluye tanto comandos "estándar" Unix, así como aquellos que requieren la instalación especial de un paquete -- siempre que sea suficientemente importante para ameritar su inclusión.
2015-06-24 19:58:46 +02:00
2015-06-25 23:30:19 +02:00
Notas:
2015-06-24 19:58:46 +02:00
- Para mantener esto en una página, el contenido está incluido implícitamente por referencia. Eres lo suficientemente inteligente para consultar más detalles en otros lugares, cuando conoces la idea o comando con Google. Usa `apt-get`/`yum`/`dnf`/`pacman`/`pip`/`brew` (según proceda) para instalar los nuevos programas.
- Usa [Explainshell](http://explainshell.com/) para obtener detalles de ayuda sobre que comandos, opciones, pipes, etc.
2015-06-24 19:58:46 +02:00
2015-06-28 22:48:37 +02:00
## Fundamentos
2015-06-24 19:58:46 +02:00
- Aprende conocimientos básicos de Bash, de hecho, escribe `man bash` y al menos échale un vistazo a todo el asunto. Es bastante fácil de seguir y no es tan largo. Alternar entre shells puede ser agradable, pero Bash es poderoso y siempre está disponible (conocer *solo* zsh, fish, etc., aunque resulte tentador en tu propia laptop, Te restringe en muchas situaciones, tales como el uso de servidores existentes).
2015-06-24 19:58:46 +02:00
- Aprende bien al menos un editor de texto, idealmente Vim (`vi`), como no hay realmente una competencia para la edición aleatoria en un terminal (incluso si usa Emacs, un gran IDE, o un editor alternativo (hipster) moderno la mayor parte del tiempo).
2015-06-24 19:58:46 +02:00
- Conoce como leer la documentación con `man` (Para curiosos, `man man` lista las secciones enumeradas, ej. 1 es comandos "regulares", 5 son archivos/convenciones, y 8 para administración). Encuentra las páginas de man `apropos`. Sepa que alguno de los comandos no son ejecutables, pero son Bash builtins, y que puedes obtener ayuda sobre ellos con `help` y `help -d`.
2015-06-24 19:58:46 +02:00
- Aprende sobre redirección de salida `>`, entrada `<` y pipes utilizando `|`. Conozca que `>` sobrescribe el archivo de salida y `>>` añade. Aprende sobre stdout y stderr.
2015-06-24 19:58:46 +02:00
2015-09-13 08:19:01 +02:00
- Aprende sobre expansión de archivos glob con `*` (y tal vez `?` y `[`...`]`) y quoting y la diferencia entre comillas dobles `"` y simples `'`. (Ver más en expansión de variables más abajo.)
2015-06-24 19:58:46 +02:00
2015-07-07 20:47:36 +02:00
- Familiarízate con la administración de trabajo en Bash: `&`, **ctrl-z**, **ctrl-c**, `jobs`, `fg`, `bg`, `kill`, etc.
2015-06-24 19:58:46 +02:00
2015-07-07 20:47:36 +02:00
- Conoce `ssh` y lo básico de autenticación sin contraseña, vía `ssh-agent`, `ssh-add`, etc.
2015-06-24 19:58:46 +02:00
2015-10-24 18:08:39 +02:00
- Administración de archivos básica: `ls` y `ls -l` (en particular, aprende el significado de cada columna en `ls -l`), `less`, `head`, `tail` y `tail -f` (o incluso mejor, `less +F`), `ln` y `ln -s` (aprende las diferencias y ventajas entre enlaces hard y soft), `chown`, `chmod`, `du` (para un resumen rápido del uso del disco: `du -hs *`). Para administración de archivos de sistema, `df`, `mount`, `fdisk`, `mkfs`, `lsblk`. Aprenda que un inode es `ls -i` or `df -i`).
2015-06-24 19:58:46 +02:00
2015-07-07 20:47:36 +02:00
- Administración básica de redes: `ip` o `ifconfig`, `dig`.
2015-06-24 19:58:46 +02:00
- Conoce bien las expresiones regulares y varias opciones (flags) para `grep`/`egrep`. Las opciones `-i`, `-o`, `-v`, `-A`, `-B` y `-C` son dignas de ser recordadas.
2015-06-24 19:58:46 +02:00
- Aprende el uso de `apt-get`, `yum`, `dnf` o `pacman` (dependiendo de la distribución "distro") para buscar e instalar paquetes. Y asegúrate que tienes `pip` para instalar la herramienta de línea de comando basada en Python (un poco más abajo esta explicado como instalar vía `pip`).
2015-06-24 19:58:46 +02:00
2015-07-02 23:26:37 +02:00
## De uso diario
2015-06-24 19:58:46 +02:00
2015-09-13 08:19:01 +02:00
- En Bash, se usa **Tab** para completar los argumentos o lista todos los comandos disponibles y **ctrl-r** para buscar a través del historial de comandos (despues de presionar, escribe la búsqueda, presiona **ctrl-r** repetidamente para hacer un ciclo a través de más coincidencias, presiona **Enter** para ejecurar el comando encontrado, o presiona la flecha derecha para poner el resultado en la línea actual y editar).
2015-06-24 19:58:46 +02:00
- En Bash, se usa **ctrl-w** para borrar la última palabra, y **ctrl-u** para borrar todo hacia atrás hasta el inicio de la línea. Se usa **alt-b** y **alt-f** para moverse entre palabras, **ctrl-a** para mover el cursor al principio de la línea, **ctrl-e** para mover el cursor al final de la línea, **ctrl-k** para eliminar hasta el final de la línea, **ctrl-l** para limpiar la pantalla. Ver `man readline` para todos los atajos de teclado por defecto en Bash. Son una gran cantidad. Por ejemplo **alt-.** realiza un ciclo a través de los comandos previos, y **alt-*** expande un glob.
2015-06-24 19:58:46 +02:00
2015-09-13 09:29:36 +02:00
- Alternativamente, si amas los atajos de teclado vi-style, usa `set -o vi`. (y `set -o emacs` para regresar a la anterior).
- Para editar largos comandos, después de configurar to editor (por ejemplo `export EDITOR=vim`), **ctrl-x** **ctrl-e** se abrirá el comando actual en un editor para editar multiples líneas. O en estilo vi, **escape-v**.
2015-06-24 19:58:46 +02:00
2015-07-17 19:02:42 +02:00
- Para ver los últimos comandos, `history`. También existen abreviaciones, tales como, `!$` (último argumento) y `!!` último comando, aunque son fácilmente remplazados con **ctrl-r** y **alt-.**.
2015-06-24 19:58:46 +02:00
2015-07-17 19:02:42 +02:00
- Para volver al directorio de trabajo previo: `cd -`
2015-06-24 19:58:46 +02:00
- Si estás a medio camino al escribir un comando pero cambias de opinión, presiona **alt-#** para agregar un `#` al principio y lo agrega como comentario (o usa **ctrl-a**, **#**, **enter**). Luego puedes regresar a este vía comando `history`.
2015-06-24 19:58:46 +02:00
- Usa `xargs` (o `parallel`). Es muy poderoso. Ten en cuenta que puedes controlar cuántos elementos son ejecutados por línea (`-L`), así como el paralelismo (`-P`). Si no estas seguro de que este haga la cosa correcta, usa `xargs echo` primero. También, `-I{}` es útil. Ejemplos:
2015-06-24 19:58:46 +02:00
```bash
find . -name '*.py' | xargs grep some_function
cat hosts | xargs -I{} ssh root@{} hostname
```
2015-07-02 23:26:37 +02:00
- `pstree -p` es útil para mostrar el árbol de procesos.
2015-06-24 19:58:46 +02:00
- Usa `pgrep` y `pkill` para encontrar o señalar procesos por su nombre (`-f` es de mucha ayuda).
2015-06-24 19:58:46 +02:00
- Conoce las señales que puedes enviar a los procesos. Por ejemplo, para suspender un proceso usa `kill -STOP [pid]`. Con `man 7 signal` puedes ver la lista completa
2015-06-24 19:58:46 +02:00
- Usa `nohup` o `disown` si quieres que un proceso de fondo se mantenga corriendo para siempre.
2015-06-24 19:58:46 +02:00
- Verifica que procesos están escuchando vía `netstat -lntp` o `ss -plat` (para TCP; agrega `-u` para UDP).
2015-06-24 19:58:46 +02:00
2015-07-03 11:45:47 +02:00
- Consulta también `lsof` para abrir sockets y archivos.
2015-06-24 19:58:46 +02:00
- Consulta `uptime` o `w` para conocer cuánto tiempo el sistema ha estado corriendo.
- Usa `alias` para crear atajos para comandos comúnmente usados. Por ejemplo, `alias ll="las -latr"` crea el alias `ll`
2015-07-03 20:52:22 +02:00
2015-09-13 09:29:36 +02:00
- En Bash scripts, usa `set -x` (o su variantes `set -v`, que registra las entradas sin procesar, incluyendo variables sin expander y comantarios) para depurar la salida. Usa el modo estricto al menos que tengas una buena razón para no hacerlo: Usa `set -e` para abortar en caso de errores (códigos de salida distintos a cero). Usa `set -u` para detectar uso de variables no definidas. Considera `set -o pipefail` también, para los errores con pipes, también (estudiar mas sobre este como un tema delicado). Para scripts más complejos, usa también `trap`. en EXIT o ERR. Un hábito útil es para comenzar un script como este, el cual detectará y abortará con errores comunes e imprimirá un mensaje:
```bash
set -euo pipefail
trap "echo 'error: Falló del Script: ver arriba comando que falló'" ERR
```
2015-06-24 19:58:46 +02:00
- En Bash scripts, subshells (escritos con paréntesis) son maneras convenientes para agrupar los comandos. Un ejemplo común es temporalmente moverse hacia un directorio de trabajo diferente, Ej.
2015-06-24 19:58:46 +02:00
```bash
# do something in current dir
(cd /some/other/dir && other-command)
# continue in original dir
```
- En Bash, considera que hay muchas formas de expansión de variables. Verificar la existencia de una variable: `${name:?error message}`. Por ejemplo, si un script Bash requiere un único argumento, solo escribe `input_file=${1:?usage: $0 input_file}`. Expansión aritmética: `i=$(( (i + 1) % 5 ))`. Secuencias: `{1..10}`. Reducción de cadenas de texto: `${var%suffix}` y `${var#prefix}`. Por ejemplo si `var=foo.pdf`, entonces `echo ${var%.pdf}.txt` imprime `foo.txt`.
2015-06-24 19:58:46 +02:00
2015-10-24 18:08:39 +02:00
- Utilizando la expansión de corchetes `{`...`}` puede reducir el tener que retipear un texto similar y automatizar conbinaciones de elementos. Esto es útil en ejemplos como `mv foo.{txt,pdf} some-dir` (el cual mueve ambos archivos), `cp somefile{,.bak}` (el cual se expandirá a `cp somefile somefile.bak`) o `mkdir -p test-{a,b,c}/subtest-{1,2,3}` (el cual se expandirá en todas las posibles conbinaciones y creará un árbol de directorios).
- La salida de un comando puede ser tratado como un archivo por medio de `<(some command)`. Por ejemplo, comparar el `/etc/hosts` local con uno remoto:
2015-06-24 19:58:46 +02:00
```sh
diff /etc/hosts <(ssh somehost cat /etc/hosts)
```
- Conocer acerca de "here documents" en Bash, como también de `cat <<EOF ...`.
2015-06-24 19:58:46 +02:00
2015-10-24 18:08:39 +02:00
- En Bash, redirecciona ambas la salida estándar y el error estándar, mediante: `some-command >logfile 2>&1` o `some-command &>logfile`. Frecuentemente, para garantizar que un comando no haya dejado abierto un archivo para controlar la entrada estándar vinculada al terminal en el que te encuentras y también como buena práctica puedes agregar `</dev/null`.
2015-06-24 19:58:46 +02:00
- Usa `man ascii` para una buena tabla ASCII con valores hexadecimal y decimales. Para información de codificación general, `man unicode`, `man utf-8`, y `man latin1` son de utilidad.
2015-06-24 19:58:46 +02:00
2015-10-24 18:08:39 +02:00
- Usa `screen` o [`tmux`](https://tmux.github.io/) para multiplexar la pantalla, especialmente útil en sesiones ssh remotas y para desconectar y reconectar a una sesión. `byobu` puede mejorar la pantalla o tmux proporcionando mayor información y gestión ás sencilla. Una alternativa más minimalista para persistencia de la sesión solo sería `dtach`.
2015-06-24 19:58:46 +02:00
- En ssh, saber cómo hacer un port tunnel con `-L` o `-D` (y de vez en cuando `-R`) es útil, Ej. para acceder a sitios web desde un servidor remoto.
2015-06-24 19:58:46 +02:00
- Puede ser útil hacer algunas optimizaciones a su configuración ssh; por ejemplo, `~/.ssh/config`, contiene la configuración para evitar desconexiones en ciertos entornos de red, utiliza compresión (cual es útil con scp sobre conexiones con un bajo ancho de banda), y la multiplexión de canales para el mismo servidor con un archivo de control local:
2015-06-24 19:58:46 +02:00
```
TCPKeepAlive=yes
ServerAliveInterval=15
ServerAliveCountMax=6
Compression=yes
ControlMaster auto
ControlPath /tmp/%r@%h:%p
ControlPersist yes
```
- Algunas otras opciones relevantes a ssh son sensibles en cuanto a seguridad y deben ser usadas con cuidado, Ej. por subnet, host o en redes confiables: `StrictHostKeyChecking=no`, `ForwardAgent=yes`.
2015-06-24 19:58:46 +02:00
2015-10-24 18:08:39 +02:00
- Considera [`mosh`](https://mosh.mit.edu/) una alternativa para ssh que utiliza UDP, evitando conexiones caidas y agregando conveniencia en el camino. (require configuración del lado del servidor).
- Para obtener permiso sobre un archivo en forma octal, el cual es útil para la configuración del sistema pero no está disponible con `ls` y fácil de estropear, usa algo como
2015-06-24 19:58:46 +02:00
```sh
stat -c '%A %a %n' /etc/timezone
```
- Para selección interactiva de valores desde la salida de otro comando, use [`percol`](https://github.com/mooz/percol) o [`fzf`](https://github.com/junegunn/fzf).
2015-06-24 19:58:46 +02:00
- Para la interacción con archivos basados en la salida de otro comando (como `git`), use `fpp` ([PathPicker](https://github.com/facebook/PathPicker)).
2015-06-24 19:58:46 +02:00
- Para un servidor web sencillo para todos los archivos en el directorio actual (y subdirectorios), disponible para cualquiera en tu red, usa:
2015-07-03 11:45:47 +02:00
`python -m SimpleHTTPServer 7777` (para el puerto 7777 y Python 2) y `python -m http.server 7777` (para 7777 y Python 3).
2015-06-24 19:58:46 +02:00
- Para ejecutar un comando con privilegios, usando `sudo` (para root) o `sudo -u` (para otro usuario). Usa `su` o `sudo bash` para realmente ejecutar un shell como este usuario. Usa `su -` para simular un login fresco como root u otro usuario.
2015-07-03 20:52:22 +02:00
2015-06-24 19:58:46 +02:00
2015-07-03 13:13:53 +02:00
## Procesamiento de archivos y datos
2015-06-24 19:58:46 +02:00
- Para localizar un archivo por nombre en el directorio actual, `find . -iname '*something*'` (o similar). Para encontrar un archivo en cualquier lado por nombre, usa `locate something` (pero tenga en mente que `updatedb` quizás no haya indexado recientemente los archivos creados).
2015-06-24 19:58:46 +02:00
- Para búsqueda general a través de archivos fuente o de datos (más avanzado que `grep -r`), usa [`ag`](https://github.com/ggreer/the_silver_searcher).
2015-06-24 19:58:46 +02:00
2015-07-17 19:02:42 +02:00
- Para convertir HTML a texto: `lynx -dump -stdin`
2015-06-24 19:58:46 +02:00
- Para Markdown, HTML, y todos los tipos de conversión de documentos, prueba [`pandoc`](http://pandoc.org/).
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- Si debe manipular XML, `xmlstarlet` es viejo pero bueno.
2015-06-24 19:58:46 +02:00
- Para JSON usa [`jq`](http://stedolan.github.io/jq/).
2015-06-24 19:58:46 +02:00
2015-10-24 18:08:39 +02:00
- Para YAML, usa [`shyaml`](https://github.com/0k/shyaml).
- Para archivos Excel o CSV, [csvkit](https://github.com/onyxfish/csvkit) proporciona `in2csv`, `csvcut`, `csvjoin`, `csvgrep`, etc.
2015-06-24 19:58:46 +02:00
2015-10-24 18:08:39 +02:00
- Para Amazon S3, [`s3cmd`](https://github.com/s3tools/s3cmd) es conveniente y [`s4cmd`](https://github.com/bloomreach/s4cmd) es el mas rápido. [`aws`](https://github.com/aws/aws-cli) de Amazon y el mejorado [`saws`](https://github.com/donnemartin/saws) son esenciales para otras tareas relacionadas al AWS.
2015-06-24 19:58:46 +02:00
- Conoce acerca de `sort` y `uniq`, incluyendo las opciones de uniq `-u` y `-d` -- ver [one-liners](https://github.com/jlevy/the-art-of-command-line/blob/master/README-es.md#one-liners) más abajo. Ver también `comm`
2015-06-24 19:58:46 +02:00
- Conoce acerca de `cut`, `paste` y `join` para manipular archivos de texto. Muchas personas usan `cut` pero se olvidan acerca de `join`.
2015-06-24 19:58:46 +02:00
- Conoce acerca de `wc` para contar saltos de línea (`-l`), caracteres (`-m`), palabras (`-w`) y bytes (`-c`).
2015-06-24 19:58:46 +02:00
- Conoce acerca de `tee` para copiar desde el stdin hacia un archivo y también hacia el stdout, al igual que en `ls -al | tee file.txt`.
2015-06-24 19:58:46 +02:00
- Conoce que la localización afecta muchas herramientas de línea de comando en forma delicada, incluyendo el ordenamiento (compaginación) y rendimiento. La mayoría de las instalaciones de Linux configuran `LANG` u otras variables de localización para la configuración local como US English. Pero ten en mente que el ordenamiento puede cambiar si cambia la localización. Y también las rutinas i18n pueden hacer que `sort` u otros comandos se ejecuten más lentamente. En algunas situaciones (tales como la realización de operaciones u operaciones singulares descritas más abajo) puedes ignorar las rutinas i18n por completo y utilizar el sort tradicional basado en bytes, usando `export LC_ALL=C`.
2015-06-24 19:58:46 +02:00
- Conoce los aspectos básicos de `awk` y `sed` para manejo de datos. Por ejemplo, sumar todos lo números en la tercera columna de un archivo de texto: `awk '{ x += $3 } END { print x }'`. Esto es probablemente 3 veces más rápido y 3 veces más corto que su equivalente en Python.
2015-06-24 19:58:46 +02:00
2015-07-17 19:02:42 +02:00
- Para reemplazar todas las ocurrencias de un string en su lugar, en uno o más archivos:
2015-06-24 19:58:46 +02:00
```sh
perl -pi.bak -e 's/old-string/new-string/g' my-files-*.txt
```
2015-11-03 10:11:24 +02:00
- Para renombrar multiples y/o buscar y remplazar dentro de archivos, intenta [`repren`](https://github.com/jlevy/repren). (En algunos casos el comando `rename` también permite multiples renombramientos, pero sea cuidadoso ya que esta funcionalidad no es igual en todas las distribuciones de Linux.)
2015-06-24 19:58:46 +02:00
```sh
2015-07-23 03:54:24 +02:00
# Renombramiento completo de archivos, carpetas y contenidos foo -> bar:
2015-06-24 19:58:46 +02:00
repren --full --preserve-case --from foo --to bar .
2015-11-03 10:11:24 +02:00
# Recuperar archivos de respaldo cualquier.bak -> cualquier:
repren --renames --from '.*)\.bak' --to '\1' *.bak
# Igual que arriba, utilizando rename, si esta disponible:
rename 's/\.bak$//' *.bak
2015-06-24 19:58:46 +02:00
```
2015-10-24 18:08:39 +02:00
- Como dice la página de man, `rsync` es una muy rápida y extraordinariamente versatil herramienta de copiado. Esta se conoce por la sincronización entre máquinas pero es igualmente útil localmente. Esta también se encuentra entre las [formas más rápidas](https://web.archive.org/web/20130929001850/http://linuxnote.net/jianingy/en/linux/a-fast-way-to-remove-huge-number-of-files.html) para borrar un gran número de archivos:
```sh
mkdir empty && rsync -r --delete empty/ some-dir && rmdir some-dir
```
- Usa `shuf` para mezclar o seleccionar líneas aleatorias de un archivo.
2015-06-24 19:58:46 +02:00
- Conoce las opciones de `sort`. Para números, usa `-n`, o `-h` para manipulación de números humanamente leíbles (Ej. desde `du -h`). Conoce el trabajo principal de (`-t` y `-k`). En particular, esta atento que lo necesitas escribir`-k1,1` para ordenar por solo el primer campo; `-k1` significa ordenar de acuerdo a toda la línea. Orden estable (`sort -s`) puede ser útil. Por ejemplo, para organizar el primer por el campo 2, entonces secundariamente hacerlo por el campo 1, Puedes usar `sort -k1,1 | sort -s -k2,2`.
2015-06-24 19:58:46 +02:00
- Si alguna vez necesitas escribir un tab literal en una línea de comandos en Bash (Ej. para el argumento -t de ordenar), presiona **ctrl-v** **[Tab]** o escribe `$'\t'` (El último es mejor porque puedes copiarlo/pegarlo).
2015-06-24 19:58:46 +02:00
2015-10-24 18:08:39 +02:00
- Las herramientas estándar para reparar el código fuente son `diff` y `patch`. Consulta también `diffstat` para resumen estadístico de una diff y `sdiff` para un diff puesto lado a lado. Considera `diff -r` trabaja con directorios por completo. Usa `diff -r tree1 tree2 | diffstat` para el resumen de cambios. Urilizá `vimdiff` para comparar y editar archivos.
2015-06-24 19:58:46 +02:00
2015-10-24 18:08:39 +02:00
- Para archivos binarios, usa `hd`, `hexdeump` or `xxd` para volcados hexdecimales simples y `bvi` o `biew` para edición de binario.
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- También para archivos binarios, `strings` (además de `grep`, etc.) permite encontrar fragmentos de texto.
2015-06-24 19:58:46 +02:00
- Para diffs binaria (compresión delta), usa `xdelta3`.
2015-06-24 19:58:46 +02:00
- Para convertir la codificación del texto, probar `iconv`. O `uconv` para uso más avanzado; este soporta algunos elementos Unicode avanzados. Por ejemplo, este comando coloca en minúsculas y remueve todas los acentos (por su expansión y colocándolos):
2015-06-24 19:58:46 +02:00
```sh
uconv -f utf-8 -t utf-8 -x '::Any-Lower; ::Any-NFD; [:Nonspacing Mark:] >; ::Any-NFC; ' < input.txt > output.txt
```
- Para dividir archivos en múltiples partes, consulta `split` (para dividir por tamaño) y `csplit` (para dividir por un patrón).
2015-06-24 19:58:46 +02:00
- Para manipular expresiones de fecha y tiempo, usa `dateadd`, `datediff`, `strptime` etc. de [`dateutils`](http://www.fresse.org/dateutils/).
2015-10-24 18:08:39 +02:00
- Usa `zless`, `zmore`, `zcat`, y `zgrep` para operar sobre archivos comprimidos.
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
## Depuración del sistema
2015-06-24 19:58:46 +02:00
- Para depuración web, `curl` y `curl -I` son prácticos, o como sus equivalentes `wget`, o el más moderno [`httpie`](https://github.com/jkbrzt/httpie).
2015-06-24 19:58:46 +02:00
2015-10-24 18:08:39 +02:00
- Para conocer el estado del cpu/disco, las clásicas herramientas son `top` (o mejor `htop`), `iostat`, y `iotop`. Usa `iostat -mxz 15` para CPU básicas y estadísticas detalladas y visión de rendimiento por partición del disco.
2015-06-24 19:58:46 +02:00
2015-10-24 18:08:39 +02:00
- Para detalles de la conexión de red, usa `netstat` y `ss`.
- Para una rápida visión general de que esta pasando en un sistema, `dstat` es especialmente útil. Para una visión general más amplia con detalles usa [`glances`](https://github.com/nicolargo/glances).
2015-06-24 19:58:46 +02:00
- Para conocer el estado de la memoria, ejecuta y entiende la salida de `free` y `vmstat`. En particular, ten en cuenta que el valor "cached" es mantenido en memoria por el kernel de Linux como un archivo de cache, por lo que efectivamente cuenta como valor para "free".
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- El sistema de depuración de Java es harina de otro costal, pero un truco simple en las JSM de Oracle y otros consta en que puedes ejecutar `kill -3 <pid>` y una traza completa y un resumen del montículo "heap summary" (incluyendo del detalle de la colección de basura generacional, la cual puede ser altamente informativa) serán descargados al stderr/logs. Las herramientas `jps`, `jstat`, `jstack`, `jmap` del JDK son útiles. [SJK tools](https://github.com/aragozin/jvm-tools) son más avanzadas.
2015-06-24 19:58:46 +02:00
- Usa `mtr` como un mejor traceroute para identificar los problemas en la red.
2015-06-24 19:58:46 +02:00
- Para examinar por qué el disco está lleno, `ncdu` ahorra tiempo en comparación con los comandos usuales como `du -sh *`.
2015-06-24 19:58:46 +02:00
2015-07-17 19:02:42 +02:00
- Para encontrar cual socket o proceso está utilizando el ancho de banda, prueba `iftop` o `nethogs`.
2015-06-24 19:58:46 +02:00
- La herramienta `ab` (viene con Apache) es útil para una verificación rápida del rendimiento de un servidor web. Para pruebas de carga más complejas prueba `siege`.
2015-06-24 19:58:46 +02:00
2015-07-24 00:23:30 +02:00
- Para una depuración mas seria de redes, `wireshark`, `tshark`, o `ngrep`.
2015-06-24 19:58:46 +02:00
- Conoce acerca de `strace` y `ltrace`. Estas puede ser de utilidad si un programa está fallando, suspendido, o colgado, y no sabe por qué, o si quieres tener una idea general del rendimiento. Considera la opción de elaboración de perfiles (`-c`), y la habilidad de adjuntar a un proceso en ejecución (`-p`).
2015-06-24 19:58:46 +02:00
- Conoce acerca `ldd` para verificar librerías compartidas etc.
2015-06-24 19:58:46 +02:00
- Conoce como conectarse a un proceso en ejecución con `gdb` y obtener su traza de pilas.
2015-06-24 19:58:46 +02:00
- Usa `/proc`. Es extraordinariamente útil algunas veces cuando se depuran problemas en vivo. Ejemplos: `/proc/cpuinfo`, `/proc/xxx/cwd`, `/proc/meminfo`, `/proc/cmdline`, `/proc/xxx/exe`, `/proc/xxx/fd/`, `/proc/xxx/smaps` (donde `xxx` es el id o pid del proceso).
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- Cuando se depura porque algo salió mal en el pasado, `sar` puede ser muy útil. Este muestra la estadística histórica en CPU, memoria, red, etc.
2015-06-24 19:58:46 +02:00
- Para sistemas y análisis de rendimiento de mayor profundidad, examina `stap` ([SystemTap](https://sourceware.org/systemtap/wiki)), [`perf`](https://en.wikipedia.org/wiki/Perf_(Linux)), y [`sysdig`](https://github.com/draios/sysdig).
2015-06-24 19:58:46 +02:00
- Comprueba en que OS se encuentra con `uname` o `uname -a` (información general en Unix/kernel) o `lsb_release -a` (información en Linux distro).
2015-06-24 19:58:46 +02:00
- Usa `dmesg` siempre que algo actúe raro (esto podría ser problemas con el hardware o driver).
2015-06-24 19:58:46 +02:00
## One-liners
2015-07-03 18:45:43 +02:00
Algunos ejemplos de comandos reunidos:
2015-06-24 19:58:46 +02:00
- Es notablemente útil en ocasiones que pueda realizar intersección, unión, y diferencia de conjuntos de archivos de texto vía `sort`/`uniq`. Suponga que `a` y `b` como archivos de texto que son únicos. Esto es rápido, y trabaja con archivos de tamaño arbitrario, hasta varios gigabytes. (Sort no está limitado por la memoria, aunque quizás necesite utilizar la opción `-T` si `/tmp` está en una pequeña partición de raíz.) Consulta también la nota acerca de `LC_ALL` y las opciones de `sort`, `-u` (dejado de lado para clarificar más abajo).
2015-06-24 19:58:46 +02:00
```sh
2015-07-24 00:23:30 +02:00
cat a b | sort | uniq > c # c es a unido con b
2015-07-23 03:54:24 +02:00
cat a b | sort | uniq -d > c # c es a intersectado con b
cat a b b | sort | uniq -u > c # c es el conjunto diferencia a - b
2015-06-24 19:58:46 +02:00
```
2015-10-24 18:08:39 +02:00
- Usa `grep . *` para rápidamente examinar el contenido de todos los archivos de un directorio (para que cada línea este emparejada con con el nombre de archivo), o `head -100 *` (para que cada archivo tenga un encabezado). Esto puede se útil para directorios llenos con ajustes de configuración como aquellos en `/sys`, `/proc`, `/etc`.
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- Sumar todos los números en la tercera columna de un archivo de texto (esto es probablemente 3 veces más rápido y 3 veces menos código que el equivalente en Python):
2015-06-24 19:58:46 +02:00
```sh
awk '{ x += $3 } END { print x }' myfile
```
- Si quiere examinar tamaños/fechas en un árbol de archivos, esto es como un `ls -l` recursivo pero es más fácil de leer que `ls -lR`:
2015-06-24 19:58:46 +02:00
```sh
find . -type f -ls
```
- Digamos que tiene un archivo de texto, como un log de un servidor web, y un cierto valor comienza a aparecer en algunas líneas, tales como un parámetro `acct_id` que está presente en la URL. Si quieres un recuento de cuantas peticiones por cada `acct_id`:
2015-06-24 19:58:46 +02:00
```sh
cat access.log | egrep -o 'acct_id=[0-9]+' | cut -d= -f2 | sort | uniq -c | sort -rn
```
2015-10-24 18:08:39 +02:00
- Para monitorear continuamente los cambios, usa `watch`, Ej. verificar los cambios de archivos en un directorio con `watch -d -n 2 'ls -rt1h | tail'` o para configuraciones de red mientras solucionas problemas con la configuración wifi `watch -d -n 2 ifconfig`.
2015-07-07 22:53:25 +02:00
- Ejecuta esta función para obtener un consejo aleatorio desde este documento (analiza el Markdown y extrae un elemento):
2015-06-24 19:58:46 +02:00
```sh
function taocl() {
curl -s https://raw.githubusercontent.com/jlevy/the-art-of-command-line/master/README.md |
pandoc -f markdown -t html |
xmlstarlet fo --html --dropdtd |
xmlstarlet sel -t -v "(html/body/ul/li[count(p)>0])[$RANDOM mod last()+1]" |
xmlstarlet unesc | fmt -80
}
```
2015-07-07 20:47:36 +02:00
## Oscuro pero útil
2015-06-24 19:58:46 +02:00
2015-07-07 20:47:36 +02:00
- `expr`: ejecuta operaciones aritméticas o booleanas o evalúa expresiones regulares
2015-06-24 19:58:46 +02:00
2015-07-17 19:02:42 +02:00
- `m4`: procesador de macro sencillo
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `yes`: imprime un string sin fin
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `cal`: lindo calendario
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `env`: ejecuta un comando (útil en scripts)
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- `printenv`: imprime las variables del entorno (útil en depuración y scripts)
2015-06-24 19:58:46 +02:00
2015-07-17 19:02:42 +02:00
- `look`: buscar palabras en inglés (o líneas en un archivo) comenzando con un string
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `cut`, `paste` y `join`: manipulación de datos
2015-06-24 19:58:46 +02:00
- `fmt`: formatea los párrafos de texto
2015-06-24 19:58:46 +02:00
- `pr`: formatea el texto en páginas/columnas
2015-06-24 19:58:46 +02:00
- `fold`: ajusta de líneas de texto
2015-06-24 19:58:46 +02:00
2015-10-24 18:08:39 +02:00
- `column`: formatea campos de texto alineados, en columnas de ancho fijo o tablas
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- `expand` y `unexpand`: conversión entre tabuladores y espacios
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `nl`: agrega números de línea
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `seq`: imprime números
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `bc`: calculadora
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `factor`: factorización de enteros
2015-06-24 19:58:46 +02:00
- [`gpg`](https://gnupg.org/): encripta y firma archivos
2015-06-24 19:58:46 +02:00
2015-07-07 20:47:36 +02:00
- `toe`: tabla de información de términos
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- `nc`: depuración de la red y transferencia de datos
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `socat`: socket relay y redireccionador de puerto tcp (similar a `netcat`)
2015-06-24 19:58:46 +02:00
- [`slurm`](https://github.com/mattthias/slurm): visualización del tráfico de red
2015-06-24 19:58:46 +02:00
- `dd`: moviliza datos entre archivos o dispositivos
2015-06-24 19:58:46 +02:00
2015-07-17 19:02:42 +02:00
- `file`: identifica el tipo de archivo
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `tree`: muestra directorios y subdirectorios como un árbol anidado; parecido a `ls` pero recursivo
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `stat`: información del archivo
2015-06-24 19:58:46 +02:00
- `time`: ejecuta y calcula el tiempo de ejecución de un comando
2015-11-03 10:11:24 +02:00
- `timeout`: ejecuta un comando especificando una cantidad de tiempo y deteniendo el proceso cuando la cantidad de tiempo especificado se completa.
2015-10-24 18:08:39 +02:00
- `lockfile`: crea un archivo semáforo que puedes solo ser removido con `rm -f`
- `logrotate`: rota, comprime y registra correos electrónicos.
- `watch`: ejecuta un comando repetidamente, mostrando resultados y/o resaltando cambios
2015-07-03 18:45:43 +02:00
- `tac`: imprime archivos en forma inversa
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- `shuf`: selección aleatoria de líneas de un archivo
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `comm`: compara archivos ordenados línea por línea
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- `pv`: monitorea el progreso de datos a través de un tubo
2015-07-03 20:52:22 +02:00
2015-10-24 18:08:39 +02:00
- `hd`, `hexdump`, `xxd`, `bview` y `bvi`: descarga o edita archivos binarios
2015-06-24 19:58:46 +02:00
2015-07-24 00:23:30 +02:00
- `strings`: extrae texto desde archivos binarios
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- `tr`: traducción o manipulación de caracteres
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `iconv` o `uconv`: conversión de codificaciones de texto
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `split` y `csplit`: división de archivos
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- `sponge`: lee todas las entradas antes de escribirlo, útil para vista previa y posterior escritura sobre el mismo archivo, Ej., `grep -v something some-file | sponge some-file`
2015-07-03 20:52:22 +02:00
2015-07-23 03:54:24 +02:00
- `units`: unidades de conversión y cálculos; convierte furlongs por fortnight a twips por blink (ver también `/usr/share/units/definitions.units`)
2015-06-24 19:58:46 +02:00
2015-10-24 18:08:39 +02:00
- `apg`: genera contraseñas aleatorias.
2015-07-07 20:47:36 +02:00
- `7z`: compresión de archivos de alto nivel
2015-06-24 19:58:46 +02:00
2015-07-07 20:47:36 +02:00
- `ldd`: información de librería dinámica
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- `nm`: símbolos de archvios objeto
2015-06-24 19:58:46 +02:00
2015-07-07 20:47:36 +02:00
- `ab`: benchmarking de servidores web
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `strace`: depuración de llamadas del sistema
2015-06-24 19:58:46 +02:00
2015-07-07 20:47:36 +02:00
- `mtr`: mejor traceroute para la depuración de la red
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- `cssh`: shell concurrente visual
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- `rsync`: sincronización de archivos y carpetas sobre SSH o en sistema de archivos locales
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `wireshark` y `tshark`: captura de paquetes y depuración de la red
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `ngrep`: grep para la capa de la red
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- `host` y `dig`: consultas DNS
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- `lsof`: descriptor de archivo de procesos e información de socket
2015-06-24 19:58:46 +02:00
2015-07-07 20:47:36 +02:00
- `dstat`: sistema de estadísticas útil
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- [`glances`](https://github.com/nicolargo/glances): visión general de multi-subsistemas, de alto nivel
2015-06-24 19:58:46 +02:00
- `iostat`: estadísticas del uso del disco duro
- `mpstat`: estadísticas del uso del CPU
- `vmstat`: estadísticas del uso de la memoria
2015-06-24 19:58:46 +02:00
2015-07-07 20:47:36 +02:00
- `htop`: versión mejorada de top
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `last`: historial de login
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- `w`: quién está autenticado
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `id`: información de identidad de usuario/grupo
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- `sar`: estadísticas históricas del sistema
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- `iftop` o `nethogs`: utilización de la red por un socket o proceso
2015-06-24 19:58:46 +02:00
2015-07-07 20:47:36 +02:00
- `ss`: estadísticas de socket
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- `dmesg`: mensajes de error del arranque y del sistema
2015-06-24 19:58:46 +02:00
2015-07-28 00:42:09 +02:00
- `sysctl`: examina y configura los parámetros de kernel de Linux en tiempo de ejecución
2015-07-03 18:45:43 +02:00
- `hdparm`: manipulación/rendimiento de discos SATA/ATA
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
- `lsb_release`: información de la distribución de Linux
2015-06-24 19:58:46 +02:00
2015-07-24 00:23:30 +02:00
- `lsblk`: lista de dispositivos de bloque: una vista tipo arbol de sus discos y particiones de disco
2015-06-24 19:58:46 +02:00
- `lshw`, `lscpu`, `lspci`, `lsusb`, `dmidecode`: información de hardware, incluyendo CPU, BIOS, RAID, gráficos, dispositivos, etc
2015-10-24 18:08:39 +02:00
- `lsmod` y `modinfo`: lista y muestra detalles de los módulos del kernel
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
- `fortune`, `ddate`, y `sl`: um, bien, depende de si considera las locomotoras de vapor y citas Zippy "útiles"
2015-06-24 19:58:46 +02:00
2015-07-15 20:47:35 +02:00
## Solo para MacOS X
2015-07-03 20:52:22 +02:00
Estos son puntos relevantes *únicamente* para MacOS.
2015-07-03 20:52:22 +02:00
- Administración de paquetes con `brew` (Homebrew) y/o `port` (MacPorts). Estos pueden ser utilizados para instalar en MacOS muchos de los comandos de arriba.
2015-07-24 00:23:30 +02:00
- Copie la salida de cualquier comando en una aplicación de escritorio con `pbcopy` y pegue una entrada con `pbpaste`.
2015-07-03 20:52:22 +02:00
2015-10-24 18:08:39 +02:00
- Para activar la teacla Option en un Terminal Mac OS Terminal como una tecla alt (tal como se usan en los comandos más arriba como **alt-b**, **alt-f**, etc.), abre Preferencias -> Perfiles -> Teclado y selecciona "Usa Option como tecla Meta".
2015-07-23 03:54:24 +02:00
- Para abrir un archivo con una aplicación de escritorio, use `open` o `open -a /Applications/Whatever.app`.
2015-07-03 20:52:22 +02:00
2015-07-23 03:54:24 +02:00
- Spotlight: Busque archivos con `mdfind` y liste metadata (tal como información de foto EXIF) con `mdls`.
2015-07-03 20:52:22 +02:00
- Ten en cuenta que MacOS está basado en BSD Unix, y muchos comandos (por ejemplo `ps`, `ls`, `tail`, `awk`, `sed`) tiene sutiles variaciones en comparación con Linux, que está en gran parte influenciado por el sistema Unix V-style y herramientas GNU. Comunmente se puede diferenciar al notar que una página man tienen el encabezado "BSD General Commands Manual." En algunos casos versiones GNU pueden ser instaladas también (tales como `gawk` y `gsed` para GNU awk y sed). Si escribe Bash scripts multiplataforma, evite tales comandos (por ejemplo, considere Python o `perl`) o prueba cuidadosamente.
2015-07-03 20:52:22 +02:00
2015-10-24 18:08:39 +02:00
- Para obtener la información de la versión del MacOS, usa `sw_vers`.
2015-07-03 20:52:22 +02:00
2015-07-03 18:45:43 +02:00
## Más recursos
2015-06-24 19:58:46 +02:00
- [awesome-shell](https://github.com/alebcay/awesome-shell): Una lista curada de herramientas shell y recursos.
2015-10-24 18:08:39 +02:00
- [awesome-osx-command-line](https://github.com/herrbischoff/awesome-osx-command-line): Una guía más detallada para la línea de comandos del Mac OS.
2015-07-03 18:45:43 +02:00
- [Strict mode](http://redsymbol.net/articles/unofficial-bash-strict-mode/) para escribir mejores script shell.
2015-10-24 18:08:39 +02:00
- [shellcheck](https://github.com/koalaman/shellcheck): Una herramienta de análisis estadístico del script shell. Esencialmente, lint para bash/sh/zsh.
- [Filenames and Pathnames in Shell](http://www.dwheeler.com/essays/filenames-in-shell.html): Las menudencias tristemente complejas sobre cómo manejar nombres de archivos correctamente en shell scripts.
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
## Advertencia
2015-06-24 19:58:46 +02:00
Con la excepción de tareas muy pequeñas, el código está escrito para que otros puedan leerlo. Con el poder llega la responsabilidad. El hecho de que *puedes* hacer algo en Bash no necesariamente significa que deba hacerlo! ;)
2015-06-24 19:58:46 +02:00
2015-07-03 18:45:43 +02:00
## Licencia
2015-06-24 19:58:46 +02:00
[![Creative Commons License](https://i.creativecommons.org/l/by-sa/4.0/88x31.png)](http://creativecommons.org/licenses/by-sa/4.0/)
2015-06-24 19:58:46 +02:00
2015-07-23 03:54:24 +02:00
Este trabajo está licenciado bajo [Creative Commons Attribution-ShareAlike 4.0 International License](http://creativecommons.org/licenses/by-sa/4.0/).