Script para tener un entorno funcional en poco tiempo y además tener sincronizada la configuración de distintos dispositivos con los que trabajo.
Este script prepara completamente el entorno de programación, aplicaciones, servidores, comandos personalizados, interfaz gráfica, plantillas y repositorios en Debian Stable y Testing.
Todas las configuraciones y elecciones se han establecido a mi gusto, puedes personalizar cualquier parte que decidas para este script bajo la misma licencia GPLv3.
Si encuentras algún fallo o detectas que algo podría funcionar mejor, añade un Issue al que estaré encantado de atender y valorar.
También puedes colaborar con los PR que creas oportuno siempre que vaya en la línea del script y no sea necesario darle la vuelta a todo el proyecto.
En todo caso recomiendo usar la rama Master y si quieres colaborar crea un fork y haz PR sobre la rama dev para valorar si formará parte de la siguiente versión.
Si no usas repositorios oficiales, mezclas repositorios o tienes otro sistema distinto a Debian Stable estarás experimentando así que úsalo bajo tu riesgo.
Este script está automatizado y puede cambiar configuración sin que te pregunte.
Una buena idea sería que lo ejecutaras tras hacer una copia de seguridad o en una máquina virtual hasta ver que el script completo se adapta a tus necesidades o modificar la parte que prefieras diferente realizando un fork de este repositorio.
Trabajo en la modularidad para que puedas ejecutar solo una parte que te interese y no dependas del script al completo.
Para evitar que sea interactivo y estar constantemente preguntando se establece "-y" como parámetro por defecto en apt lo cual puede instalar software en forma de dependencia y/o romper en casos muy extremos el sistema, aunque repito que con repositorios oficiales no debe ocurrir nada extraño y si es así puedes reportarlo para su corrección.
Crear un entorno de trabajo personalizado para desarrollar aplicaciones web según las preferencias del autor (https://github.com/raupulus).
Se plantea lo más modular que me ha sido posible para que en algunos casos no sea necesario ejecutar el script completo y solo la parte que realmente necesitas (si fuese el caso).
Previsualización de menú para aplicaciones:
Estos son los principales objetivos:
- Configurar terminales, bash y zsh
- Instalar tipografías
- Instalar editores Intellij, ninja IDE y Vim con sus personalizaciones
- Instalar IDEs si el usuario lo elige
- Configurar sistema y variables globales
- Ampliar repositorios desde fuentes estables y fiables
- Instalar configuraciones y personalizaciones para el sistema y programas en el HOME
- Instalar atajos y personalizaciones para trabajar con git, GitHub y GitLab
- Instalar servidores Apache2, PostgreSQL, MariaDB
- Instalar lenguajes de programación, dependencias y librerías para → php, python, nodejs, ruby, bash, zsh
- Instalar Navegadores WEB para desarrolladores como Firefox Developer y Firefox Nightly
- Instalar herramientas para ayudar a debug en lenguajes web
- Configurar interfaces gráficas
Previsualización de menú Personalización:
Está pensado principalmente para Debian Stable y Debian Testing, así como para Raspberry Pi OS (Raspbian). El soporte para Fedora, Gentoo y macOS es parcial y experimental: no se garantiza que funcione sin ajustes.
En distribuciones no soportadas puede romper el sistema; para portarlo no hay demasiadas complicaciones, pero se deberá renombrar la instalación/nombre de paquetes si procede y establecer repositorios de acorde a la distribución. El resto de los pasos deberían ser idénticos.
Todo el script se basa en functions.sh por lo que editando este archivo y
adaptándolo a tu distribución podrás conseguir un cierto nivel de
compatibilidad.
Se ha intentado hacer modular de forma que apenas sea necesario tocar los scripts para añadir/quitar funciones.
La idea es que el script pregunte lo mínimo posible y que esto sean decisiones relevantes.
Es importante realizar todos los pasos desde bash. Si usas zsh cambia a bash antes de ejecutarlo:
bashPrimero instalamos GIT
sudo apt install gitClonamos el repositorio actual en nuestro equipo
git clone https://github.com/raupulus/debian-developer-conf.gitEntramos y ejecutamos el script principal
cd debian-developer-conf
./main.shAgrega elementos gráficos al sistema, los configura para el usuario y activa.
- Fondo de pantalla
- Grub
- GDM
- Iconos
- Cursores crystalblue
Además también se añadieron iconos "paper", temas "flatpat" y la instalación de cursores "crystal"
Se incorporan en la parte servidores instalación para apache2, postregsql, mariadb, NodeJS, bind9 y docker.
Se crean 3 servidores virtuales:
- Por defecto escuchando todo, con ruta /var/www/html
- Público como publico.local, con ruta /var/www/html/Publico
- Privado como privado.local, con ruta /var/www/html/Privado y contraseña creada/generada en /var/www/.htpasswd
Todos por el puerto estándar, 80
En este script para seguir rigurosamente la filosofía Debian apostando por la seguridad que nos acostumbra y sobre todo la estabilidad la cual es bastante conocida, optamos a seguir siempre con la versión más alta de sus repositorios estables y oficiales libres.
Se instalan los siguientes paquetes básicos desde repositorios:
- php
- php-cli
- libapache2-mod-php
Se instalan los siguientes paquetes extras desde repositorios:
- php-gd
- php-curl
- php-pgsql
- php-sqlite3
- sqlite
- sqlite3
- php-intl
- php-mbstring
- php-xml
- php-xdebug
- php-json
Se instala Composer y algunos paquetes con este:
- composer
Se instalan las siguientes herramientas de fuentes externas:
- psysh → Un intérprete interactivo para aprender o hacer debug, incluyendo su documentación accesible una vez dentro del mismo intérprete usando la palabra reservada doc seguido de la función que solicitamos ayuda/información.
Se modifican los archivos de configuración para Todas las versiones de PHP que se encuentren instaladas en el equipo. Estas modificaciones serán:
- timezone = 'UTC'
- error_reporting = E_ALL
- display_errors = On
- display_startup_errors = On
- max_execution_time = 180
- memory_limit = 128M
- upload_max_filesize = 512M
- post_max_size = 1024M
Se instala la última versión stable de PostgreSQL (en el futuro se configuran todas las versiones que pudieran estar instalada en el sistema), configura:
- intervalstyle = 'iso_8601
- timezone = 'UTC'
Instala el cliente y el servidor para MariaDB (versión libre de MySQL)
También instala phpmyadmin para poder manipular/trabajar con estas bases de datos de forma gráfica desde su interfaz web.
Una vez instalado plantea si quieres crear un usuario para desarrollar con el nombre "dev" y con la contraseña en un principio "dev" dándole todos los permisos de administración y manipulación a este usuario. No debe usarse así en producción y se aconseja una vez finalizado el script cambiar la contraseña de este usuario si habilitamos la posibilidad de conectar fuera de localhost (para evitar que en sitios públicos puedan acceder, esto aún así es poco probable además).
Contempla la instalación de Python2 y Python3 con sus gestores de paquetes pip y pip3.
Además se instalan una serie de librerías normalmente recurridas.
Instala NodeJS (tienen que estar los repositorios agregados) y además contempla la instalación de algunos paquetes como ámbito global para poder corregir sintaxis javascript en algunos IDE's y/o desde terminal.
También instala desde npm bower y los siguientes paquetes globales:
- eslint
- jscs
- compass
- stylelint
- bundled
Se plantea la instalación y configuración de los siguientes lenguajes:
- C
- C++
- go
- php
- python
- ruby
- nodejs
El proyecto está organizado en módulos, cada uno con su propio menú
(0_Main.sh). Los principales son:
- Apps/ → Instalación de aplicaciones de todo tipo (IDEs, ofimática,
navegación, ver subcarpeta
IDEs/). - Repositorios/ → Listas y scripts para añadir repositorios de terceros por distro y rama.
- configurations/ → Ajustes genéricos y variables del sistema (crons, archivo hosts).
- Personalizar/ → Mejoras visuales (temas GTK/QT, iconos, Grub, fuentes, cursores).
- servers/ → Software para servidores (Apache, Nginx, MariaDB, Docker, etc.).
- Lenguajes-Programacion/ → Entornos de programación (PHP, Python, Ruby, Go, etc.).
- Usuario/ → Configuración específica del entorno del usuario (dotfiles, tmux, vim, shell).
- Desktops/ → Entornos de escritorio y gestores de ventanas (i3, xmonad, openbox, sway).
- root/ → Configuración base para el usuario administrador.
- VPS/ → Configuraciones especializadas en servidores privados virtuales (fail2ban, firewall).
- raspberry/ → Scripts exclusivos de optimización para Raspberry Pi.
- Software-Lists/ → Listas planas de paquetes (
.lst) por distro, consumidas por los módulos anteriores. - Accesos_Directos/ → Accesos directos
.desktoppara el usuario (~/.local/share/applications). - fonts/ → Tipografías, un directorio por familia.
- conf/ → Archivos de configuración o plantillas para generarlos.
- docs/ → Documentación del proyecto e imágenes (ver
docs/info/para el detalle técnico de cada módulo). - Backups/ y tmp/ → Directorios de trabajo generados en tiempo de ejecución (backups y descargas temporales), no versionados.
Para el detalle técnico y de comportamiento de cada módulo, consulta
AGENTS.md y los documentos en docs/info/.
main.sh→ Programa principal con menú para elegir el paso a realizar. Debe ejecutarse desde la raíz del repositorio.main-vps.sh→ Punto de entrada alternativo para VPS, se ejecuta como root antes de clonar el repositorio completo (crea el usuario del sistema y luego continúa conmain.sh).functions.sh→ Contiene funciones globales y auxiliares para no repetir código.routes.sh/preferences.sh→ Rutas de Apache por distro y configuración interactiva inicial (distro/rama/entorno), persistida en/etc/environment.limpiador.sh→ Limpia directorios y archivos de personalización de forma agresiva; existe para depurar y su uso se desaconseja por ser altamente arriesgado para perder datos (no restaura backups pese a estar planteado).env.example→ Plantilla de variables de entorno; cópiala a.envpara fijarDISTRO,BRANCH,ENV, etc. antes de la primera ejecución.
Dentro de Apps/IDEs/ se instalan y configuran distintos editores/IDEs
(PhpStorm, WebStorm, PyCharm Pro, Android Studio, Arduino IDE, entre otros).
El estado y detalle de cada script puede variar entre versiones del proyecto;
consulta docs/info/apps.md para la lista actualizada.
Sección opcional que permite instalar y dejar configurado automáticamente el escritorio o window manager elegido (i3, Sway, Xmonad, Openbox, entre otros).
Puedes leer más sobre los escritorios en Desktops/README.md.
Instala y configura i3 Window Manager personalizando la barra de estado con i3pystatus y applets autoiniciados.
cd $HOME
git clone https://github.com/raupulus/debian-developer-confapt install git wget sudo
wget https://raw.githubusercontent.com/raupulus/debian-developer-conf/master/main-vps.sh -O /tmp/main-vps.sh
cd /tmp
chmod ugo+x main-vps.sh
./main-vps.sh





