Examen Oposicion 2019
Examen Oposicion 2019
Examen Oposicion 2019
INSTRUCIÓNS
• A duración total desta parte é de 3 horas.
• Entrégase un caderno con cinco exercicios.
• O/a aspirante escollerá e realizará dous exercicios de entre os cinco propostos, que deberá indicar
nos recadros correspondentes na cabeceira desta páxina e na do caderno de respostas, xunto co seu
nome, apelidos e o seu DNI/NIE.
• Os exercicios 1.2, 1.3, 3.3, 3.4, 4.3 e 5.2 responderanse nos espazos asignados a tal efecto no propio
enunciado. O resto dos exercicios deberán responderse no caderno de respostas que se achega.
• As follas grampadas non se poden separar.
• De precisar algún folio adicional, este será solicitado a un membro do tribunal, quen o grampará ao
resto dos folios.
• As respostas deben realizarse con bolígrafo de tinta negra ou azul, que non se poida borrar. Non se
permite o uso de cintas ou líquidos correctores. Non se corrixirá nada a lapis ou con tinta que se
poida borrar.
• Non se admiten preguntas. Calquera aclaración ou interpretación do enunciado que o/a aspirante
considere oportuno para a súa valoración, deberá indicala no caderno de respostas.
• Non se pode utilizar ningún material auxiliar, e están prohibidos os móbiles, reloxos, mans libres ou
calquera outro dispositivo electrónico, que deberán estar completamente apagados e gardados nos
bolsos debaixo do propio asento.
1 de 24
PRIMEIRA PROBA PARTE A
VLAN
Switch(config)#vlan <n> Creación de VLAN.
Switch(config-vlan)#name <nombreVLAN> Nome de VLAN.
switch(config-if)# switchport access vlan <n> Asignación de VLAN a un porto de acceso.
switch(config-if) switchport mode trunk Configuración do porto en modo trunk.
R1(config-subif)#encapsulation dot1Q 10
2 de 24
PRIMEIRA PROBA PARTE A
EXERCICIO 1
EXERCICIO 1.1
Desenvolver unha aplicación con scripts PHP na súa versión 7.x que realice un control de acceso á páxina de
perfil dos usuarios dun sitio web. A aplicación terá unha páxina de inicio de sesión (login.php) que permitirá
indicar as credenciais dun usuario para validar o seu acceso á aplicación.
A táboa de usuarios deberá ter os seguintes campos:
• Código de tipo autoincremento.
• Usuario, 12 caracteres alfanuméricos.
• Contrasinal, constará de 8 caracteres alfanuméricos incluíndo como caracteres especiais arroba, o punto
e coma, o símbolo do dólar, do euro, e almohadilla. Almacenarase na base de datos tendo en conta as
consideracións de seguridade implícitas a este tipo de páxinas.
• Correo electrónico, 255 caracteres alfanuméricos.
• Un campo numérico que garde o número de accesos á web dese usuario.
• Data e hora do último acceso do usuario.
A táboa de roles debe conter:
• Código, de tipo autoincremento.
• Nome do rol.
Un usuario pode ter varios roles.
O código da aplicación debe cumprir cos estándares de programación para programación orientada a obxectos
e o patrón arquitectónico modelo-vista-controlador así como todas as consideracións de seguridade necesarias.
Debe ser compatible con diferentes sistemas xestores de bases de datos.
Procura comentar o teu código para unha mellor comprensión do mesmo.
Desenvolve os seguintes aspectos do sitio web:
a) Os scripts SQL para crear as táboas necesarias nun servidor MySQL 5.7.
b) Completa a páxina login.php cos scripts necesarios.
<!DOCTYPE html>
<?php
//Lugar para os scripts solicitados
?>
<html>
<head>
<meta charset="UTF-8"/>
<title>Login</title>
<link href="estilos.css" rel="stylesheet">
</head>
<body>
<form action="login.php" method="post">
<fieldset>
<legend>Datos de acceso</legend>
Usuario: <input type="text" name="usuario" id="usuario" />
<br /><br />
Contrasinal: <input type="password" name="contrasinal" id="contrasinal" />
<br /><br />
<input type="submit" name ="enviar" id="enviar" value="Iniciar sesión" />
</fieldset>
</form>
</body>
</html>
3 de 24
PRIMEIRA PROBA PARTE A
c) O Data Access Object (dao.php) cos seguintes métodos:
a. Conexión á base de datos.
b. Recuperación dos datos dun usuario.
c. Comprobación de que as credenciais son correctas.
d) A páxina logout.php, que conterá un script que desconectará ao usuario autenticado para forzar a que no
seguinte acceso teña que volver a autenticarse, devolvéndoo á páxina login.php.
EXERCICIO 1.2
(Este exercicio debe resolverse aquí)
Un centro de estudos ten segmentado o tráfico LAN coas seguintes VLAN: Alumnos, Profesores e Servidores.
Para permitir a comunicación entre equipos de distintas VLAN, o centro conta cun router que limita estas
comunicacións con regras de acceso.
Topoloxía
Dispositivo Interfaz Dirección IPv4 Porto do switch Número VLAN Nome VLAN
4 de 24
PRIMEIRA PROBA PARTE A
Pídese usar comandos CLI para:
1. Crear e configurar os dispositivos para usar as VLAN.
2. Configurar as regras de acceso de xeito que se teñan en conta as seguintes restricións, indicando clara-
mente o dispositivo e a interface que se está a configurar:
• Os equipos dos alumnos poden ter acceso ao servidor web. Non terán acceso a ningún outro
equipo.
• Os equipos da VLAN de profesores terán acceso ao servidor web. Non terán acceso a ningún
outro equipo.
• O servidor de dominio terá acceso as VLAN de alumnos e profesores. Non terá acceso a ningún
outro equipo.
• O servidor web limitarase a responder as consultas orixinadas na LAN.
5 de 24
PRIMEIRA PROBA PARTE A
EXERCICIO 1.3
(Este exercicio debe resolverse aquí)
Dada a seguinte captura de Wireshark responde as seguintes cuestións:
6 de 24
PRIMEIRA PROBA PARTE A
EXERCICIO 2
EXERCICIO 2.1
Implementa unha clase Combinaciones que teña un método que calcule as combinacións posibles dada unha
lonxitude e unha lista de enteiros e as imprima por consola. Deberá ser o máis eficiente posible e permitir
calcular calquera lonxitude e para calquera combinación de enteiros.
Por exemplo, para lonxitude 2 e os enteiros 0 e 1, as combinacións posibles serían as seguintes:
[0, 0] | [0, 1] | [1, 0] | [1, 1]
Procura documentar e comentar o código para unha mellor comprensión do mesmo.
O resultado da execución desta clase Main deberá ser como o seguinte:
import java.util.ArrayList;
import java.util.List;
public class Main {
public static void main(String[] args) {
Combinaciones comb = new Combinaciones();
List<Integer> valores = new ArrayList<>();
valores.add(0);
valores.add(1);
valores.add(2);
System.out.println("Combinacións de lonxitude 3 con 0, 1 e 2: ");
comb.calculaCaminosVariables(valores, new ArrayList<>(), 3);
}
}
EJERCICIO 2.2
No seguinte main() utilízanse expresións lambda para indicar a un método filtrar() o criterio para filtrar Strings
do array listaPalabras. Observa que as expresións lambda implementan o interface funcional Predicate. Pídese
que escribas o método filtrar(), de forma que imprima por pantalla os strings que cumpran o predicado indicado
na expresión lambda. O método filtrar() simplemente ten que ter a capacidade de filtrar Strings, non outros tipos
de obxectos. Hai que ter en conta que para realizar o exercicio, o main() non se pode modificar e ao executalo
debe obterse unha saída como a que se indica máis abaixo.
Implementa en Java o método filtrar()
Procura documentar e comentar o teu código para unha mellor comprensión do mesmo.
import java.util.function.Predicate;
class FiltrosLambda {
public static void main(String[] args) {
String[] listaPalabras = {"cola", "limbo", "zapatos", "imposible"};
System.out.print("Imprimir palabras con máis de 5 caracteres: ");
Predicate<String>predicado = s->s.length() > 5;
filtrar(listaPalabras, predicado);
System.out.print("\nImprimir palabras menores que vaca: ");
SAÍDA:
Imprimir palabras con máis de 5 carácteres: zapatos imposible
Imprimir palabras menores alfabéticamente que 'vaca': cola limbo imposible
7 de 24
PRIMEIRA PROBA PARTE A
AXUDA:
EXERCICIO 2.3
Dada unha Base de Datos formada polas seguintes relacións:
• M(ALUMNO, MODULO, NOTA)
• I(PROFESOR, MODULO)
• D(PROFESOR, DEPARTAMENTO)
• E(CICLO, MODULO)
Onde:
• M relaciona os alumnos cos módulos nos que están matriculados e as notas correspondentes.
• I relaciona aos profesores cos módulos que imparten.
• D relaciona aos profesores cos departamentos aos que pertencen.
• E relaciona os ciclos cos módulos que os compoñen.
Expresa en MySQL 5.7 as seguintes consultas:
a) Profesores que non imparten clase.
b) Profesores que imparten clase en dous módulos.
c) Departamentos que imparten módulos en máis dun ciclo.
d) Alumnos que aproban todos os módulos aos que se presentan.
e) Media das notas medias dos alumnos que aprobaron polo menos a metade dos módulos nos que esta-
ban matriculados.
8 de 24
PRIMEIRA PROBA PARTE A
EXERCICIO 3
EXERCICIO 3.1
(Os datos expostos neste exercicio non teñen por que axustarse á realidade).
Queremos deseñar unha base de datos para a xestión da Formación en Centros de Traballo (FCT) dos institutos
nos que se imparten ciclos de Formación Profesional.
Os ciclos formativos poden ser de grao básico, medio ou superior e clasifícanse en familias.
Dun instituto queremos almacenar o seu código, nome, a localidade na que está situado e os ciclos formativos
que se imparten nel. Nun instituto haberá polo menos un ciclo dunha familia formativa, pero pode haber máis
ciclos da mesma ou doutra familia.
De cada familia formativa almacenaremos o seu código e nome, así como os ciclos que a forman. De cada ciclo
almacenaremos o código, o nome, o grao (básico, medio ou superior), o réxime (ordinario ou adultos) e o número
total de horas asignadas á FCT nese ciclo.
Cada ciclo formativo terá un titor de FCT (titor no centro de educativo), que titorizará a todos os alumnos
matriculados nese ciclo que realicen a FCT.
Poderán acceder a esa base de datos mediante unha aplicación web que se deseñará a tal efecto os seguintes
tipos de usuarios: titor no centro de traballo, alumno e titor no centro educativo.
Dos usuarios queremos almacenar o seu nome, teléfono de contacto, correo electrónico e DNI. Do titor no centro
de traballo tamén queremos almacenar a empresa á que pertence.
Do titor no centro educativo almacenaremos ademais o instituto no que ten praza e o tipo de praza (definitiva,
provisional, interinidade ou substitución). Un titor no centro educativo ten praza nun único instituto, e pode
estar matriculado nun ciclo formativo, pero non no mesmo que titoriza.
Do alumno gardaremos tamén a súa data de nacemento e o ciclo no que está matriculado. Un alumno pode estar
matriculado nun ciclo en réxime ordinario e outro en réxime de adultos, pero non en máis dun ciclo no mesmo
réxime.
Dunha empresa almacenaremos o seu CIF e nome comercial. Cada empresa pode ter un ou máis centros de
traballo dos que almacenaremos o seu enderezo.
Un alumno terá un só titor no centro de traballo e outro no centro educativo e estará asociado a un único centro
de traballo. Interésanos almacenar a data de inicio das prácticas.
Os titores do centro de traballo poden estar asociados a máis dun centro de traballo. Cada empresa pode ter
varios titores. Cada titor pode ter varios alumnos ao seu cargo.
Expresa cun diagrama E/R estendido as seguintes entidades, os seus atributos e as relacións existente entre elas:
a) Usuario, titor no centro de traballo, titor no centro educativo e alumno.
b) Empresa, centro de traballo e titor no centro de traballo.
c) Familia, ciclo e os distintos tipos de usuario (non fai falta que indiques os atributos para os usuarios
neste apartado).
d) Instituto, titor no centro educativo e ciclos formativos. Xustifica as cardinalidades empregadas neste
apartado.
9 de 24
PRIMEIRA PROBA PARTE A
EXERCICIO 3.2
DataNace-
Nome DataNacemento Posto Adestradora Equipo Patrocinadores Cidade Provincia Tempada Puntos
mentoAdestradora
María Victoria
01/03/1997 10 02/02/1998 Obradoiro Aspaneps Santiago A Coruña 2018/2019 32
Gutiérrez Segura
Xulia
12/05/2001 7 María Torres 20/04/1999 Celta Galicia Verde Vigo Pontevedra 2018/2019 47
Fernández
Emilia Victoria Meniños,
24/04/1995 11 02/02/1998 Obradoiro Santiago A Coruña 2018/2019 21
Pérez Segura Greenpeace
Carmela Unicef, Cruz
Ana López 25/11/1999 10 24/12/1993 Estudantes Pontevedra Pontevedra 2018/2019 5
Durante vermella
Obradoiro 2018/2019 53
Celta 2018/2019 47
EXERCICIO 3.3
(Este exercicio debe resolverse aquí)
A empresa ABC ten asignada a seguinte dirección IP 180.200.0.0/16. Ten delegacións no sur de Galicia repartidas
en 3 áreas xeográficas: Vigo, Ourense e Pontevedra. A área de Ourense conta con 6 oficinas con 1050 hosts cada
unha, a área de Vigo ten 10 oficinas, en cada unha ten 600 hosts. Na terceira área, Pontevedra, ten 35 oficinas
con 200 hosts cada unha. A empresa pídenos deseñar un esquema de direccionamento xerárquico con subredes
de tamaño variable (VLSM).
A dirección de rede que se proporciona para o esquema é: 180.200.0.0/16.
Para a realización do exercicio consideraremos que a subrede cero (subnet zero) está habilitada en todos os
dispositivos de rede, polo que se utilizará para a súa resolución.
1. Cantos bits son necesarios para identificar cada área? Codifica as distintas áreas na táboa e
indica a máscara de subrede para cada área, a dirección de subrede e a de broadcast.
10 de 24
PRIMEIRA PROBA PARTE A
2. Indica na táboa o número de bits necesarios para codificar as oficinas de cada área e a máscara
de subrede en formato CIDR.
Máscara
Oficina do área de Oficinas Bits codificación Hosts Bits necesarios
CIDR
Vigo 10 600
Ourense 6 1050
Pontevedra 35 200
3. Cal sería a máscara de rede para cada oficina? Escríbeas nas táboas
Dirección de rede das oficinas de Vigo e máscara CIDR
Oficina 1
Oficina 2
Oficina 3
Oficina 4
Oficina 5
Oficina 6
Oficina 7
Oficina 8
Oficina 9
Oficina 10
Dirección de rede das oficinas de Ourense
Oficina 1
Oficina 2
Oficina 3
Oficina 4
Oficina 5
Oficina 6
6. Supoña que a nosa organización se lle asigna o prefixo de routing global IPv6 :
2001:0DB8:AC10::/48
Os administradores da rede deciden repartir o hexteto de subrede de xeito que permita identificar as
áreas e as oficinas, para iso deixan o byte máis significativo para codificar as áreas e o menos significativo
para as oficinas:
Áreas Codificación do hexteto
Vigo 0000
Ourense 0100
Pontevedra 0200
11 de 24
PRIMEIRA PROBA PARTE A
Como exemplo, no hexteto, a quinta oficina de Ourense quedaría codificada como segue: 0104
Cubre a táboa coas direccións de subrede das oficinas da área de Ourense que se piden. Utiliza nota-
ción CIDR para as direccións IPv6 comezando a asignación das direccións dende 0 (a oficina número 2
corresponderá coa terceira oficina sendo a primeira oficina a numerada co 0).
7. Expresa, reducindo todo o posible a expresión, a dirección da subrede da primeira oficina da área de
Vigo (emprega notación CIDR).
EXERCICIO 3.4
(Este exercicio debe resolverse aquí)
Estamos administrando unha rede co seguinte esquema:
1. Acaba de encher a táboa coa información dos routers e, usando comandos CLI, configura o router de
Pontevedra coas direccións IPv4. Os routers enlazan coa LAN co porto Gigabit0/1.
Pontevedra$>
12 de 24
PRIMEIRA PROBA PARTE A
2. Enche a seguinte táboa cos datos dos PC, e escribe unha IP e unha porta de enlace que consideres
axeitada.
3. Escribe os comandos para activar e configurar o enrutamento RIP no router de Pontevedra. Utiliza RIP
versión 2. Poderías usar a versión anterior? Razoa a túa resposta.
Pontevedra$>
4. Completa a táboa coa información dos routers. Usa direccións estáticas para as direccións de enlace local.
Os routers enlazan coa LAN no porto Gigabit0/1. Temos asignado un prefixo de routing global
2001:DB8:CAF1::/48
13 de 24
PRIMEIRA PROBA PARTE A
EXERCICIO 4
EXERCICIO 4.1
<?xmlversion="1.0" encoding="UTF-8"?>
<!DOCTYPE informacion SYSTEM "informacionG.dtd">
<informacion>
<software codigo="N1" tipo="gratuito">
<nome>Notepad++</nome>
<dataPubli ano="2015" mes="marzo"/>
</software>
<software codigo="X1">
<nome>XML Copy Editor</nome>
<dataPubli ano="2012" mes="maio"/>
</software>
<software codigo="M1" tipo="comercial">
<nome>Microsoft Word</nome>
</software>
<software codigo="P1">
<nome>PacketTracer</nome>
<dataPubli ano="2016" mes="enero"/>
</software>
<modulo usa="N1 X1">
<titulo>Linguaxe de Marcas</titulo>
</modulo>
<modulo usa="P1">
<titulo>Redes</titulo>
</modulo>
<modulo>
<titulo>FOL</titulo>
</modulo>
</informacion>
Partindo do documento XML anterior, crea un DTD que o valide tendo en conta o seguinte:
• Sempre existirán elementos software e modulo.
• O elemento informacion terá un atributo chamado curso que sempre terá o valor 1.
• O codigo será único e o tipo poderá tomar os valores gratuito ou comercial.
• A data de publicación terá por defecto o ano 2015 e sempre indicará o mes.
• Debemos validar que os módulos usen o software existente no documento XML.
14 de 24
PRIMEIRA PROBA PARTE A
EXERCICIO 4.2
<?xml version="1.0" encoding="UTF-8"?>
<ordenadores xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLoca-
tion="ordenadores1.xsd">
<sistemaOperativo codigo="WXP">Windows XP</sistemaOperativo>
<sistemaOperativo codigo="W7">Windows 7</sistemaOperativo>
<sistemaOperativo codigo="W10">Windows 10</sistemaOperativo>
<sistemaOperativo codigo="U18">Ubuntu 18.04</sistemaOperativo>
<taller>
<codigo>10</codigo>
<lugar>Planta 1</lugar>
<numOrdenadores>30</numOrdenadores>
</taller>
<sala impresora="true">
<codigo>11</codigo>
<lugar>Planta 2</lugar>
<numServidores>30</numServidores>
</sala>
<ordenador numero="200.300.1">
<sistemaOperativo codigo="WXP"/>
</ordenador>
<ordenador numero="200.300.20">
<sistemaOperativo codigo="W10"/>
</ordenador>
<ordenador numero="200.300.300">
<sistemaOperativo codigo="W7"/>
</ordenador>
<ordenador numero="200.300.40">
<sistemaOperativo codigo="U18"/>
</ordenador>
<ordenador numero="200.300.5">
<sistemaOperativo codigo="W7"/>
</ordenador>
<ordenador numero="200.300.75">
<sistemaOperativo codigo="W10"/>
</ordenador>
</ordenadores>
Partindo do documento XML anterior, crea os elementos do XML Schema necesarios para realizar as seguintes
tarefas:
1. Definir o elemento sistemaOperativo (o que é fillo de ordenadores). O atributo codigo contén unha
cadea de caracteres.
2. Definir o elemento do XML Schema que permita comprobar que os ordenadores empreguen o software
existente no documento XML.
3. Definir o elemento sala creando un grupo que se poida reutilizar para definir o elemento taller.
4. Definir o elemento numOrdenadores sabendo que ten que conter un número maior que 20 e menor ou
igual que 40.
5. Definir o atributo numero do ordenador tendo en conta que sempre segue o mesmo formato: comeza
por 200.300. e a continuación ten un número do 0 a 999.
15 de 24
PRIMEIRA PROBA PARTE A
EXERCICIO 4.3
(Este exercicio debe resolverse aquí)
1. En Apache 2.4, indica como podemos permitir o acceso ao directorio /www/docs ao usuario admin ou aos
usuarios do grupo profes que accedan dende a rede 192.168.10.0/24.
Que sucede?
3. Nun entorno Linux, realiza unha conexión FTP anónima co servidor ftp.teis.gal. Coa conexión establecida,
comproba no servidor remoto, cal é o directorio actual, lista o seu contido e obtén os arquivos con exten-
sión jpg.
Sube ao servidor o arquivo subida.txt.
4. Explica as seguintes liñas de código e indica o arquivo no que hai que incluílas:
chroot_local_user=YES
chroot_list_enable=YES
chroot_list_file=/etc/vsftpd/chroot_list
16 de 24
PRIMEIRA PROBA PARTE A
5. Dado o seguinte código, extraído dun arquivo de configuración dun servidor ISC DHCP Linux,
escribe as liñas necesarias para declarar a subrede 192.168.4.0/24 cun rango dende a IP 192.168.4.50 ata a
IP 192.168.4.150 e para reservar a IP 192.168.4.20 ao host equipo1 coa MAC 09:24:00:A7:D1:06.
authoritative;
option domain-name "asir.net";
option domain-name-servers 192.168.4.1;
option broadcast-address 192.168.4.255;
option routers 192.168.4.254;
default-lease-time 600;
max-lease-time 7200;
7. Observa a seguinte imaxe que amosa parcialmente o contido dun dos ficheiros relacionados con DNS.
Completa correctamente os valores que non se amosan.
#cat /etc/bind/___________
;
;BIND data file for local loopback interface
;
$______ 604800
@ IN _______ localhost. root.localhost. (
2 ; ________
604800 ; ________
86400 ; ________
2419200 ; ________
604800 ) ; Negative Cache ______
;
@ IN ______ localhost.
@ IN ______ 127.0.0.1
17 de 24
PRIMEIRA PROBA PARTE A
8. Temos instalado na nosa rede o snort. Incorporámoslle a regra que se amosa a continuación.
Indica a mensaxe que debería devolver tras a detección da actividade configurada na mesma.
alert any any -> 192.168.1.0/24 any (flags: A; ack: 0; msg: "_________________________";)
9. Que regra crearíamos se queremos que o snort rexistre todo o tráfico TCP que entra na nosa rede
(192.168.1.0/24) aos portos menores ou iguais a 6000? Indica o arquivo no que terías que incluíla.
18 de 24
PRIMEIRA PROBA PARTE A
EXERCICIO 5
EXERCICIO 5.1
1. Na rede da figura temos tres máquinas server01, server02 e client01 cun sistema operativo Linux.
A máquina server01 ten dous interfaces de rede, enruta (echo 1 > /proc/sys/net/ipv4/ip_forward) e ademais ten
instalado o paquete netfilter con iptables, o servizo ssh (openssh) e un proxy DNS (dnsmasq) que reenvía as
consultas a un servidor DNS situado na rede insegura.
A máquina server02 ten instalado un servidor http (Apache) e un proxy http (squid3) que escoita sobre o porto
TCP 3128. Ambos se xestionan remotamente mediante un servizo (webmin) que escoita sobre o porto TCP
10000.
A máquina client01 dispón dun navegador web.
O router da rede insegura está configurado para poder acceder a Internet.
19 de 24
PRIMEIRA PROBA PARTE A
A configuración do ficheiro /etc/network/interfaces en cada unha das máquinas é a seguinte:
SERVER01 SERVER02 CLIENT01
auto lo auto lo auto lo
iface lo inet loopback iface lo inet loopback iface lo inet loopback
auto eth1
iface eth1 inet static auto eth0 auto eth0
address 192.168.56.99 iface eth0 inet static iface eth0 inet static
netmask 255.255.255.0 address 192.168.56.100 address 192.168.56.101
auto eth0 netmask 255.255.255.0 netmask 255.255.255.0
iface eth0 inet static gateway 192.168.56.99 gateway 192.168.56.99
address 192.168.1.5 dns-nameservers 192.168.56.99 dns-nameservers 192.168.56.99
netmask 255.255.255.0
gateway 192.168.1.1
dns-nameservers 192.168.1.2
20 de 24
PRIMEIRA PROBA PARTE A
2. Modificamos as configuracións do ficheiro /etc/network/interfaces das distintas máquinas da seguinte
maneira:
SERVER01 SERVER02 CLIENT01
auto lo auto lo auto lo
iface lo inet loopback iface lo inet loopback iface lo inet loopback
auto eth1
iface eth1 inet static auto eth0 auto eth0
address 192.168.56.99 iface eth0 inet static iface eth0 inet static
netmask 255.255.255.0 address 192.168.55.100 address 192.168.56.101
iface eth1 inet static netmask 255.255.255.0 netmask 255.255.255.0
address 192.168.55.99 gateway 192.168.55.99 gateway 192.168.56.99
netmask 255.255.255.0 dns-nameservers 192.168.55.99 dns-nameservers 192.168.56.99
auto eth0
iface eth0 inet static
address 192.168.1.5
netmask 255.255.255.0
gateway 192.168.1.1
dns-nameservers 192.168.1.2
21 de 24
PRIMEIRA PROBA PARTE A
Responda agora ás seguintes preguntas:
a) Nesta nova configuración engadiuse unha regra NAT que reenvía as peticións http e https ao proxy
instalado na máquina server02 co cal as máquinas da rede 192.168.56.0/24 acceden a Internet usando un
proxy transparente. Con todo, o acceso Internet segue sen funcionar. Sabería dicir por que? Que cambios
faría na configuración das máquinas para permitilo?
b) É posible acceder ao servidor web da máquina server02 dende a máquina client01? En caso afirmativo,
indica se se trata dunha conexión directa ou proxificada e razoa a resposta.
c) Que ocorre se tecleamos na barra do navegador da máquina client01 a dirección http://192.168.1.5? Que
sucede se repetimos a conexión web poñendo a regra número 6 antes da regra número 4?
EXERCICIO 5.2
(Este exercicio debe resolverse aquí)
22 de 24
PRIMEIRA PROBA PARTE A
EXERCICIO 5.3
Queremos implementar o problema do Produtor-Consumidor. Para o que se creou unha clase principal
ProductorConsumidor que executa o método main e as clases Productor e Consumidor.
As tres fan uso da clase Contenedor, que será a que almacene o recurso compartido. Debes implementar a clase
completa de tal forma que se garanta que nunca poderán acceder ao recurso compartido de forma simultánea
dous fíos distintos (nin para producir nin para consumir). Tamén deberá permitir que os fíos queden á espera
de que exista recurso para consumir ou espazo para producir. Recorda que todos os fíos deben notificar ao resto
a liberación do recurso.
Procura documentar e comentar o teu código para unha mellor comprensión do mesmo.
O comezo do resultado da execución da clase ProductorConsumidor deberá ser similar ao seguinte:
ProductorConsumidor.java
Consumidor.java
23 de 24
PRIMEIRA PROBA PARTE A
Productor.java
import java.util.Random;
public class Productor implements Runnable {
private final Random aleatorio;
private final Contenedor contenedor;
private final int id;
private final int TIEMPOESPERA = 1000;
public Productor(Contenedor contenedor, int idproductor) {
this.contenedor = contenedor;
this.id = idproductor;
aleatorio = new Random();
}
@Override
public void run() {
while (Boolean.TRUE) {
int poner = aleatorio.nextInt(300);
contenedor.put(poner);
System.out.println("Productor " + id + " pon: " + poner);
try {
Thread.sleep(TIEMPOESPERA);
} catch (InterruptedException e) {
System.err.println("Productor " + id + ": " + e.getMessage());
}
}
}
}
24 de 24