> **📝 EXAMEN 12: Simulacro Táctico de Afianzamiento** # Bloque I: Preguntas tipo Test > *Elixe unha única resposta correcta. Razoa o teu descarte mentalmente.* ## 1. (Tema 6) Facendas Locais: O Orzamento Segundo o Real Decreto Lexislativo 2/2004 (TRLRHL), as entidades locais deben elaborar o seu orzamento baixo o principio de "Estabilidade Orzamentaria". ¿Que significa este concepto na práctica contable e financeira dun Concello? - a) Que o Concello pode gastar sempre máis do que ingresa se o destino é investimento social. - b) Que a situación de equilibrio ou superávit debe manterse ao longo do ciclo económico, sen superar o límite de déficit estructural permitido. - c) Que o orzamento debe ser o mesmo exactamente todos os anos sen variacións superiores ao 1%. - d) Que o Concello ten prohibido por lei solicitar calquera tipo de préstamo ou crédito bancario. ### Resposta Esta, só lendo as preguntas é sinxelo, e viría a ser a `b`. ### Corrección - **A túa resposta**: b) Que a situación de equilibrio ou superávit debe manterse ao longo do ciclo... - **Veredicto**: **✅ ¡Correcta!** - **O apuntamento do profe**: Clavadísimo. La estabilidad presupuestaria no prohíbe endeudarse (los ayuntamientos piden préstamos a menudo), pero sí exige que a lo largo del ciclo económico las cuentas estén cuadradas (déficit cero o superávit). ## 2. (Tema 14) SQL Server: Modelos de recuperación En Microsoft SQL Server, si configuramos una base de datos con el "Simple Recovery Model" (Modelo de recuperación simple), ¿qué impacto directo tiene esto en la gestión de los registros de transacciones (Transaction Logs)? - a) El registro de transacciones crece indefinidamente hasta que se realiza una copia de seguridad del log. - b) Se permite realizar copias de seguridad de registros de transacciones para recuperar la base de datos en un punto específico del tiempo (Point-in-time recovery). - c) El espacio del registro de transacciones se reutiliza automáticamente después de que los cambios se escriban en el disco, eliminando la posibilidad de recuperar transacciones individuales tras un fallo. - d) La base de datos entra en modo de solo lectura para evitar la fragmentación del log. ### Respuesta Voy a responder inicialmente a ciegas entendiendo que la correcta es la `b` pues entiendo que la recuperación simple se basa en los Logs pues sino estaríamos hablando de recuperación a partir de los BAK. Ahora bien, mirando en Internet, la respuesta correcta es la `c` pues reduce automáticamente el registro de transacciones y elimina la necesidad de realizar copias de seguridad de registros. ### Corrección - **A túa resposta**: c) El espacio del registro de transacciones se reutiliza automáticamente... (Corrixida a tempo). - **Veredicto**: **✅ ¡Correcta por investigación y razonamiento!** - **O apuntamento do profe**: Haces muy bien en buscar cuando dudas, así se graba el concepto. El modelo "Simple" es literalmente el modo de "no me compliques la vida": cuando una transacción termina, SQL borra el log para no ocupar espacio. ¿La contrapartida? Si la base de datos se rompe a las 11:59h, no puedes restaurarla a las 11:58h (*Point-in-time*), solo puedes cargar la copia de seguridad de la noche anterior. ## 3. (Tema 32) Sistemas Operativos: Xerarquía de directorios en Linux En un sistema operativo GNU/Linux que siga el estándar FHS (Filesystem Hierarchy Standard), ¿en qué directorio se almacenan habitualmente los archivos de configuración del sistema y de las aplicaciones? - a) /bin - b) /home - c) /var - d) /etc ### Respuesta Esta creo que es fácil y diría que la `d` pues en `bin` estarían los binarios de ejecución; en `/home` estarían los datos del usuario, donde también se puede almacenar configuración de las aplicaciones con respecto al usuario; en `/var` se suelen guardar archivos diversos como los Logs, entre otros; y finalmente nos queda `/etc` que nos permite almacenar material diverso, normalmente orientado a configuración y estructuración para los programas y el sistema. ### Corrección - **A túa resposta**: d) /etc - **Veredicto**: **✅ ¡Correcta!** - **O apuntamento do profe**: Tu desglose mental del FHS (Filesystem Hierarchy Standard) ha sido perfecto. `/bin` para binarios, `/home` para usuarios, `/var` para datos variables (logs, bases de datos) y `/etc` (que históricamente viene de "et cetera") es la sala de máquinas de las configuraciones. ## 4. (Tema 21) Seguridade nas redes: DMZ No deseño de redes de seguridade, unha DMZ (Zona Desmilitarizada) utilízase principalmente para: - a) Aloxar os servidores internos que conteñen as bases de datos máis sensibles da organización sen acceso a internet. - b) Crear unha subrede illada que contén os servizos que a organización ofrece cara ao exterior (como o servidor web da Sede Electrónica) para que, en caso de ataque, a rede interna permaneza protexida. - c) Aloxar exclusivamente os postos de traballo dos empregados públicos que non teñen privilexios de administrador. - d) Conectar directamente todos os routers da administración sen utilizar ningún tipo de cortafogos. ### Resposta Esta é sinxela, é a `b` por mor de illar os servizos expostos cara a Intranet. ### Corrección - **A túa resposta**: b) Crear unha subrede illada que contén os servizos... cara ao exterior. - **Veredicto**: **✅ ¡Correcta!** - **O apuntamento do profe**: De manual. Es la zona "tampón". Si un hacker tumba la web pública del Ayuntamiento (situada en la DMZ), se queda ahí atrapado y no puede saltar a la red interna donde están los ordenadores de los funcionarios. ## 5. (Tema 10) Desenvolvemento .NET: Ciclo de vida de Windows Forms En el desarrollo de una interfaz con WinForms en Visual Studio .NET, ¿cuál es el orden correcto de ejecución de estos tres eventos principales cuando se inicia un formulario? - a) Load -> Activated -> Shown - b) Shown -> Load -> Activated - c) Activated -> Shown -> Load - d) Load -> Shown -> Activated ### Respuesta Voy a responder a ciegas y diría que la `d` pues desde el desconocimiento más absoluto entiendo que primero cargamos la aplicación (`load`); luego mostramos el GUI base (`shown`); y finalmente lo rellenamos con lo que carguemos en éste (`activated`). ### Corrección - **A túa resposta**: d) Load -> Shown -> Activated - **Veredicto**: **❌ Incorrecta**. - **A correcta é**: **a) Load -> Activated -> Shown** - **O apuntamento do profe**: ¡Casi! Tu lógica tenía sentido, pero el sistema operativo Windows gestiona las ventanas con un matiz diferente. - **Load**: El formulario se carga en memoria y procesa los datos internos. - **Activated**: El formulario reclama y obtiene el foco del sistema operativo (se convierte en la ventana activa). - **Shown**: Finalmente, se dibuja y se hace visible por primera vez en la pantalla del usuario. # Bloque II: Preguntas de Respuesta Corta > *Respostas claras e directas ao concepto.* ## 6. (Tema 38 - Hardware: Almacenamento e RAID) Explica brevemente la diferencia de funcionamiento y tolerancia a fallos entre una configuración de discos en RAID 1 (Espejo) y una configuración en RAID 5 (Distribuido con paridad). ¿Cuál es el número mínimo de discos necesarios para cada uno? ### Respuesta En el RAID 1 tenemos la obligación de tener al menos 2 discos, aunque pueden ser más para mayor seguridad, pero en todos los discos habría la misma información espejada, lo que sí, a más discos mayor sacrificio de recursos; por otro lado, tenemos RAID 5 que requiere de al menos 3 discos donde uno es de mapeado/sumas de la información y los otros dos son fragmentos diversos recuperables mediante sí mismos o el disco de mapeado/sumas, pero puede haber más unidades de disco de fragmentos, permitiendo ampliar la capacidad de almacenamiento del RAID. El más seguro es el RAID 1 pero si queremos rendimiento y espacio el más eficiente es el RAID 5. ### Corrección - **Veredicto**: **✅ ¡Perfecta!** - **O apuntamento do profe**: Has dado con los números y los conceptos exactos. - **RAID 1 (Mínimo 2 discos)**: Si grabas una foto, se guarda en el disco A y en el disco B a la vez. Pierdes el 50% del espacio, pero si un disco arde, no pasa nada. - **RAID 5 (Mínimo 3 discos)**: Los datos se fragmentan y se reparten, calculando un "bloque de paridad". Si un disco muere, el sistema usa las matemáticas de los otros dos para reconstruir el disco muerto. Es el equilibrio perfecto en servidores. ## 7. (Tema 4 - Lei 7/1985 LRBRL: Servizos obrigatorios) Segundo o Artigo 26 da LRBRL, os servizos que os Concellos deben prestar obrigatoriamente varían segundo o número de habitantes. Nomea polo menos dous servizos que son obrigatorios en todos os municipios, independentemente da súa poboación. ### Resposta Falando a cegas diría servizos como iluminación, lixo, mantemento, etc. ### Corrección - **Veredicto**: **✅ ¡Correcta!** - **O apuntamento do profe**: Has tirado de la lógica municipalista básica y has acertado de lleno. El Artículo 26.1.a exige para **todos** los municipios (incluso los de 10 habitantes): Alumbrado público (iluminación), cementerio, recogida de residuos (lixo), limpieza viaria, abastecimiento de agua potable, alcantarillado, acceso a los núcleos de población y pavimentación de las vías públicas. ## 8. (Tema 35 - Scripts de automatización) En un script de Bash o Python para la automatización de tareas TIC, ¿qué es un "Exit Code" (o código de salida) y para qué se utiliza habitualmente dentro de una estructura de control (como un if)? ### Respuesta Los códigos de salida indican cómo se finalizó una aplicación o servicio. En Python, lo más conocido es la función `exit` cuyo argumento es el valor numérico que identifica el cierre para identificar cómo se cerró; lo mismo que con Bash tenemos el comando `exit` que funciona de la misma forma. Habitualmente, el argumento `0` indica que todo correcto mientras que el resto de códigos indican situaciones diversas que condicionaron el cierre no estándar del mismo. El `1` suele indicar un cierre excepcionado. ### Corrección - **Veredicto**: **✅ ¡Explicación de 10!** - **O apuntamento do profe**: Totalmente preciso. En Bash, un `0` siempre es "Misión Cumplida" y cualquier número del `1` al `255` es un código de error específico. Esto es vital en los `if` de Bash porque puedes hacer: `if comando_backup; then echo "Éxito"`. El `if` evalúa el exit code de forma invisible.