= Introducción = Mis portatiles son:
Un ordenador Acer 5755G con las siguientes características:
Core i5 2430M 2.4GHz
NVIDIA Geforce GT 540M (+ intel integrada)
8Gb RAM
750Gb HD
Este portátil equipa una tarjeta ''Nvidia Geforce GT540M'' que resulta pertenecer a una rama muerta en el árbol de desarrollo de Nvidia.
Esta tarjeta provocaba todo tipo de problemas de sobrecalientamiento, pero en las últimas versiones de Linux instalando el driver de Nvidia parece funcionar correctamente.
Un Lenovo Legion
Core i7-9750H
Nvidia GTX1650-4Gb (+ intel integrada)
16Gb RAM
512Gb SSD + 1Tb HDD
sudo
y las aplicaciones que uso habitualmente para gestión de paquetes por defecto (''aptitude'' y ''synaptic'').
Interesa tener instalado el paquete ''ppa-purge'' (sudo apt install ppa-purge
). Sirve para eliminar ppas junto con los programas instalados desde ese ppa.
Tampoco voy a enredar nada con los orígenes del software (de momento), es decir no voy a cambiar al depósito regional. Si quieres cambiarlo, en mi experiencia los más rápidos suelen ser los alemanes.
== Firmware ==
Ya no es necesario intalar los paquetes de ''microcode'' la instalación de Una se encargó de instalar:
* amd64-microcode
* intel-microcode
Instalamos el driver de nvidia recomendado, después de la instalación inicial el ''Mint'' nos avisará de que tenemos que revisar la instalación de los drivers.
El driver de Nvidia viene muy mejorado. Merece la pena ver todas las opciones.
Una vez instalado el driver de Nvidia, el comando prime-select query
debe indicarnos la tarjeta activa y podremos cambiar de tarjeta ejecutando prime-select [nvidia|intel]
. También podremos acceder a las funciones de Nvidia a través del applet en la barra de estado de nuestro escritorio.
== Control de configuraciones con git ==
Una vez instalado el driver de Nvidia y antes de seguir con la instalación instalamos el git
y el etckeeper
para que todos los cambios que se produzcan en el directorio /etc
durante nuestra instalación queden reflejados en el git.
Yo nunca almaceno esta información en la nube (por seguridad), pero me permite tener controlados los cambios de configuración y ayuda en caso de problemas.
=== Instalación de etckeeper
===
¡Ojo!, nos hacemos root
para ejecutar:
sudo su - git config --global user.email xxxxx@whatever.com git config --global user.name "Name Surname" apt install etckeeper''etckeeper'' hara un control automático de tus ficheros de configuración en
/etc
Para echar una mirada a los ''commits'' creados puedes ejecutar:
cd /etc sudo git log=== Controlar dotfiles con git === Vamos a crear un repo de git para controlar nuestros ficheros personales de configuración. Creamos el repo donde queramos, yo suelo usar el directorio
~/work/repos
.
mkdir usrcfg cd usrcfg git init git config core.worktree "/home/salvari"Y ya lo tenemos, un repo de git, en la localización que queramos y que tiene el directorio de trabajo apuntando a nuestro ''$HOME''. Podemos añadir los ficheros de configuración que queramos al repo:
git add .bashrc git commit -m "Add some dotfiles"Una vez que tenga añadidos los ficheros que quiero tener controlados pondré
*
en el fichero .git/info/exclude
de mi repo para que ignore todos los ficheros de mi $HOME
.
Cuando instalo algún programa nuevo añado a mano los ficheros de configuración que quiero tener controlados al repo.
Yo no tengo información confidencial en este repositorio (claves ssh por ejemplo) así que no tengo problemas en almacenarlo en la nube. Facilita mucho las cosas en casos de upgrade del sistema o copiar configuraciones entre ordenadores.
== Editor desde linea de comandos ==
Hasta que instalemos nuestro editor favorito (''Emacs'' en mi caso) podemos usar ''nano'' desde la linea de comandos para editar cualquier fichero. Pero yo añado ''micro'' con el paquete .deb
descargado desde [https://github.com/zyedidia/micro/releases su github].
== Parámetros de disco duro ==
Tengo un disco duro ssd y otro hdd normal.
El area de intercambio la hemos creado en el disco duro hdd, no se usará mucho (mejor dicho: no se usará nunca) pero evitamos multiples operaciones de escritura en el disco ssd en caso de que se empiece a tirar del swap.
Añadimos el parámetro noatime
para las particiones de root
y /home
, que si que se han creado en el ssd.
# /etc/fstab: static file system information. # # Use 'blkid' to print the universally unique identifier for a # device; this may be used with UUID= as a more robust way to name devices # that works even if disks are added and removed. See fstab(5). # # <file system> <mount point> <type> <options> <dump> <pass> # / was on /dev/sda5 during installation UUID=d96a5501-75b9-4a25-8ecb-c84cd4a3fff5 / ext4 noatime,errors=remount-ro 0 1 # /home was on /dev/sda7 during installation UUID=8fcde9c5-d694-4417-adc0-8dc229299f4c /home ext4 defaults,noatime 0 2 # /store was on /dev/sdc7 during installation UUID=0f0892e0-9183-48bd-aab4-9014dc1bd03a /store ext4 defaults 0 2 # swap was on /dev/sda6 during installation UUID=ce11ccb0-a67d-4e8b-9456-f49a52974160 none swap sw 0 0 # swap was on /dev/sdc5 during installation UUID=11090d84-ce98-40e2-b7be-dce3f841d7b4 none swap sw 0 0Una vez modificado el
/etc/fstab
no hace falta arrancar, basta con ejecutar lo siguiente:
mount -o remount / mount -o remount /home mount=== Ajustes adicionales para ''Firefox'' === Las diferencias de rendimiento del Firefox con estos ajustes son bastante notables. Seguimos [https://easylinuxtipsproject.blogspot.com/p/ssd.html#ID10 esta referencia] Visitamos
about::config
con el navegador.
Cambiamos
* browser.cache.disk.enable
'''false'''
* browser.cache.memory.enable
'''true'''
* browser.cache.memory.capacity
'''204800'''
* browser.sessionstore.interval
'''15000000'''
TODO: Comprobar ''trim'' en mi disco duro. Y mirar [https://easylinuxtipsproject.blogspot.com/p/speed-mint.html esto]
Y siguiendo [https://linuxreviews.org/HOWTO_Make_Mozilla_Firefox_Blazing_Fast_On_Linux esta otra referencia] cambiamos:
* gfx.x11-egl.force-enabled
'''true'''
* '''IMPORTANTE''' Ajustar el parámetro network.IDN_show_punycode
a '''true''' (para evitar ataques de URL falsas con caracteres Unicode)
Reiniciamos nuestro ''Firefox'' (podemos visitar about:restartRequired
)
== Fuentes (tipográficas) adicionales ==
Instalamos algunas fuentes desde los orígenes de software:
sudo apt install ttf-mscorefonts-installer sudo apt install fonts-notoY la fuente [https://robey.lag.net/2010/06/21/mensch-font.html Mensch] la bajamos directamente al directorio
~/.local/share/fonts
Puede ser conveniente instalar el paquete ''font-manager'' (sudo apt install font-manager
), sólo lo uso para visualizar fuentes, no para hacer configuración.
Instaladas varias de las [https://github.com/ryanoasis/nerd-fonts nerd-fonts] en ~/.local/share/fonts
. Simplemente descargamos las fuentes interesantes y ejecutamos sudo fc-cache -f -v
Fuentes interesantes:
* [https://github.com/ryanoasis/nerd-fonts nerd-fonts]
* [https://github.com/powerline/fonts Powerline fonts]
* [https://github.com/ProgrammingFonts/ProgrammingFonts Programming fonts]
== Firewall ==
ufw
y gufw
vienen instalados por defecto, pero no activados.
aptitude install ufw ufw default deny ufw enable ufw status verbose aptitude install gufw-----
'''Nota''': Ojo con el log de ufw
, tampoco le sienta muy bien al ssd esa escritura masiva. Yo normalmente lo dejo desactivado excepto cuando valido una nueva configuración.
-----
== Aplicaciones variadas ==
'''Nota''': Ya no instalamos ''menulibre'', Linux Mint tiene una utilidad de edición de menús.; KeepassXC : Para mantener nuestras contraseñas a buen recaudo ; Gnucash : Programa de contabilidad, la versión de los repos está bastante atrasada habrá que probar la nueva que puede instalarse desde la web o desde el flathub. ; Deluge : Programa de descarga de torrents (acuérdate de configurar tus cortafuegos) ; rsync, grsync : Para hacer backups de nuestros ficheros ; Descompresores variados : Para lidiar con los distintos formatos de ficheros comprimidos ; mc : Midnight Comander, gestor de ficheros en modo texto ; most : Un
less
mejorado
; tree
: Para ver estructuras de directorios
; neofetch
: Este solo vale para presumir de ordenador creo ¬_¬
; fasd
: Para cambiar entre directorios rápidamente
; silversearcher-ag
: Una alternativa mejorada al clásico ''grep''
; ack
: Otro grep mejorado
; ncdu
: Un analizador de uso de disco alternativa a du
; mate-tweak
: Para ''customizar'' nuestro escritorio Mate
; filezilla
: Un interfaz gráfico para transferencia de ficheros
; rofi
: Un conmutador de ventanas capaz de automatizar muchas tareas
; Chromium
: Como Chrome pero libre, en Linux Mint no hay snaps, puedes instalarlo directamente con apt
sudo apt install keepassxc gnucash deluge rsync grsync rar unrar \ zip unzip unace bzip2 lzop p7zip p7zip-full p7zip-rar \ most mc tree neofetch fasd silversearcher-ag ack ncdu mate-tweak filezilla \ rofi chromium== Algunos programas de control del sistema == Son útiles para control de consumo.
sudo apt install tlp tlp-rdw htop powertop== Programas de terminal == Dos imprescindibles:
sudo apt install guake terminator''terminator'' lo dejamos como aplicación terminal preferida del sistema. '''TODO:''' asociar ''Guake'' a una combinación apropiada de teclas. También instalo ''rxvt'' para tener una alternativa ligera al ''terminator''.
sudo apt install rxvt-unicode=== tmux === ''tmux'' combinado por ejemplo con ''rxvt'' nos da la misma funcionalidad que ''Terminator'', además merece la pena aprender a usarlo por que instalado en servidores remotos es increíblemente útil.
sudo apt install tmux* [https://leanpub.com/the-tao-of-tmux/read El tao de tmux] * [https://www.askapache.com/linux/rxvt-xresources/ rxvt customizations] == Dropbox == Lo instalamos desde el software manager. == Chrome == No lo he instalado. Puede instalarse desde [https://www.google.com/chrome/ la página web de Chrome] == Varias aplicaciones instaladas de binarios == Lo recomendable en un sistema POSIX es instalar los programas adicionales en
/usr/local
o en /opt
. Yo soy más chapuzas y suelo instalar en ~/apt
por que el portátil es personal e intrasferible. En un ordenador compartido es mejor usar /opt
.
En general cuando instalo en el directorio ~/apps
sigo los siguientes pasos:
Descargamos los binarios o ''appimage'' desde la web
Descomprimo en un nuevo directorio para la aplicación, tomamos como ejemplo freeplane, así que el directorio se llamará: ~/apps/mi_aplicacion
Creamos enlace simbólico al que llamamos current
. Esto es para no editar los ficheros .desktop
cada vez que actualicemos la versión del programa. El enlace puede apuntar a un directorio o a un binario, depende de como obtengamos la aplicación. En el caso de freeplane yo tengo la siguiente estructura
freeplane ├── current -> freeplane-1.7.11 ├── freeplane-1.7.10 └── freeplane-1.7.11
Vemos que el enlace apunta a la versión más reciente de ''freeplane''.
Añadimos la aplicación a los menús, al hacer esto se creará un fichero .desktop
en el directorio ~/.local/share/applications
.desktop
=== Tor browser ===
Descargamos desde la [https://www.torproject.org/ página oficial del proyecto] Descomprimimos en ~/apps/
y ejecutamos desde terminal:
cd ~/apps/tor-browser ./start-tor-browser.desktop --register-appTor se encarga tanto de crear el fichero
.desktop
como de mantenerse actualizado a la última versión.
=== Brave browser ===
Instalamos siguiendo las instrucciones de la [https://brave-browser.readthedocs.io/en/latest/installing-brave.html#linux página web oficial]
curl -s https://brave-browser-apt-release.s3.brave.com/brave-core.asc | sudo apt-key --keyring /etc/apt/trusted.gpg.d/brave-browser-release.gpg add - echo "deb [arch=amd64] https://brave-browser-apt-release.s3.brave.com/ stable main" | sudo tee /etc/apt/sources.list.d/brave-browser-release.list sudo apt update sudo apt install brave-browser=== TiddlyDesktop === Descargamos desde la [https://github.com/Jermolene/TiddlyDesktop página web], descomprimimos y generamos la entrada en el menú. === Joplin === Una herramienta libre para mantener notas sincronizadas entre el móvil y el portátil. Instalamos siguiendo las instrucciones de la [https://joplinapp.org/ página web]
wget -O - https://raw.githubusercontent.com/laurent22/joplin/master/Joplin_install_and_update.sh | bashJoplin se instala en el directorio
~/.joplin
y crea su propia entrada en el menú.
== Terminal y shells ==
Por defecto tenemos instalado bash
.
=== bash-git-promt ===
Para dejar configurado el ''bash-git-prompt'' seguimos las instrucciones de [https://github.com/magicmonty/bash-git-prompt este github]
=== zsh ===
Nos adelantamos a los acontecimientos, pero conviene tener instaladas las herramientas de entornos virtuales de python antes de instalar ''zsh'' con el plugin para ''virtualenvwrapper''.
apt install python-all-dev apt install python3-all-dev apt install virtualenv virtualenvwrapper python3-virtualenv''zsh'' viene por defecto en mi instalación, en caso contrario:
apt install zshPara ''zsh'' vamos a usar [https://github.com/zsh-users/antigen antigen], así que nos lo clonamos en
~/apps/
cd ~/apps git clone https://github.com/zsh-users/antigenTambién vamos a usar [https://github.com/olivierverdier/zsh-git-prompt zsh-git-prompt], así que lo clonamos también:
cd ~/apps git clone https://github.com/olivierverdier/zsh-git-promptY editamos el fichero
~/.zshrc
para que contenga:
# This line loads .profile, it's experimental [[ -e ~/.profile ]] && emulate sh -c 'source ~/.profile' source ~/apps/zsh-git-prompt/zshrc.sh source ~/apps/antigen/antigen.zsh # Load the oh-my-zsh's library. antigen use oh-my-zsh # Bundles from the default repo (robbyrussell's oh-my-zsh). antigen bundle git antigen bundle command-not-found # must install autojump for this #antigen bundle autojump # extracts every kind of compressed file antigen bundle extract # jump to dir used frequently antigen bundle z #antigen bundle pip antigen bundle common-aliases antigen bundle robbyrussell/oh-my-zsh plugins/virtualenvwrapper antigen bundle zsh-users/zsh-completions # Syntax highlighting bundle. antigen bundle zsh-users/zsh-syntax-highlighting antigen bundle zsh-users/zsh-history-substring-search ./zsh-history-substring-search.zsh # Arialdo Martini git needs awesome terminal font #antigen bundle arialdomartini/oh-my-git #antigen theme arialdomartini/oh-my-git-themes oppa-lana-style # autosuggestions antigen bundle tarruda/zsh-autosuggestions #antigen theme agnoster antigen theme gnzh # Tell antigen that you're done. antigen apply # Correct rm alias from common-alias bundle unalias rm alias rmi='rm -i'Para usar ''virtualenvwrapper'' hay que decidir en que directorio queremos salvar los entornos virtuales. El obvio seria
~/.virtualenvs
la alternativa sería ~/.local/share/virtualenvs
.
El que escojamos lo tenemos que crear y añadirlo a nuestro ~/.profile
con las líneas:
# WORKON_HOME for virtualenvwrapper if [ -d "$HOME/.virtualenvs" ] ; then WORKON_HOME="$HOME/.virtualenvs" fiDespués de seguir estos pasos basta con arrancar el ''zsh'' ''Antigen'' ya se encarga de descargar todos los plugins que queramos utilizar en zsh. Todos el software se descarga en
~/.antigen
Para configurar el [https://github.com/olivierverdier/zsh-git-prompt zsh-git-prompt], que inspiró el bash-git-prompt.
He modificado el fichero zshrc.sh
de zsh-git-prompt
cambiando la linea `echo “$STATUS”:
#echo "$STATUS" if [[ "$__CURRENT_GIT_STATUS" == ": 0 0 0 0 0 0" ]]; then echo "" else echo "$STATUS" fiTambién he cambiado el fichero del tema ''gnzh'' en
~/.antigen/bundles/robbyrussell/oh-my-zsh/themes/gnzh.zsh-theme
por que me interesa ver la versión python asociada a cada virtualenv.
== Codecs ==
sudo apt-get install mint-meta-codecs== Syncthing == Añadimos el ppa:
curl -s https://syncthing.net/release-key.txt | sudo apt-key add - echo "deb https://apt.syncthing.net/ syncthing stable" | sudo tee /etc/apt/sources.list.d/syncthing.list sudo apt-get update sudo apt-get install syncthing= Utilidades = == Utilidades variadas ==
''Agave'' y ''pdftk'' ya no existen, nos pasamos a ''gpick'' y ''poppler-utils''
sudo apt install gpick
Una utilidad de generación de gráficos que uso a veces. También es útil para web2py
y para `org-roam
sudo apt install graphviz
Un motor de bases de datos sencillo que se uso a menudo
sudo apt install sqlite3
Chuletas de comandos habituales, se instala bajando el ejecutable desde [https://github.com/cheat/cheat/releases su github]
Echa una mirada a su página web: http://cheat.sh/, es casi idéntico al anterior pero disponible desde cualquier ordenador con conexión.
Instalamos ''gparted'' para poder formatear memorias usb
sudo apt install gparted
Para pasar páginas web a pdf
sudo apt install wkhtmltopdf
ls
potenciado, instalamos el paquete desde [https://github.com/Peltoche/lsd/releases la página de releases del github del proyecto]
cat
potenciado, instalamos el paquete desde [https://github.com/sharkdp/bat/releases la página de releases del github del proyecto]
nmap
nos permite realizar mapeos de subredes en nuestras redes locales. Por ejemplo para localizar dispositivos enganchados a nuestra red. ndiff
nos permite comparar escaneos realizados con nmap
y ncat
hace todo tipo de cosas (mira en la red)
sudo apt install nmap ndiff ncat
El super conmutador de ventanas (y muchas más cosas).
Creamos el fichero ~/.config/rofi/config.rasi
con el siguiente contenido
Asociamos un atajo de teclado al comando: rofi -show drun
sudo add-apt-repository ppa:go-for-it-team/go-for-it-daily && sudo apt-get update sudo apt-get install go-for-it== autokey == Instalamos [https://github.com/autokey/autokey autokey] siguiendo [https://github.com/autokey/autokey/wiki/Installing#debian-and-derivatives las instrucciones para instalarlo con paquetes debian] Me he descargado la última estable en el Legion y la beta en el Acer. Después de descargar los paquetes Debian ejecutamos los siguientes comandos (para la estable):
python3-pyinotify
Si estamos usando un entorno virtual con pyenv creo que sería mejor usar la instalación con pip
([https://github.com/autokey/autokey/wiki/Installing#pip-installation ver documentación])
Para lanzar la aplicación ejecutamos: python3 -m autokey.gtkui
= Internet =
== Rclone ==
Instalamos desde la página web(https://rclone.org/), descargando el fichero .deb
.
curl https://rclone.org/install.sh | sudo bash=== Recetas rclone === Copiar directorio local en la nube:
rclone copy /localdir hubic:backup -vvSi queremos ver el directorio en la web de Hubic tenemos que copiarlo en ''default'':
rclone copy /localdir hubic:default/backup -vvSincronizar una carpeta remota en local:
rclone sync hubic:directorio_remoto /home/salvari/directorio_local -vv=== Referencias === * [https://elblogdelazaro.gitlab.io//articles/rclone-sincroniza-ficheros-en-la-nube/ Como usar rclone (blogdelazaro)] * [https://elblogdelazaro.gitlab.io//articles/rclone-cifrado-de-ficheros-en-la-nube/ y con cifrado (blogdelazaro)] * [https://rclone.org/docs/ Documentación] == Palemoon == Un fork de ''Firefox'' con menos chorradas. Instalado con el paquete
deb
descargado de su [https://software.opensuse.org/download.html?project=home:stevenpusser&package=palemoon página web]
== LibreWolf ==
Otro fork de ''Firefox'' centrado en la privacidad. Instalado como ''appimage'' descargado desde su [https://librewolf-community.gitlab.io/ página web]
'''UPDATE''': Ya está disponible el repo para Mint:
ln -s ~/.mozilla/native-messaging-hosts ~/.librewolf/native-messaging-hosts
* Clear URLs
* Mozilla Multiaccount Containers
== Netsurf ==
Un navegador ultraligero (aunque no funciona con muchas páginas, solo para webs austeras) Instalado via flathub con flatpak install netsurf
== Lagrange ==
Un navegador para el protocolo ''Gemini''. Instalado con la ''appimage'' desde su [https://git.skyjake.fi/gemini/lagrange página web]
== Castor ==
Otro navegador para el protocolo ''Gemini'' programado en ''Rust''. Instalado desde las fuentes siguiendo instrucciones de su [https://sr.ht/~julienxx/Castor/ página web]
== Sengi: Cliente de Mastodon ==
Instalada ''appimage'' desde su [https://github.com/NicolasConstant/sengi github]
= Window Managers adicionales =
== i3wm ==
Añadimos el repo:
pyenv
.
* Creamos el ''virtualenv'' qtile
basado en la versión 3.10.0 que teniamos instalada previamente:
qtile start
, pero no puede funcionar claro. Para que arranque correctamente, tenemos que lanzarlo en un servidor X. (ver el punto “[[#lanzar-window-managers-con-xephyr|Lanzar Window Managers con Xephyr]]”)
=== Configurar Qtile en ''virtualenv'' para arrancer desde el ''Lightdm'' ===
Como root
nos creamos un script launch_qtile
en /usr/local/bin
, con el siguiente contenido
chmod 755 launch_qtile
(ojo a los permisos para ''all'' que si no son estos no le gusta a ''Lightdm'')
También como root
creamos el fichero /usr/share/xsessions/qtile.desktop
con el contenido:
i3
por qtile start
= Comunicación con dispositivos Android =
== scrcpy ==
sudo apt install scrcpy
== Heimdall ==
Para flashear roms en moviles
deb
y que nuestro sistema sepa que tenemos ''texlive'' instalado.
cd ~ mkdir tmp cd tmp wget http://mirror.ctan.org/systems/texlive/tlnet/install-tl-unx.tar.gz tar xzf install-tl-unx.tar.gz cd install-tl-xxxxxxLa parte xxxxxx varía en función del estado de la última versión de LaTeX disponible.
sudo ./install-tlUna vez lanzada la instalación podemos desmarcar las opciones que instalan la documentación y las fuentes. Eso nos obligará a consultar la documentación on line pero ahorrará practicamente el 50% del espacio necesario. En mi caso sin doc ni src ocupa 2,3Gb
mkdir -p /opt/texbin sudo ln -s /usr/local/texlive/2020/bin/x86_64-linux/* /opt/texbinPor último para acabar la instalación añadimos
/opt/texbin
al ''PATH''. Para ''bash'' y ''zsh'' basta con añadir al fichero ~/.profile
las siguientes lineas:
# adds texlive to my PATH if [ -d "/opt/texbin" ] ; then PATH="$PATH:/opt/texbin" fiEn cuanto a ''fish'' (si es que lo usas, claro) tendremos que modificar (o crear) el fichero
~/.config/fish/config.fish
y añadir la siguiente linea:
set PATH $PATH /opt/texbin=== Falsificando paquetes === Ya tenemos el ''texlive'' instalado, ahora necesitamos que el gestor de paquetes sepa que ya lo tenemos instalado.
sudo apt install equivs --no-install-recommends mkdir -p /tmp/tl-equivs && cd /tmp/tl-equivs equivs-control texlive-localAlternativamente para hacerlo más fácil podemos descargarnos un fichero
texlive-local
ya preparado, ejecutando:
wget http://www.tug.org/texlive/files/debian-equivs-2018-ex.txt /bin/cp -f debian-equivs-2020-ex.txt texlive-localEditamos la versión (si queremos) y procedemos a generar el paquete ''deb''.
equivs-build texlive-localEl paquete que hemos generado tiene una dependencia: ''freeglut3'', hay que instalarla previamente.
sudo apt install freeglut3 sudo dpkg -i texlive-local_2020-1_all.debTodo listo, ahora podemos instalar cualquier paquete debian que dependa de ''texlive'' sin problemas de dependencias, aunque no hayamos instalado el ''texlive'' de Debian. === Fuentes === Para dejar disponibles las fuentes opentype y truetype que vienen con texlive para el resto de aplicaciones:
sudo cp $(kpsewhich -var-value TEXMFSYSVAR)/fonts/conf/texlive-fontconfig.conf /etc/fonts/conf.d/09-texlive.conf sudo nano /etc/fonts/conf.d/09-texlive.confBorramos la linea:
<dir>/usr/local/texlive/20xx/texmf-dist/fonts/type1</dir>Y ejecutamos:
sudo fc-cache -fsvActualizaciones Para actualizar nuestro ''latex'' a la última versión de todos los paquetes:
sudo /opt/texbin/tlmgr update --self sudo /opt/texbin/tlmgr update --allTambién podemos lanzar el instalador gráfico con:
sudo /opt/texbin/tlmgr --guiPara usar el instalador gráfico hay que instalar previamente:
sudo apt-get install perl-tk --no-install-recommendsLanzador para el actualizador de ''texlive'':
mkdir -p ~/.local/share/applications /bin/rm ~/.local/share/applications/tlmgr.desktop cat > ~/.local/share/applications/tlmgr.desktop << EOF [Desktop Entry] Version=1.0 Name=TeX Live Manager Comment=Manage TeX Live packages GenericName=Package Manager Exec=gksu -d -S -D "TeX Live Manager" '/opt/texbin/tlmgr -gui' Terminal=false Type=Application Icon=system-software-update EOF== Tipos de letra == Creamos el directorio de usuario para tipos de letra:
mkdir ~/.local/share/fonts== Fuentes Adicionales == Me he descargado de internet la fuente [https://robey.lag.net/downloads/mensch.ttf Mensch] el directorio de usuario para los tipos de letra:
~/.local/share/fonts
Además he clonado el repo [https://github.com/ProgrammingFonts/ProgrammingFonts ''Programming Fonts''] aunque parece que las fuentes están un poco anticuadas.
cd ~/wherever git clone https://github.com/ProgrammingFonts/ProgrammingFonts cd ~/.local/share/fonts ln -s ~/wherever/ProgrammingFonts/Menlo .La fuente Hack la he instalado directamente desde el [https://sourcefoundry.org/hack/ sitio web] == Pandoc == ''Pandoc'' es un traductor entre formatos de documento. Está escrito en Python y es increiblemente útil. De hecho este documento está escrito con ''Pandoc''. Instalado el ''Pandoc'' descargando paquete
.deb
desde [http://pandoc.org/installing.html la página web del proyecto].
Además descargamos plantillas de Pandoc desde [https://github.com/jgm/pandoc-templates este repo] ejecutando los siguientes comandos:
mkdir ~/.pandoc cd ~/.pandoc git clone https://github.com/jgm/pandoc-templates templatesLas plantillas no son imprescindibles pero si quieres aprender a usarlas o hacer alguna modificación viene bien tenerlas. == Algunos editores adicionales == Dos editores para hacer pruebas: ; Obsidian : Instalado con ''appimage'' descargado desde la [https://obsidian.md/ página web] ; Zettlr : Instalado con fichero
.deb
descargado desde [https://www.zettlr.com/ su página web]
== Calibre ==
La mejor utilidad para gestionar tu colección de libros electrónicos.
Ejecutamos lo que manda la página web:
sudo -v && wget -nv -O- https://download.calibre-ebook.com/linux-installer.sh | sudo sh /dev/stdinEl programa queda instalado en
/opt/calibre
. Se puede desinstalar con el comando sudo calibre-unistall
.
Para usar el calibre con el Kobo Glo:
* Desactivamos todos los plugin de Kobo menos el Kobo Touch Extended
* Creamos una columna MyShelves con identificativo #myshelves
* En las opciones del plugin:
** En la opción Collection columns añadimos las columnas series,#myshelves
** Marcamos las opciones Create collections y Delete empy collections
** Marcamos ''Modify CSS''
** Update metadata on device y Set series information
Algunos enlaces útiles:
* (https://github.com/jgoguen/calibre-kobo-driver)
* (http://www.lectoreselectronicos.com/foro/showthread.php?15116-Manual-de-instalaci%C3%B3n-y-uso-del-plugin-Kobo-Touch-Extended-para-Calibre)
* (http://www.redelijkheid.com/blog/2013/7/25/kobo-glo-ebook-library-management-with-calibre)
* (https://www.netogram.com/kobo.htm)
== Scribus ==
Scribus es un programa libre de composición de documentos. con Scribus puedes elaborar desde los folletos de una exposición hasta una revista o un poster.
Instalamos desde los depósitos oficiales de Mint.
Se podría instalar desde ppa cuando lo actualicen para incluir Ubunto 20 con los siguientes comandos:
sudo add-apt-repository ppa:scribus/ppa sudo apt update sudo apt install scribus scribus-ng scribus-template scribus-ng-doc=== Cambiados algunos valores por defecto === He cambiado los siguientes valores en las dos versiones, non están exactamente en el mismo menú pero no son díficiles de encontrar: * Lenguaje por defecto: '''English''' * Tamaño de documento: '''A4''' * Unidades por defecto: '''milimeters''' * Show Page Grid: '''Activado''' * Dimensiones de la rejilla: ** Mayor: '''30 mm''' ** Menor: '''6mm''' * En opciones de salida de ''pdf'' indicamos que queremos salida a impresora y no a pantalla. Y también que no queremos ''spot colors'', que serían sólo para ciertas impresoras industriales, así que activamos la opción ''Convert Spot Colors to Process Colors''. Siempre se puede volver a los valores por defecto sin mucho problema (hay una opción para ello) Referencia [https://www.youtube.com/watch?v=3sEoYZGABQM&list=PL3kOqLpV3a67b13TY3WxYVzErYUOLYekI aquí] === Solucionados problemas de ''hyphenation'' === ''Scribus'' no hacia correctamente la separación silábica en castellano, he instalado los paquetes: * hyphen-es * hyphen-gl Y ahora funciona correctamente. == Foliate: lector de libros electrónicos == Instalado el paquete deb desde [https://github.com/johnfactotum/foliate/releases su propio github] == Zotero: Gestor de referencias bibliográficas == Por cortesía de [https://github.com/retorquere/zotero-deb Emiliano Heyns] tenemos disponible el paquete de Zotero para Debian y Ubuntu.
sudo apt install build-essential checkinstall make automake cmake autoconf \ git git-core git-crypt dpkg wget== Git == ----- '''NOTA''': Si quieres instalar la última versión de git, los git developers tienen un ppa para ubuntu, si quieres tener el git más actualizado:
sudo add-apt-repository ppa:git-core/ppa sudo apt update sudo apt upgrade----- Control de versiones distribuido. Imprescindible. Para ''Linux Mint'' viene instalado por defecto. Configuración básica de git:
git config --global ui.color auto git config --global user.name "Pepito Pérez" git config --global user.email "pperez@mikasa.com" git config --global alias.cl clone git config --global alias.st "status -sb" git config --global alias.last "log -1 --stat" git config --global alias.lg "log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %Cblue<%an>%Creset' --abbrev-commit --date=relative --all" git config --global alias.dc "diff --cached" git config --global alias.unstage "reset HEAD --" git config --global alias.ci commit git config --global alias.ca "commit -a" git config --global alias.ri "rebase -i" git config --global alias.ria "rebase -i --autosquash" git config --global alias.fix "commit --fixup" git config --global alias.squ "commit --squash" git config --global alias.cp cherry-pick git config --global alias.co checkout git config --global alias.br branch git config --global core.editor emacs== Emacs == Instalado emacs desde los repos:
sudo aptitude install emacs== Lenguaje de programación D (D programming language) == El lenguaje de programación D es un lenguaje de programación de sistemas con una sintaxis similar a la de C y con tipado estático. Combina eficiencia, control y potencia de modelado con seguridad y productividad. === D-apt e instalación de programas === Configurado ''d-apt'', instalados todos los programas incluidos
sudo wget http://master.dl.sourceforge.net/project/d-apt/files/d-apt.list -O /etc/apt/sources.list.d/d-apt.list sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys EBCF975E5BA24D5E sudo apt updateInstalamos todos los programas asociados excepto ''textadept'' que no uso.
sudo apt install dmd-compiler dmd-tools dub dcd dfix dfmt dscanner=== DCD === Una vez instalado el DCD tenemos que configurarlo creando el fichero
~/.config/dcd/dcd.conf
con el siguiente contenido:
/usr/include/dmd/druntime/import /usr/include/dmd/phobosPodemos probarlo con:
dcd-server & echo | dcd-client --search toImpl=== gdc === Instalado con:
sudo aptitude install gdc=== ldc === Instalado con:
sudo aptitude install ldcPara poder ejecutar aplicaciones basadas en Vibed, necesitamos instalar:
sudo apt-get install -y libssl-dev libevent-dev=== Emacs para editar D === Instalados los siguientes paquetes desde Melpa * d-mode * flymake-d * flycheck * flycheck-dmd-dub * flychek-d-unittest * auto-complete (desde melpa) * ac-dcd Referencias * (https://github.com/atilaneves/ac-dcd) * (https://github.com/Hackerpilot/DCD) == C, C++ == === Instalación de Gnu Global === Para instalar las dependencias, previamente instalamos:
sudo apt install ncurses-dev id-utils exuberant-ctags python-pygmentsCon
ctags --version
nos aseguramos de que se llama a Exuberant y no el ctags que instala Emacs. Si no es así habrá que revisar la definición del PATH
python-pygments
no es necesario para C o C++, pero añade funcionalidad a Global (hasta 25 lenguajes de programación más)
No podemos instalar Global desde los repos de Ubuntu, está muy anticuado y genera bases de datos enormes y lentas. Tendremos que compilarlo.
Nos bajamos las fuentes del programa desde [https://www.gnu.org/software/global/ la página oficial] En el momento de escribir esto se trata de la versión 6.6.4.
Descomprimimos los fuentes y los compilamos con:
./configure --prefix=/usr/local --with-exuberant-ctags=/usr/bin/ctags make sudo make installHe comprobado que make uninstall funciona correctamente, las librerías quedan instaladas en
/usr/local/lib/gtags
y los ejecutables en /usr/local/bin
== Rust ==
Instalamos siguiendo las instrucciones de [https://www.rust-lang.org/tools/install aqui] (Hacemos la instalación por defecto)
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh stable installed - rustc 1.47.0 (18bf6b4f0 2020-10-07) Rust is installed now. Great! To get started you need Cargo's bin directory ($HOME/.cargo/bin) in your PATH environment variable. Next time you log in this will be done automatically. To configure your current shell run source $HOME/.cargo/envYo comento la linea del fichero
.zprofile
por que mi .zshrc
ya lee el fichero .profile
Para desinstalar rust
bastaría con ejecutar rustup self uninstall
Para actualizar la instalación: rustup update
=== RLS ===
Seguimos las instrucciones de la página oficial de [https://emacs-lsp.github.io/lsp-mode/page/lsp-rust/ LSP] y de [https://github.com/rust-lang/rls RLS]
/usr/local/
~/.profile
:
~/apps/
, en las nuevas versiones incorpora un script de instalación que ya se encarga de crear el fichero ''desktop''.
La última versión incorpora varios modos de trabajo, he descargado el modo ''Python'' para probarlo.
== openFrameworks ==
Nos bajamos los fuentes para linux 64bits desde [https://openframeworks.cc la página web del proyecto], y las descomprimimos en un directorio para proceder a compilarlas.
No hay más que seguir [https://openframeworks.cc/setup/linux-install/ las instrucciones de instalación para linux].
La instalación no es demasiado intrusiva si tienes Ubuntu 18 o mayor y una versión reciente del gcc.
En la primera pregunta que nos hace es necesario contestar que no. De lo contrario falla la compilación.
Añade los siguientes paquetes a nuestro sistema
installing OF dependencies OF needs to install the following packages using apt-get: curl libjack-jackd2-0 libjack-jackd2-dev freeglut3-dev libasound2-dev libxmu-dev libxxf86vm-dev g++ libgl1-mesa-dev libglu1-mesa-dev libraw1394-dev libudev-dev libdrm-dev libglew-dev libopenal-dev libsndfile-dev libfreeimage-dev libcairo2-dev libfreetype6-dev libssl-dev libpulse-dev libusb-1.0-0-dev libgtk-3-dev libopencv-dev libassimp-dev librtaudio-dev libboost-filesystem-dev libgstreamer1.0-dev libgstreamer-plugins-base1.0-dev gstreamer1.0-libav gstreamer1.0-pulseaudio gstreamer1.0-x gstreamer1.0-plugins-bad gstreamer1.0-alsa gstreamer1.0-plugins-base gstreamer1.0-plugins-good gdb libglfw3-dev liburiparser-dev libcurl4-openssl-dev libpugixml-dev libgconf-2-4 libgtk2.0-0 libpoco-dev Do you want to continue? [Y/n]No te olvides de compilar también el ''Project Generator''. == Python == De partida tenemos instalado dos versiones: ''python2'' y ''python3'' Parece que Linux Mint no viene con nigún python por defecto. Si invocamos el comando
python
el sistema nos indicará que no existe.
Para escoger un python por defecto tenemos dos paquetes que podemos instalar: python-is-python2
y python-is-python3
En principio yo no quería instalar ninguno para averigüar que paquetes no funcionaban, pero la instalación de VirtualBox hizo que se instalara automáticamente el paquete python-is-python2
.
python2 -V Python 2.7.18rc1 python3 -V Python 3.8.2=== Paquetes de python instalados === Son los que ya comentamos en la sección de instalación de zsh, como ya dijimos conviene que instalemos los paquetes de desarrollo:
sudo apt install python2-dev sudo apt install python-all-dev sudo apt install python3-dev sudo apt install python3-all-dev sudo apt install virtualenv virtualenvwrapper python3-virtualenvAdemas añadimos las siguientes lineas al fichero
~/.profile
:
# WORKON_HOME for virtualenvwrapper if [ -d "$HOME/.virtualenvs" ] ; then WORKON_HOME="$HOME/.virtualenvs" fi[https://virtualenvwrapper.readthedocs.io/en/latest/command_ref.html Aquí] tenemos la referencia de comandos de ''virtualenvwrapper''. === Instalación de bpython y ptpython === [https://bpython-interpreter.org/ ''bpython''] instalado desde repos
sudo apt install bpython bpython3
[https://github.com/prompt-toolkit/ptpython ''ptpython''] instalado en un virtualenv para probarlo
=== Jupyter ===
Una instalación para pruebas.
mkvirtualenv -p /usr/bin/python3 jupyter python -m pip install jupyter=== Instalamos
python3.9
===
python3.9
está ya disponible en los repos oficiales. Para dejarla instalada:
sudo apt install python3.9 python3.9-dev python3.9-venv=== pyenv === Instalamos los pre-requisitos:
home
:
.zshrc
y dejar que se encargue de todo.
~/.profile
:
~/.bashrc
y en ~/.zshrc
(aunque en el último no es necesario tocar nada si usamos el ''bundle'' para ''Antigen''):
pyenv install -l
Una vez instalado hay que estudiarse [https://github.com/pyenv/pyenv/blob/master/COMMANDS.md la referencia de comandos]
=== poetry ===
Instalamos con:
~ /.profile
, añadiendo las siguientes lineas:
poetry self update
== neovim ==
Vamos a probar ''neovim'', ahora mismo la versión de los repos de Ubuntu está actualizada a la penúltima versión (0.4.3). También podemos descargar el appimage desde [https://github.com/neovim/neovim/releases la página web]
Es de esperar que alguna vez vuelvan a tener el neovim disponible en los repos de la aplicación:
sudo apt-add-repository ppa:neovim-ppa/stable sudo apt update sudo apt install neovimPara instalar los módulos de python creamos un ''virtualev'' que más tarde añadiremos al fichero
init.vim
.
mkvirtualenv -p /usr/bin/python3 neovim3 sudo pip install --upgrade neovim deactivateRevisar [https://neovim.io/doc/user/provider.html#provider-python esto] {| | '''NOTA''': El siguiente paso ya no parece necesario, las alternativas |- | se han actualizado con la instalación del ''neovim''. |} Para actualizar las alternativas:
sudo update-alternatives --install /usr/bin/vi vi /usr/bin/nvim 60 sudo update-alternatives --config vi sudo update-alternatives --install /usr/bin/vim vim /usr/bin/nvim 60 sudo update-alternatives --config vim==== Install ''vim-plug'' ==== Ejecutamos:
curl -fLo ~/.local/share/nvim/site/autoload/plug.vim --create-dirs \ https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vimConfiguramos el fichero de configuración de ''nvim'' (
~/.config/nvim/init.vim
):
" Specify a directory for plugins " - For Neovim: ~/.local/share/nvim/plugged " - Avoid using standard Vim directory names like 'plugin' call plug#begin('~/.local/share/nvim/plugged') if has('nvim') Plug 'Shougo/deoplete.nvim', { 'do': ':UpdateRemotePlugins' } else Plug 'Shougo/deoplete.nvim' Plug 'roxma/nvim-yarp' Plug 'roxma/vim-hug-neovim-rpc' endif Plug 'deoplete-plugins/deoplete-jedi' " Initialize plugin system call plug#end() let g:deoplete#enable_at_startup = 1 " set python enviroments let g:python_host_prog = '/full/path/to/neovim2/bin/python' let g:python3_host_prog = '/home/salvari/.virtualenvs/neovim3/bin/python'La primera vez que abramos ''nvim'' tenemos que instalar los plugin porn comando ejecutando:
:PlugInstall
'''Instalación de dein
'''
{|
| '''Nota''':
|-
| Solo hay que instalar uno de los dos o ''dein'' o ''plug-vim''. Yo uso
|-
| ''plug-vim'' así que esto es sólo una referencia.
|}
https://github.com/Shougo/dein.vim
" Add the dein installation directory into runtimepath set runtimepath+=~/.config/nvim/dein/repos/github.com/Shougo/dein.vim if dein#load_state('~/.config/nvim/dein') call dein#begin('~/.config/nvim/dein') call dein#add('~/.config/nvim/dein/repos/github.com/Shougo/dein.vim') call dein#add('Shougo/deoplete.nvim') call dein#add('Shougo/denite.nvim') if !has('nvim') call dein#add('roxma/nvim-yarp') call dein#add('roxma/vim-hug-neovim-rpc') endif call dein#end() call dein#save_state() endif filetype plugin indent on syntax enable== Firefox developer edition == El rollo de siempre, descargar desde [https://www.mozilla.org/en-US/firefox/developer/ la página web] descomprimir en
~/apps
y crear un lanzador.
== Navegadores cli ==
Herramientas útiles para depuración web
sudo apt install httpie links== MariaDB == Instalamos la última estable para Ubuntu Fossa desde los repos oficiales. Primero añadimos los repos. Añadimos la clave de firma:
sudo apt-key adv --fetch-keys 'https://mariadb.org/mariadb_release_signing_key.asc'Ahora tenemos dos opciones: Podemos ejecutar:
sudo add-apt-repository 'deb [arch=amd64,arm64,ppc64el] http://mariadb.mirror.liteserver.nl/repo/10.5/ubuntu focal main'O podemos crear un fichero
/etc/apt/apt.sources.list.d/MariaDB
con el siguiente contenido (yo dejo las fuentes comentadas):
# MariaDB 10.5 [Stable] repository list - created UTC # https://mariadb.org/download-test/ deb [arch=amd64] http://mariadb.mirror.liteserver.nl/repo/10.5/ubuntu focal main # deb-src http://mariadb.mirror.liteserver.nl/repo/10.5/ubuntu focal mainY ya solo nos queda lo de siempre:
sudo apt update sudo apt upgrade sudo apt install mariadb-serverPodemos comprobar con
systemctl status mariadb
También podemos hacer login con el usuario root
:
sudo mariadb -u root'''Ojo''', hay que hacer
sudo
, el comando mariadb -u root
no funciona.
Y ahora aseguramos la instación con:
sudo mysql_secure_installationYo diría que tienes que decir que si a todas las preguntas, excepto quizás al ''unix_socket_authentication''. Por último sólo nos queda decidir si el servicio mariadb debe estar ejecutándose permanentemente o no. Si queremos pararlo y que no se arranque automáticamente al arrancar el ordenador:
sudo systemctl stop mariadb sudo systemctl disable mariadb== Squirrel SQL Client == Bajamos el zip de estándar desde [http://www.squirrelsql.org/ la página web de Squirrel] (yo prefiero no usar el instalador) Como de costumbre descomprimimos en
~/apps
y creamos una entrada en nuestro menú de aplicaciones.
Nos descargamos también el ''java connector'' para MariaDB. Desde la página oficial. Nos interesa el fichero maria-java-client-2.6.0.jar
Configuramos el driver para que sepa donde está el fichero .jar
y ya estamos listos para trabajar.
== R y R-studio ==
Primero instalamos la última versión de R en nuestro pc:
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys E298A3A825C0D65DFD57CBB651716619E084DAB9 sudo add-apt-repository 'deb https://cloud.r-project.org/bin/linux/ubuntu focal-cran40/' sudo apt update sudo apt install r-base=== R-studio === Ojo, tenemos ''R-studio Server'' y ''R-studio Desktop'', en tu portátil casi seguro que quieres el ''Desktop'' y no el ''Server''. Para ''R-studio Server'' descargamos la última versión disponible de ''R-studio'' desde la [https://rstudio.com/products/rstudio/download-server/debian-ubuntu/ página web] Instalamos con ''gdebi'' (basta con clicar sobre el fichero ''.deb'') Para ''R-studio Desktop'' descargamos la última versión disponible desde la [https://www.rstudio.com/products/rstudio/download/#download página web] Igual que el ''Server'' instalamos el paquete del ''Desktop'' con ''gedebi''. == Octave == Instalado desde flatpak
sudo flatpak install flathub org.octave.Octave= Desarrollo hardware = == Arduino IDE == Bajamos los paquetes de la página [https://www.arduino.cc web], descomprimimimos en ''~/apps/arduino''. La distribución del IDE incluye ahora un fichero
install.sh
que se encarga de hacer la integración del IDE en los menús de Linux.
Además también incluye un script (arduino-linux-setup.sh
) para crear las ''devrules'' y que además desinstala el driver ''modemmanager'' y crea grupos nuevos en el sistema si no existen.
No tengo claro lo de desinstalar el driver así que creamos las ''devrules'' a mano mirando por el fichero.
Hay que añadir nuestro usuario a los grupos ''tty'', ''dialout'', ''uucp'' y ''plugdev'' (no hay que crear grupos nuevos, ya tenemos todos en el sistema)
sudo gpasswd --add <usrname> tty sudo gpasswd --add <usrname> dialout sudo gpasswd --add <usrname> uucp sudo gpasswd --add <usrname> plugdevCreamos los siguientes ficheros en el directorio
/etc/udev/rules.d
Fichero 90-extraacl.rules
mete mi usario en el fichero de reglas (¬_¬)
# Setting serial port rules KERNEL=="ttyUSB[0-9]*", TAG+="udev-acl", TAG+="uaccess", OWNER="salvari" KERNEL=="ttyACM[0-9]*", TAG+="udev-acl", TAG+="uaccess", OWNER="salvari"Fichero
98-openocd.rules
# Adding Arduino M0/M0 Pro, Primo UDEV Rules for CMSIS-DAP port ACTION!="add|change", GOTO="openocd_rules_end" SUBSYSTEM!="usb|tty|hidraw", GOTO="openocd_rules_end" #Please keep this list sorted by VID:PID #CMSIS-DAP compatible adapters ATTRS{product}=="*CMSIS-DAP*", MODE="664", GROUP="plugdev" LABEL="openocd_rules_end"Fichero
avrisp.rules
# Adding AVRisp UDEV rules SUBSYSTEM!="usb_device", ACTION!="add", GOTO="avrisp_end" # Atmel Corp. JTAG ICE mkII ATTR{idVendor}=="03eb", ATTRS{idProduct}=="2103", MODE="660", GROUP="dialout" # Atmel Corp. AVRISP mkII ATTR{idVendor}=="03eb", ATTRS{idProduct}=="2104", MODE="660", GROUP="dialout" # Atmel Corp. Dragon ATTR{idVendor}=="03eb", ATTRS{idProduct}=="2107", MODE="660", GROUP="dialout" LABEL="avrisp_end"Fichero
40-defuse.rules
:
# Adding STM32 bootloader mode UDEV rules # Example udev rules (usually placed in /etc/udev/rules.d) # Makes STM32 DfuSe device writeable for the "plugdev" group ACTION=="add", SUBSYSTEM=="usb", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="df11", MODE="664", GROUP="plugdev", TAG+="uaccess"Fichero
99-arduino-101.rules
:
# Arduino 101 in DFU Mode SUBSYSTEM=="tty", ENV{ID_REVISION}=="8087", ENV{ID_MODEL_ID}=="0ab6", MODE="0666", ENV{ID_MM_DEVICE_IGNORE}="1", ENV{ID_MM_CANDIDATE}="0" SUBSYSTEM=="usb", ATTR{idVendor}=="8087", ATTR{idProduct}=="0aba", MODE="0666", ENV{ID_MM_DEVICE_IGNORE}="1"Yo añado el fichero
99-arduino.rules
que se encarga de inhibir el modemmanager para que no capture al ''CircuitPlayground Express'':
# for arduino brand, stop ModemManager grabbing port ATTRS{idVendor}=="2a03", ENV{ID_MM_DEVICE_IGNORE}="1" # for sparkfun brand, stop ModemManager grabbing port ATTRS{idVendor}=="1b4f", ENV{ID_MM_DEVICE_IGNORE}="1"Una vez añadidos todos los ficheros de reglas recargamos con:
https://adafruit.github.io/arduino-board-index/package_adafruit_index.json
, si tenemos otras URL, simplemente añadimos esta separada por una coma.
Ahora desde el ''Board Manager'' instalamos:
* Arduino SAMD Boards
* Adafruit SAMD Boards
=== Añadir soporte para ''Circuit Playground Express'' ===
Bastaría con instalar ''Arduino SAMD Boards''
=== Añadir soporte para STM32 ===
Tenemos varias URL posibles para configurar en las preferencias del IDE Arduino:
* http://dan.drown.org/stm32duino/package_STM32duino_index.json (recomendada por Tutoelectro)
* https://github.com/stm32duino/BoardManagerFiles/raw/master/STM32/package_stm_index.json (parece la oficial)
He optado por añadir los dos ficheros json al IDE, la oficial tiene buena pinta pero parece que no soporta st-link. Con la otra podremos usarlo sin problemas.
Instalamos la biblioteca stm32 cores
que corresponde al origen de software oficial y la biblioteca STM32F1xx/GD32F1xx
, esta última es la que nos dará soporte explícito para el st-link
Lo probamos con el ''Blink'' y funciona perfectamente con las opciones de la [[#figura_1|Figura 1]]
[[File:src/img/stm32_arduino_opts.jpg|thumb|none|alt=Menu Arduino desplegado|Opciones Arduino para STM32 con st-link]]
=== Añadir soporte para ESP32 y ESP8266 ===
Añadimos las URL:
* https://dl.espressif.com/dl/package_esp32_index.json
* http://arduino.esp8266.com/stable/package_esp8266com_index.json
Añadimos la librería:
* ESP32 (de espressif)
=== Añadir biblioteca de soporte para Makeblock ===
-----
'''Nota''': Pendiente de instalar
-----
Clonamos el [https://github.com/Makeblock-official/Makeblock-Libraries repo oficial en github].
Una vez que descarguemos las librerias es necesario copiar el directorio Makeblock-Libraries/makeblock
en nuestro directorio de bibliotecas de Arduino. En mi caso ~/Arduino/libraries/
.
Una vez instaladas las bibliotecas es necesario reiniciar el IDE Arduino si estaba arrancado. Podemos ver si se ha instalado correctamente simplemente echando un ojo al menú de ejemplos en el IDE, tendríamos que ver los ejemplos de ''Makeblock''.
Un detalle importante para programar el Auriga-Me es necesario seleccionar el micro Arduino Mega 2560 en el IDE Arduino.
== Pinguino IDE ==
-----
'''Nota''': Pendiente de instalar
-----
Tenemos el paquete de instalación disponible en su página [http://pinguino.cc/download.php web]
Ejecutamos el programa de instalación. El programa descargará los paquetes Debian necesarios para dejar el IDE y los compiladores instalados.
Al acabar la instalación he tenido que crear el directorio ''~/Pinguino/v11'', parece que hay algún problema con el programa de instalación y no lo crea automáticamente.
El programa queda correctamente instalado en ''/opt'' y arranca correctamente, habrá que probarlo con los micros.
== stm32 cubeide ==
Nos bajamos el instalador genérico. Tendremos que:
* aceptar un montón de acuerdos de licencias
* indicarle un directorio de instalación (en mi caso `~/apps/st/st/stm32cubeide_1.4.0)
* darle la password de root para instalar ficheros de udev, concretamente:
** udev/rules.d/49-stlinkv1.rules
** udev/rules.d/49-stlinkv2-1.rules
** udev/rules.d/49-stlinkv2.rules
** udev/rules.d/49-stlinkv3.rules
** udev/rules.d/99-jlink.rules
== esp-idf ==
Instalamos las dependencias (cmake ya lo tenemos instalado)
-----
'''NOTA''': No es necesario instalar los paquetes de python que nos especifican en las instrucciones de instalación del ''esp-idf'', se instalarán automáticamente en el siguiente paso.
-----
sudo apt-get install gperf cmake ninja-build ccache libffi-dev libssl-devAhora creamos un directorio para nuestro ''tool-chain'':
mkdir ~/esp cd ~/esp git clone --recursive https://github.com/espressif/esp-idfTambién es necesario que nuestro usuario pertenezca al grupo
dialout
, pero eso ya deberíamos tenerlo hecho de antes.
Una vez clonado el repo ejecutamos el script de instalación
cd ~/esp/esp-idf ./install.shEste script nos va a dejar instaladas todas las herramientas necesarias en el directorio
~/.expressif
'''Nota''': para que funcione correctamente en Linux Mint es necesario que el script tools/idf_tools.py
apunte al python3 de nuestro sistema. Basta con editar la primera linea ''shebang'' del script.
Estas son las bibliotecas que deja instaladas:
Installing ESP-IDF tools Installing tools: xtensa-esp32-elf, xtensa-esp32s2-elf, esp32ulp-elf, esp32s2ulp-elf, openocd-esp32Para empezar a trabajar bastará con hacer un ''source'' del fichero
~/apps/esp/esp-idf/export.sh
:
. ~/apps/esp/esp-idf/export.sh== KiCAD == En la [http://kicad-pcb.org/download/linux-mint/ página web del proyecto] nos recomiendan el ppa a usar para instalar la última versión estable:
sudo add-apt-repository --yes ppa:kicad/kicad-5.1-releases sudo apt-get update sudo apt install kicadPaciencia, el paquete
kicad-packages3d
tarda un buen rato en descargarse.
Algunas librerías alternativas:
* [https://github.com/freetronics/freetronics_kicad_library Freetronics] una libreria que no solo incluye Shield para Arduino sino una completa colección de componentes que nos permitirá hacer proyectos completos. [http://www.freetronics.com Freetronics] es una especie de BricoGeek australiano, publica tutoriales, vende componentes, y al parecer mantiene una biblioteca para KiCAD. La biblioteca de Freetronics se mantiene en un repo de github. Lo suyo es incorporarla a cada proyecto, por que si la actualizas se pueden romper los proyectos que estes haciendo.
* [http://meta-blog.eklablog.com/kicad-librairie-arduino-pretty-p930786 eklablog] Esta biblioteca de componentes está incluida en el github de KiCAD, así que teoricamente no habría que instalarla en nuestro disco duro.
=== Actualizar a KiCAD 6.0 ===
Hacemos un sudo apt purge
de todos los paquetes del antiguo KiCAD. Desactivamos el antiguo repo y ejecutamos:
demos
de momento en el nuevo KiCAD 6.0
== Wireviz ==
Una herramienta para documentar cableados de proyectos. Es una aplicación ''Python'' que usa ''Graphviz'', lo he instalado con pipx
.
sudo aptitude install sigrokAl instalar '''Sigrok''' instalamos también '''Pulseview'''. Si al conectar el analizador, echamos un ojo al fichero ''syslog'' vemos que al conectarlo se mapea en un puerto tty. Si arrancamos '''Pulseview''' (nuestro usuario tiene que estar incluido en el grupo ''dialout''), en la opción ''File::Connect to device'', escogemos la opción ''Openbench'' y le pasamos el puerto. Al pulsar la opción ''Scan for devices'' reconoce el analizador correctamente como un ''Sump Logic Analyzer''. === Sump logic analyzer === Este es el software recomendado para usar con el analizador. Descargamos el paquete de la [https://www.sump.org página del proyecto], o más concretamente de [https://www.sump.org/projects/analyzer/ esta página] y descomprimimos en ''~/apps''. Instalamos las dependencias:
sudo apt install librxtx-javaEditamos el fichero ''~/apps/Logic Analyzer/client/run.sh'' y lo dejamos así:
#!/bin/bash # java -jar analyzer.jar $* java -cp /usr/share/java/RXTXcomm.jar:analyzer.jar org.sump.analyzer.LoaderY ya funciona. === OLS === ----- '''Nota''': Pendiente de instalar ----- [https://www.lxtreme.nl/ols/ Página oficial] == IceStudio == Instalamos dependencias con
sudo apt install xclip
Bajamos el ''AppImage'' desde el [https://github.com/FPGAwars/icestudio github de IceStudio] y lo dejamos en ~/apps/icestudio
== PlatformIO ==
=== VS Code ===
Añadimos el origen de software:
curl https://packages.microsoft.com/keys/microsoft.asc | gpg --dearmor > packages.microsoft.gpg sudo install -o root -g root -m 644 packages.microsoft.gpg /usr/share/keyrings/ sudo sh -c 'echo "deb [arch=amd64 signed-by=/usr/share/keyrings/packages.microsoft.gpg] https://packages.microsoft.com/repos/vscode stable main" > /etc/apt/sources.list.d/vscode.list'E instalamos
sudo apt update sudo apt install code # alternativamente code-insiders (es como la versión beta, se pueden instalar los dos)Ahora # lanzamos el editor # abrimos el gestor de extensiones # buscamos el platformio ide # instalamos Seguimos las instrucciones de [https://docs.platformio.org/en/latest/ide/vscode.html#quick-start aqui] === Incluir platform.io CLI en el PATH === Esto es una malísima idea, '''NO LO HAGAS''' Las instrucciones indican que hagamos lo siguiente para usar Platformio desde linea de comandos pero no es conveniente hacerlo. Modificamos el fichero
~/.profile
añadiendo las siguientes lineas:
if [ -d "$HOME/.platformio/penv/bin"] ; then PATH="$PATH:$HOME/.platformio/penv/bin" fiSi quieres usar Platformio desde linea de comandos, es mejor activar manualmente el entorno virtual con
source ~/.platformio/penv/bin/activate
=== vscodium ===
wget -qO - https://gitlab.com/paulcarroty/vscodium-deb-rpm-repo/raw/master/pub.gpg | gpg --dearmor | sudo dd of=/etc/apt/trusted.gpg.d/vscodium.gpg echo 'deb https://paulcarroty.gitlab.io/vscodium-deb-rpm-repo/debs/ vscodium main' | sudo tee --append /etc/apt/sources.list.d/vscodium.list sudo apt update && sudo apt install codium=== Editor Atom === ----- ''NOTA'': Parece que antes recomendaban instalar Atom para disponer del Platformio CLI, ahora en cambio recomiendan VS Code. -----
wget -qO - https://packagecloud.io/AtomEditor/atom/gpgkey | sudo apt-key add - sudo sh -c 'echo "deb [arch=amd64] https://packagecloud.io/AtomEditor/atom/any/ any main" > /etc/apt/sources.list.d/atom.list' sudo apt update sudo apt install atom== RepRap == === OpenScad === El OpenSCAD está disponible en los orígenes de software, así que
sudo apt install openscad
.
=== Slic3r ===
Descargamos la estable desde la [https://dl.slic3r.org página web] y como de costumbre descomprimimos en ~/apps
y creamos un lanzador con ''MenuLibre''
=== Slic3r Prusa Edition ===
Una nueva versión del clásico ''Slic3r'' con muchas mejoras. Descargamos la ''appimage'' desde la [https://www.prusa3d.com/slic3r-prusa-edition/ página web] y ya sabeis, descomprimir en ~/apps
y dar permisos de ejecución.
=== ideaMaker ===
Una aplicación más para generar gcode con muy buena pinta, tenemos el paquete ''deb'' disponible en su [https://www.raise3d.com/pages/ideamaker página web]. Instalamos con el gestor de software.
=== Ultimaker Cura ===
Descargamos el ''AppImage'' desde la [https://github.com/Ultimaker/Cura/releases página web]
=== Pronterface ===
Seguimos las instrucciones para Ubuntu Focal:
Instalamos las dependencias: sudo apt install libsdl2-dev
Clonamos el repo:
cd ~/apps git clone https://github.com/kliment/Printrun.git cd Printrun mkvirtualenv -p /usr/bin/python3 printrun python -m pip install https://extras.wxpython.org/wxPython4/extras/linux/gtk3/ubuntu-20.04/wxPython-4.1.0-cp38-cp38-linux_x86_64.whl pip install -r requirements.txt # sudo apt-get install libdbus-glib-1-dev libdbus-1-devY ya lo tenemos todo listo para ejecutar. == Cortadora de vinilos == === Inkcut === Instalado en un entorno virtual:
mkvirtualenv -p `which python3` inkcut sudo apt install libxml2-dev libxslt-dev libcups2-dev pip install PyQt5 pip install inkcut=== Plugin para inkscape === Instalamos dependencias:
pip install python-usbInstalamos el fichero
.deb
desde la web https://github.com/fablabnbg/inkscape-silhouette/releases
== Drone ==
=== qgroundcontrol ===
Descargamos [https://s3-us-west-2.amazonaws.com/qgroundcontrol/latest/QGroundControl.AppImage el appimage]
=== missionplanner ===
Para usar ''Mission Planner'' en Linux Mint se recomienda instalar los paquetes:
sudo apt install mono-complete festivalDescargamos el MissionPlanner desde [https://firmware.ardupilot.org/Tools/MissionPlanner/MissionPlanner-latest.zip aquí] [https://www.rcgroups.com/forums/showthread.php?2179591-Installing-MissionPlanner-1-3-X-on-Ubuntu-17-04 Descripción de la instalación] Una vez descomprimido el
zip
ejecutamos: mono MissionPlanner.exe
== node-red ==
Para instalar node-red en linux necesitamos instalar primero node.js
. Hay varias formas de instalar node.js
, yo voy a optar por instalar nvm
que es el '''n'''ode '''v'''ersion '''m'''anager.
Para ello ejecutamos el siguiente comando (la versión actual de nvm
es la 0.37.0)
~/.bashrc
, nosotros las movemos al fichero ~/.profile
command -v nvm
que nos devolverá nvm
. which
no funciona en este caso por que es un script para aplicarle source
=== Instalación de node.js
===
Ahora que tenemos nvm
instalado, ya podemos instalar fácilmente la versión o versiones que queramos de node.js
mosquitto
===
mosquitto
es un ''mqtt broker'' muy sencillo y completo, aunque no es capaz de aguantar cargas grandes, para aprender es perfecto.
scs mosquitto
o systemctl status mosquitto
)
Si queremos el servicio parado para arrancarlo nosotros manualmente:
scst mosquitto.service
o sudo systemctl start mosquitto.service
=== Instalación de Influxdb ===
Seguimos el método para ubuntu:
node-red
===
Una vez instalado el node.js
instalar el node-red
es muy fácil
sudo apt install librecad== FreeCAD == No hay ppa disponible para Ubuntu 20. Instalamos ''AppImage'' desde [https://wiki.freecadweb.org/AppImage#FreeCAD_AppImages aquí] Dejo la instalación desde ppa como recordatorio.
sudo add-apt-repository ppa:freecad-maintainers/freecad-stable sudo apt update sudo install freecad----- '''NOTA:''' the ccx package brings CalculiX support to the FEM workbench, and needs to be installed separately. ----- == Inkscape == El programa libre para creación y edición de gráficos vectoriales.
sudo add-apt-repository ppa:inkscape.dev/stable sudo apt update sudo apt install inkscape== Gimp == El programa para edición y retocado de imágenes. Parece que ahora mismo los repos están más actualizados que el ppa. Así que bastaría con:
sudo apt install gimp gimp-data gimp-texturize \ gimp-data-extras gimp-gap gmic gimp-gmicDe todas formas dejo aquí las instrucciones para instalar desde el ppa por si hacen falta algún dia:
sudo apt remove gimp gimp-data sudo add-apt-repository ppa:otto-kesselgulasch/gimp sudo apt update sudo apt upgrade sudo apt install gimp gimp-data gimp-texturize \ gimp-data-extras gimp-gap gmic gimp-gmic gimp-python=== Plugins de Gimp === Para instalar los principales plugins basta con:
sudo apt install gimp-plugin-registry== Krita == La versión disponible en orígenes de software está bastante por detrás de la disponible en la web. Basta con descargar el ''Appimage'' desde la [https://krita.org página web] Lo copiamos a
~/apps/krita
y creamos un lanzador con el editor de menús.
Alternativamente también lo tenemos disponible por ppa en https://launchpad.net/~kritalime/+archive/ubuntu/ppa
== MyPaint ==
Desde el [https://github.com/mypaint/ github] tenemos disponible la última versión en formato ''appimage''. La descargamos la dejamos en ~/apps
y creamos un acceso con ''Menulibre'', como siempre.
== Alchemy ==
Igual que el ''MyPaint'' descargamos desde [http://al.chemy.org la página web], descomprimimos en ~/apps
y creamos un accso con ''Menulibre''.
== Capturas de pantalla ==
El [https://flameshot.js.org/#/ ''flameshot''] cubre el 99% de mis necesidades: sudo apt install flameshot
El [https://github.com/DamirPorobic/ksnip ''ksnip''] por si tenemos que hacer una captura con retardo lo instalé con un ''appimage''.
Shutter vuelve a estar disponible, al instalar desde este ppa ya queda con las opciones de edición habilitadas:
sudo add-apt-repository ppa:linuxuprising/shutter sudo apt update sudo apt install shutter== Reoptimizar imágenes == === ImageMagick === Instalamos desde los repos, simplemente:
sudo apt install imagemagick=== Imagine === Nos bajamos un ''AppImage'' desde el [https://github.com/meowtec/Imagine/releases github] de la aplicación == dia == Un programa para crear diagramas
sudo apt install dia dia-shapes gsfonts-x11== Blender == Bajamos el Blender linkado estáticamente de [https://www.blender.org la página web] y lo descomprimimos en
~/apps/blender
.
El paquete incluye un fichero blender.desktop
que podemos editar y copiar en ~/.local/share/applications
.
== Structure Synth ==
Instalado desde repos, junto con sunflow para explorar un poco.
sudo apt install structure-synth sunflow== Heron animation == El proyecto parece abandonado. El software ya no funciona en el último linux. == Stopmotion == Primero probamos el del repo:
sudo apt install stopmotion
== Instalación del driver digiment para tabletas gráficas Huion ==
He intentado un par de veces instalar con el fichero deb
pero parece que no funciona.
Para hacer la instalación via DKMS el truco está en:
* Dejar el código fuente en un directorio de la forma /usr/src/<PROJECTNAME>-<VERSION>
* Lanzar el build
pero usando esta vez <PROJECTNAME>/<VERSION>
Descargamos los últimos drivers desde [https://github.com/DIGImend/digimend-kernel-drivers/releases la página oficial de releases], en el momento de escribir esto descargamos la versión V9.
Descomprimimos en /usr/src/digimend-9
cd /usr/src sudo xvzf <path-to-digimend-kernel-drivers-9> . sudo dkms build digimend-kernel-drivers/9 sudo dkms install digimend/9Para comprobar:
xinput --list dkms statusReferencia: * [https://davidrevoy.com/article331/setup-huion-giano-wh1409-tablet-on-linux-mint-18-1-ubuntu-16-04 Aquí] = Sonido = == Spotify == Spotify instalado desde las opciones de Linux Mint via flatpak. == Audacity == El ppa de Audacity no permite instalar la última versión. Podemos instalarla via flatpak o simplemente instalar la de los repos (no es la última) Es de esperar que al final la añadan al ppa asi que dejamos aquí las instrucciones. Añadimos ppa:
sudo add-apt-repository ppa:ubuntuhandbook1/audacity sudo apt-get update sudo apt install audacityInstalamos también el plugin [https://theaudacitytopodcast.com/chriss-dynamic-compressor-plugin-for-audacity/ Chris’s Dynamic Compressor plugin] == Clementine == La version disponible en los orígenes de software parece al dia:
sudo apt install clementine= Video = == Shotcut == Nos bajamos la ''AppImage'' para Linux desde la [https://www.shotcut.org/ página web]. La dejamos en
~/apps/shotcut
y:
cd chmod 744 Shotcutxxxxxx.AppImage ./Shotcutxxxxxx.AppImage== kdenlive == Está disponible [https://kdenlive.org en la web] como ppa o como ''appimage''. Lo he bajado como ''appimage'' para probarlo. == Openshot == También descargado desde [https://www.openshot.org su web] como ''appimage'', para probar. Tienen un ppa disponible. == Avidemux == Descargado ''appimage'' desde [http://avidemux.sourceforge.net/ la web] == Handbrake == Instalado como flatpak desde [https://handbrake.fr/ su web]. == Grabación de screencast == === Vokoscreen, Kazam y SimpleScreenRecorder === Instalados desde los repos oficiales:
sudo apt update sudo apt install vokoscreen vokoscreen-ng kazam simplescreenrecorderEscoge el que más te guste. === OBS === Añadimos el repositorio
sudo add-apt-repository ppa:obsproject/obs-studio sudo apt update sudo apt install obs-studio== Grabación de podcast == === Mumble === Podemos instalarlo desde flatpak o bajarnos [https://launchpad.net/~mumble/+archive/ubuntu/release/+packages el paquete antiguo] (parece que funciona bien). Mumble no está disponible desde el PPA, aunque dejo aquí las instrucciones por si lo corrigen.
sudo add-apt-repository ppa:mumble/release sudo apt update sudo apt install mumble== Clientes de youtube == === smtube === Instalado el ppa siguiendo instrucciones de [http://www.smtube.org/ su página web].
.deb
desde [https://freetubeapp.io/#download su página web].
= Fotografía =
== Rawtherapee ==
Bajamos el AppImage desde la [http://rawtherapee.com/ página web] al directorio ~/apps/rawtherapee
.
cd chmod 744 RawTherapeexxxxxx.AppImage ./RawTherapeexxxxxx.AppImageAl ejecutarla la primera vez ya se encarga la propia aplicación de integrarse en nuestro sistema. == Darktable == Instalamos ppa (ver [https://software.opensuse.org/download/package?package=darktable&project=graphics%3Adarktable esta web])
echo 'deb http://download.opensuse.org/repositories/graphics:/darktable/xUbuntu_20.04/ /' | sudo tee /etc/apt/sources.list.d/graphics:darktable.list curl -fsSL https://download.opensuse.org/repositories/graphics:darktable/xUbuntu_20.04/Release.key | gpg --dearmor | sudo tee /etc/apt/trusted.gpg.d/graphics:darktable.gpg > /dev/null sudo apt update sudo apt install darktableSe instala la última versión de Darktable (3.0.2) '''OJO''': Conviene renombrar el fichero de claves de darktable, a nuestro linux no le gustan los ficheros con un ‘:’ Revisa
/etc/apt/trusted.gpg.d/
== Digikam ==
Instalado desde la [https://www.digikam.org/ página web] de la aplicación con appimage.
== Webcamoid ==
Descargada la appimage desde la [https://webcamoid.github.io/ página web]
= Seguridad =
== Autenticación en servidores por clave pública ==
Generar contraseñas para conexión servidores remotos:
cd ~ ssh-keygen -b 4096 [-t dsa | ecdsa | ed25519 | rsa | rsa1] cat .ssh/Solo resta añadir nuestra clave pública en el fichero
authorized_keys
del servidor remoto.
cat ~/.ssh/id_xxx.pub | ssh user@hostname 'cat >> .ssh/authorized_keys'[https://www.digitalocean.com/community/tutorials/understanding-the-ssh-encryption-and-connection-process ¿Cómo funciona esto?] == Claves gpg ==
gpg --gen-key
Para generar nuestra clave.
* '''Siempre''' hay que ponerle una fecha de expiración, la puedes cambiar más tarde.
* '''Siempre''' hay que escoger la máxima longitud posible
== Seahorse ==
Para manejar todas nuestras claves con comodidad:
sudo apt install seahorse
== Conexión a github con claves ssh ==
Usando este método podemos conectarnos a github sin tener que teclear la contraseña en cada conexión.
=== Claves ssh ===
Podemos echar un ojo a nuestras claves desde seahorse
la aplicación de gestión de claves que hemos instalado. También podemos ver las claves que tenemos generadas:
ls -al ~/.sshEn las claves listadas nuestras claves públicas aparecerán con extensión
.pub
También podemos comprobar que claves hemos añadido ya a nuestro agente ssh con:
ssh-add -lPara generar una nueva pareja de claves ssh:
ssh-keygen -t rsa -b 4096 -C "your_email@example.com"Podremos dar un nombre distintivo a los ficheros de claves generados y poner una contraseña adecuada a la clave. Si algún dia queremos cambiar la contraseña:
ssh-keygen -pAhora tenemos que añadir nuestra clave ssh en nuestra cuenta de github, para ello editamos con nuestro editor de texto favorito el fichero
~/.ssh/id_rsa.pub
y copiamos el contenido integro. Después pegamos ese contenido en el cuadro de texto de la web de github.
Para comprobar que las claves instaladas en github funcionan correctamente:
ssh -T git@github.com Hi salvari! You've successfully authenticated, but GitHub does not provide shell access.Este mensaje indica que todo ha ido bien. Ahora en los repos donde queramos usar ssh debemos cambiar el remote:
git remote set-url origin git@github.com:$USER/$REPONAME.git== Signal == El procedimiento recomendado en la página oficial:
.deb
desde [https://www.dnielectronico.es/PortalDNIe/PRF1_Cons02.action?pag=REF_1112 la página de descargas del portal DNIe].
Automáticamente nos instalará las dependecias: libccid
, pcsd
y pinentry-gtk2
. A mayores instalamos:
root@rasalhague:~# pcsc_scan PC/SC device scanner V 1.4.23 (c) 2001-2011, Ludovic Rousseau <ludovic.rousseau@free.fr> Compiled with PC/SC lite version: 1.8.11 Using reader plug'n play mechanism Scanning present readers... Waiting for the first reader...Si insertamos el lector veremos algo como esto:
root@rasalhague:~# pcsc_scan PC/SC device scanner V 1.4.23 (c) 2001-2011, Ludovic Rousseau <ludovic.rousseau@free.fr> Compiled with PC/SC lite version: 1.8.11 Using reader plug'n play mechanism Scanning present readers... Waiting for the first reader...found one Scanning present readers... 0: C3PO LTC31 v2 (11061005) 00 00 Wed Jan 25 01:17:20 2017 Reader 0: C3PO LTC31 v2 (11061005) 00 00 Card state: Card removed,Si insertamos un DNI veremos que se lee la información de la tarjeta insertada:
Reader 0: C3PO LTC31 v2 (11061005) 00 00 Card state: Card inserted,y mas rollo Para abrir los certificados en el navegador Firefox, nos lo explica [https://www.agenciatributaria.es/AEAT.internet/Inicio/Ayuda/_comp_Consultas_informaticas/Categorias/Firma_digital__certificado_o_DNIe__y_sistema_Cl_ve_PIN/DNI_electronico__DNIe_/Comprobaciones_tecnicas_para_el_funcionamiento_del_DNIe/Comprobaciones_tecnicas_del_DNIe_con_Mozilla_Firefox_y_Linux/Comprobaciones_tecnicas_del_DNIe_con_Mozilla_Firefox_y_Linux.shtml esta página de la AEAT] Como se puede ver el link de la AEAT, los pasos necesarios para Firefox son: # Vamos a preferencias y buscamos ‘cert’ # En el diálogo de certificados abrimos los
Dispositivos de Seguridad
(''Security Devices'')
# Para dar de alta un nuevo dispositivo pulsamos el botón Cargar
(''Load'')
# Damos un nombre (p.ej. DNIe
) y asociamos el driver: /usr/lib/libpkcs11-dnie.so
# Adicionalmente podemos Cargar
(crear), otro dispositivo con el driver opensc
, no es necesario para el DNIe pero nos añade soporte para otras tarjetas. (Nombre: OtrasTarjetas, Driver: `/usr/lib/x86_64-linux-gnu/pkcs11/opensc-pkcs11.so)
-----
'''NOTA''':
Para cada tarjeta puede hacer falta un driver diferente, tendrás que investigar con ayuda del pcsc_scan
y herramientas similares.
-----
= Virtualizaciones y contenedores =
== Instalación de ''virtualBox'' ==
'''AVISO IMPORTANTE'''
Tenemos dos formas de instalar ''Virtualbox'', desde los repos oficiales de la aplicación o desde los propios de Linux Mint (Ubuntu Focal Fossa)
Si descargamos los oficiales de ''Virtualbox'' se instalará el paquete python-is-python2
, eso hara que el python por defecto de nuestro sistema sea el dos. A cambio tendremos la última versión de ''Virtualbox''
Si lo instalamos con los repos de Ubuntu, podemos tener instalado el paquete python-is-python3
(esta es mi opción favorita)
=== Instalación desde Ubuntu ===
# Importamos la clave gpg wget -q https://www.virtualbox.org/download/oracle_vbox_2016.asc -O- | sudo apt-key add - # Añadimos el nuevo origen de software sudo add-apt-repository "deb [arch=amd64] https://download.virtualbox.org/virtualbox/debian $(. /etc/os-release; echo "$UBUNTU_CODENAME") contrib" # Actualizamos la base de datos de paquetes sudo apt updateAhora podemos comprobar que además del paquete ''virtualbox'' tenemos varios paquetes con número de versión (p.ej. _virtualbox.6.1), estos últimos son los que hemos añadido (compruebalo con
apt-cache policy [nombrepaquete]
)
Instalamos el que nos interesa:
sudo apt install virtualbox-6.1'''ATENCIÓN'''
The following additional packages will be installed: python-is-python2Descargamos también el [https://www.virtualbox.org/wiki/Downloads VirtualBox Extension Pack], este paquete lo podemos instalar desde el propio interfaz de usuario del ''VirtualBox'', o bien con el siguiente comando:
sudo VBoxManage extpack install ./Oracle_VM_VirtualBox_Extension_Pack-6.1.2.vbox-extpackSólo nos queda añadir nuestro usuario al grupo
vboxusers
, con el comando sudo gpasswd -a username vboxusers
, y tendremos que cerrar la sesión para refrescar nuestros grupos.
== qemu ==
Un par de comprobaciones previas:
* El comando egrep -c '(vmx|svm)' /proc/cpuinfo
debe devolvernos un número mayor que cero si nuestro sistema soporta virtualización.
* El comando kvm-ok
nos sirve para comprobar que la virtualización hardware no está deshabilitada en la BIOS (puede que tengas que ejecutar apt install cpu-checker
)
Instalamos desde el repo oficial:
sudo apt install qemu-kvm libvirt-daemon-system libvirt-clients bridge-utils virtinst virt-manager sudo apt install virt-viewer; qemu-kvm : nos da la emulación hardware para el hipervisor KVM ; libvirt-daemon-system : los ficheros de configuración para ejecutar el demonio
libvirt
como servicio
; libvirt-clients
: software para gestionar plataformas de virtualización
; bridge-utils
: utilidades de linea de comandos para configurar bridges ethernet
; virtinst
: utilidades de linea de comandos para crear máquinas virtuales
; virt-manager
: un interfaz gráfico junto con utilidades de linea de comandos para gestionar máquinas virtuales a través de ''libvirt''
Solo queda añadir nuestro usuario a los grupos:
sudo gpasswd -a username libvirt sudo gpasswd -a username kvmPodemos comprobar el estado del servicio con
scs libvirtd
(systemctl status libvirtd
).
=== Referencias ===
* [https://www.how2shout.com/how-to/how-to-install-kvm-on-ubuntu-20-04-graphical-headless-server.html How to install KVM on Ubuntu 20.04 Graphical & headless server]
* [https://linuxize.com/post/how-to-install-kvm-on-ubuntu-20-04/ How to Install Kvm on Ubuntu 20.04]
* [https://www.tecmint.com/install-kvm-on-ubuntu/ How to Install KVM on Ubuntu 20.04]
== Docker ==
Tenemos que añadir el repositorio correspondiente a nuestra distribución:
# Be safe sudo apt remove docker docker-engine docker.io sudo apt autoremove sudo apt update # Install pre-requisites sudo apt install ca-certificates curl # Import the GPG key curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add - # Next, point the package manager to the official Docker repository sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(. /etc/os-release; echo "$UBUNTU_CODENAME") stable" # Update the package database sudo apt update # apt-cache policy docker-ce sudo apt install docker-ce sudo gpasswd -a username dockerEsto dejará el servicio ''docker'' funcionando y habilitado (arrancará en cada reinicio del ordenador) La forma de pararlo es:
sudo systemctl stop docker sudo systemctl disable docker systemctl status dockerAñadimos el ''bundle'' '''docker''' en nuestro fichero
~/.zshrc
para tener autocompletado en comandos de docker.
Para usar ''docker'' tendremos que arrancarlo, con los alias de nuestro sistema para ''systemd'' ejecutamos:
scst docker # para arrancar el servicio scsp docker # para parar el servicio=== docker-compose === * Nos bajamos la última versión disponible de [https://github.com/docker/compose/releases las releases de github] * Movemos el fichero que hemos descargado a
/usr/local/bin/docker-compose
* Y le damos permisos de ejecución sudo chmod +x /usr/local/bin/docker-compose
=== Kitematic ===
Un interfaz gráfico para ''Docker''. En su [https://github.com/docker/kitematic/releases página de releases] bajamos la última para Ubuntu e instalamos con el gestor de paquetes.
La verdad es que me gusta más el CLI.
= Utilidades para mapas y cartografía =
== josm ==
Descargamos y añadimos la clave gpg:
wget -q https://josm.openstreetmap.de/josm-apt.key -O- | sudo apt-key add -Añadimos el origen de software:
sudo add-apt-repository "deb [arch=amd64] https://josm.openstreetmap.de/apt $(. /etc/os-release; echo "$UBUNTU_CODENAME") universe"Y ahora procedemos a la instalación:
sudo apt update sudo apt install openjfx josmAlternativamente también podemos instalar la versión “nightly” con el siguiente comando, pero tendréis actualizaciones diarias:
sudo apt josm-latestYa estamos listos para editar Open Street Map offline. == MOBAC == Bajamos el paquete desde [http://mobac.sourceforge.net/ la página web] y descomprimimos en
~/apps/mobac
como de costumbre nos creamos una entrada de menú con ''MenuLibre''.
Conviene bajarse wms adicionales para MOBAC y leerse [http://mobac.sourceforge.net/wiki/index.php/Custom_XML_Map_Sources la wiki]
=== Referencias ===
*[Cartografía digital] (https://digimapas.blogspot.com.es/2015/01/oruxmaps-vii-mapas-de-mobac.html)
== QGIS ==
Añadimos la clave gpg:
wget -q https://qgis.org/downloads/qgis-2019.gpg.key -O- | sudo apt-key add -Ejecutamos:
sudo add-apt-repository "deb [arch=amd64] https://qgis.org/debian $(. /etc/os-release; echo "$UBUNTU_CODENAME") main"E instalamos como siempre
sudo apt update sudo apt install qgis=== Referencias === * [https://mappinggis.com/2015/09/como-conectar-con-servicios-wms-y-wfs-con-arcgis-qgis-y-gvsig/ Conectar WMS con QGIS] * [https://www.altergeosistemas.com/blog/2014/03/28/importando-datos-de-osm-en-qgis-2/ Importar OSM en QGIS] * [http://learnosm.org/es/osm-data/osm-in-qgis/ Learn OSM] * [http://www.qgistutorials.com/es/docs/downloading_osm_data.html QGIS Tutorials] = Recetas variadas = == Añadir las claves GPG de un repo ==
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys F7E06F06199EF2F2== Solucionar problemas de menús duplicados usando menulibre == {| | '''Nota''': Ya no uso ''MenuLibre'' |} En el directorio
~/.config/menus/applications-merged
borramos todos los ficheros que haya.
== Mapear un servidor webdav en nuestro sistema de ficheros ==
/etc/fstab
la linea del servidor webdav:
~/.davfs2/secrets
que sería una linea con <mount point> <webdav-user> <webdav-passwd>
Con eso ya podremos montar el webdav con nuestro usuario sin mas que ejecutar mount <mount point>
== Formatear memoria usb ==
“The driver descriptor says the physical block size is 2048 bytes, but Linux says it is 512 bytes.”
Este comando borró todas las particiones de la memoria:
sudo dd if=/dev/zero of=/dev/sdd bs=2048 count=32 && sync
I’m assuming your using gparted.
First delete whatever partitions you can…just keep pressing ignore.
There will be one with a black outline…you will have to unmount it…just right click on it and unmount.
Again you will have to click your way through ignore..if fix is an option choose it also.
Once all this is done… you can select the device menu and choose new partition table.
Select MSdos
Apply and choose ignore again.
Once it’s done it show it’s real size.
Next you can format the drive to whichever file system you like.
It’s a pain in the behind this way, but it’s the only way I get it done..I put live iso’s on sticks all the time and have to remove them. I get stuck going through this process every time.
== Copiar la clave pública ssh en un servidor remoto ==
cat /home/tim/.ssh/id_rsa.pub | ssh tim@just.some.other.server 'cat >> .ssh/authorized_keys'
O también:
ssh-copy-id -i ~/.ssh/id_rsa.pub username@remote.server
== ssh access from termux ==
https://linuxconfig.org/ssh-into-linux-your-computer-from-android-with-termux
== SDR instalaciones varias ==
Vamos a trastear con un dispositivo [https://www.rtl-sdr.com/ RTL-SDR.com].
Tenemos un montón de información en el blog de [https://sdrgal.wordpress.com/ SDR Galicia] y tienen incluso una guia de instalación muy completa, pero yo voy a seguir una guía un poco menos ambiciosa, por lo menos hasta que pueda hacer el curso que imparten ellos mismos (SDR Galicia)
La guía en cuestión la podemos encontrar [https://ranous.wordpress.com/rtl-sdr4linux/ aquí]
Seguimos los pasos de instalación:
* La instalación de git
, cmake
y build-essential
ya la tengo hecha.
sudo apt-get install libusb-1.0-0-dev== Posible problema con modemmanager y micros programables == Programando el ''Circuit Playground Express'' con el ''Arduino IDE'' tenía problemas continuos para hacer los ''uploads'', al parecer el servicio ''ModemManager'' es el culpable, se pasa todo el tiempo capturando los nuevos puertos serie por que considera que todo es un modem. Una prueba rápida para comprobarlo:
sudo systemctl stop ModemManager
Con esto funciona todo bien, pero en el siguiente arranque volvera a cargarse.
Para dar una solución definitiva se puede programar una regla para impedir que el ''ModemManager'' capture el puerto con un dispositivo
Creamos un fichero con permisos de root
en el directorio /etc/udev/rules.d
que llamaremos: 99-arduino.rules
Dentro de ese fichero especificamos los codigos VID/PID que se deben ignorar:
# for arduino brand, stop ModemManager grabbing port ATTRS{idVendor}=="2a03", ENV{ID_MM_DEVICE_IGNORE}="1" # for sparkfun brand, stop ModemManager grabbing port ATTRS{idVendor}=="1b4f", ENV{ID_MM_DEVICE_IGNORE}="1"Ojo que si tienes SystemV no va a funcionar. https://starter-kit.nettigo.eu/2015/serial-port-busy-for-avrdude-on-ubuntu-with-arduino-leonardo-eth/ https://www.codeproject.com/Tips/349002/Select-a-USB-Serial-Device-via-its-VID-PID == Programar los nanos con chip ch340 o ch341 == Linux mapea el chip correctamente en un puerto
/dev/ttyUSB0
y con eso basta, que no te lien con el cuento de “drivers para linux”
Todo lo que hace falta es configurar correctamente el ''Arduino IDE'', hay que escoger:
Board: "Arduino Nano" Processor: "ATmega168" Port: "/dev/ttyUSB0"Y ya funciona todo. == Linux Mint 20 es ''python agnostic'' == En principio no podemos invocar a
python
por que no se ha escogido una versión por defecto.
Tenemos dos opciones:
apt install python-is-python2 apt install python-is-python3== Instalar chromium sin snapdrop == Este rodeo ya no es necesario en las versiones modernas de Linux Mint ~~~~ sudo apt install keepassxc gnucash deluge rsync grsync rar unrar