Bottler Proxy
Go to file
Juan F. Codagnone 15ca9ae0c3 selector.c - un muliplexor de entrada salida
Un selector permite manejar en un único hilo de ejecución la entrada salida
de file descriptors de forma no bloqueante.

Esconde la implementación final (select(2) / poll(2) / epoll(2) / ..)

El usuario registra para un file descriptor especificando:
 1. un handler: provee funciones callback que manejarán los eventos de
    entrada/salida
 2. un interés: que especifica si interesa leer o escribir.

Es importante que los handlers no ejecute tareas bloqueantes ya que demorará
el procesamiento del resto de los descriptores.

Si el handler requiere bloquearse por alguna razón (por ejemplo realizar
una resolución de DNS utilizando getaddrinfo(3)), tiene la posiblidad de
descargar el trabajo en un hilo notificará al selector que el resultado del
trabajo está disponible y se le presentará a los handlers durante
la iteración normal. Los handlers no se tienen que preocupar por la
concurrencia.

Dicha señalización se realiza mediante señales, y es por eso que al
iniciar la librería `selector_init' se debe configurar una señal a utilizar.

Todos métodos retornan su estado (éxito / error) de forma uniforme.
Puede utilizar `selector_error' para obtener una representación human
del estado. Si el valor es `SELECTOR_IO' puede obtener información adicional
en errno(3).

El flujo de utilización de la librería es:
 - iniciar la libreria `selector_init'
 - crear un selector: `selector_new'
 - registrar un file descriptor: `selector_register_fd'
 - esperar algún evento: `selector_iteratate'
 - destruir los recursos de la librería `selector_close'
2022-05-31 09:48:52 -03:00
docs Add initial files 2022-05-28 15:34:03 -03:00
include Add initial files 2022-05-28 15:34:03 -03:00
src selector.c - un muliplexor de entrada salida 2022-05-31 09:48:52 -03:00
.gitignore Add initial files 2022-05-28 15:34:03 -03:00
LICENSE.md Add initial files 2022-05-28 15:34:03 -03:00
Makefile Add initial files 2022-05-28 15:34:03 -03:00
README.md Add initial files 2022-05-28 15:34:03 -03:00

README.md

BProxy

BProxy (Bottler Proxy)

Tabla de contenidos

Requisitos

Debe instalar gcc y make. Estos se encuentran disponibles en el repositorio de la vasta mayoría de distribuciones de Linux/macOS.

Compilación

Para compilar todos los archivos se debe hacer:

make all

Ejecución

Ahora, tendrá dos ejecutables: client y server. Note que primero debe correr el server y luego conectarse con el client.

./server

y en otra terminal

./client

Testeos

En orden de realizar un análisis estático del sistema usted debe tener instalado cppcheck y pvs-studio. Luego, puede correrlos con:

make test

Por último, si quiere hacer un análisis dinámico (usando valgrind) puede hacerlo mediante:

valgrind ./server

y en otra terminal

valgrind ./client

Limpieza

Si desea borrar los archivos creados luego de la compilación debe correr:

make clean

Note que si, además, quiere borrar el output de los tests (de PVS-Studio específicamente), lo puede hacer con:

make cleanTest

Autores

  • Barmasch, Juan Martín (61033)
  • Bellver, Ezequiel (61268)
  • Lo Coco, Santiago (61301)