miércoles, 23 de mayo de 2012

Cataluña pretende que se tenga que pedir permiso con un mes de antelación para hacer “streaming”

Cataluña pretende que se tenga que pedir permiso con un mes de antelación para hacer “streaming”:
xatakaon.com
¿Os imaginaís tener que pedir permiso a una autoridad para poder hacer una TweetCam? ¿Parece de locos verdad? Pues algo así es lo que ha aprobado el Consejo de Audiovisual de Cataluña, una normativa por la que toda emisión de vídeo o audio en streaming deberá contar con permiso previo para su emisión.
Desde la popularización de Internet las administraciones y los gobiernos de distintos puntos del mundo han perdido cierto control sobre la información que reciben los ciudadanos. De un modelo donde cualquier difusión pública a gran escala como son la televisión o la radio hemos pasado a un panorama en donde la información fluye con rapidez escapándose del control del gobierno.
El CAC viene a regular todo aquella transmisión que se realice, teniendo que pedir permiso para ella el emisor con un plazo de un mes de antelación respecto a cuando se vaya a hacerse la emisión en cuestión.
Lo novedoso es que hasta donde conocemos reguladores como el CAC, supuestamente independiente del gobierno de la región, solo tienen derecho a regular las emisiones que se realicen mediante el espectro radioeléctrico por lo que a pesar de que Internet puede usar dicho espectro para su transmisión no es la única manera de transmitir la señal por lo que el consejo no debería tener derecho a regular lo que se puede emitir o no vía Internet.
Dejando de lado los aspectos legales que pueda suponer esta nueva regulación para los expertos en materias legales lo que esta claro es que el CAC se esta queriendo meter en un terreno que puede resultar muy farragoso y en el que seguramente encuentre la oposición frontal de la gran mayoría de la ciudadanía y de los internautas.
Una pregunta queda en el aire ahora ¿que pretende conseguir el CAC con una medida como esta?

domingo, 13 de mayo de 2012

El Gobierno, débil y sin autoridad política, desaloja Sol por la fuerza | #desalojoSol

El Gobierno, débil y sin autoridad política, desaloja Sol por la fuerza | #desalojoSol:

20120513-121402.jpg

Un Gobierno débil y sin autoridad siempre usa la fuerza para reprimir a los manifestantes pacíficos. Ayer eran muchos, muchos miles de manifestantes, y Delegación de Gobierno no se atrevió a ordenar a su brazo armado a reprimir a los concentrados el Sol. Esperó a que entrase la noche, a que los manifestantes fueran muchos menos, para decirles “quien manda”.
El resultado: 18 detenidos y una nueva muestra más de que el Gobierno pretende ganar con la fuerza lo que hace mucho tiempo que perdió con la razón.
La Policía asegura que no se han registrado incidentes graves y que no se ha realizado acampadas en ninguna ciudad española, a pesar de lo cual se ha procedido al desalojo, contradiciendose una vez mas el Gobierno, que dijo anoche que no se procedería al desalojo si no se acampaba.
La Policía Nacional desalojó por completo en apenas una hora la Puerta del Sol de Madrid y los principales accesos a la plaza, sacando del lugar por la fuerza a varios cientos de personas que, minutos antes de las 5.00, aún permanecían en el recinto.
En torno a las 4.40 horas, varias decenas de furgones de la Unidad de Intervención Policial accedieron a la plaza y los agentes procedieron a establecer un cordón en torno a las personas que permanecían en el lugar.
En el marco del desalojo, varias personas, que opusieron resistencia, fueron detenidas. Alguno de ellos permaneció durante varios minutos en el suelo y esposado con las manos en la espalda. Durante todo el proceso, la Policía ha procedido también a realizar numerosas identificaciones.

jueves, 10 de mayo de 2012

Y esta, niños, es la razón por la que las contraseñas no se escriben en un papel y se cuelgan de la pared

Y esta, niños, es la razón por la que las contraseñas no se escriben en un papel y se cuelgan de la pared:

Wifi-Passwords

… porque quizá venga la televisión a grabarte y el cartelón con las contraseñas del Wi-Fi esté a tu espalda. Viejuno pero divertido, rescatado de Front Line Sentinel vía Schneier.

Utilizando un kernel RT (de baja latencia)

Utilizando un kernel RT (de baja latencia):

Miguel Mayol, gran seguidor y comentador de este blog, nos recomendó un artículo publicado en Hispasonic sobre la utilización de kernels RT, que hemos decidido publicar y ampliar en algunas de sus partes.

Los kernels RT permiten un óptimo rendimiento en algunas situaciones partículares, por ejemplo, la edición de audio o la utilización de instrumentos musicales virtuales.

Kernel multitarea

El kernel de Linux, como el de la mayoría de los sistemas operativos modernos, es multitarea. Eso quiere decir que se están ejecutando varios programas al mismo tiempo.

En realidad esto no ocurre exactamente así. Lo que se hace es poner los programas en una cola y, uno por uno, el microprocesador los ejecuta durante una cierta cantidad de tiempo. Una vez agotado éste el microprocesador interrumpe la tarea dejándola a medias y da paso a la siguiente. A esta cantidad de tiempo se le denomina quantum o time slice, y no tiene por qué ser constante.

Una buena analogía podría ser el cocinero de un bar preparando varios platos a la vez: un bocata de lomo, una de callos, una ensalada mixta... Ahora parto el pan, enciendo la sartén, mientras se calienta lavo la lechuga, etc.

Si el quantum es suficientemente pequeño la impresión subjetiva para un observador lento, como el ser humano, es de que en vez de un procesador rápido ejecutando tareas alternativamente tenemos un procesador lento para cada una ellas (varios cocineros en la misma cocina haciendo lentamente cada uno un solo plato).

La conmutación de tareas tiene un costo

La multitarea no es gratis: implica una sobrecarga del procesador. En efecto, desalojar una tarea y cargar la siguiente es un trabajo extra. Esta operación se denomina 'cambio de contexto' o 'conmutación de tareas'. Sería más rentable en términos de CPU ejecutar los programas por completo, uno por uno, que partirlos en 'rodajas' e ir saltando de uno a otro. Sin embargo, el sistema perdería en interactividad, no podríamos tener varias ventanas abiertas o, en el caso de un servidor, atender a varias peticiones simultáneamente.

Latencia y rendimiento

Supongamos que nuestro cocinero tiene que pelar 20 kilos de gambas y deshuesar 20 kilos de aceitunas. ¿Cómo se planifica el trabajo?

En un caso extremo primero pelaría todas las gambas, se lavaría las manos para no mezclar sabores y después deshuesaría todas las aceitunas. Lo representaremos así:

GGGGGGGGGGGGGGGGGGGGGG... C AAAAAAAAAAAAAAAAAAAAAA...

En el extremo opuesto, pelaría una gamba, se lavaría las manos, deshuesaría una aceituna, se lavaría las manos... gamba, aceituna, gamba, aceituna... Lo representaremos así:

GCACGCACGCACGCACGCACGCACGCACGCACGCACGCACGCACGCACGCACGCACGCAC...

La 'C' representa el cambio de contexto: lavarse las manos, cambiar de utensilio...

Al mismo tiempo, un camarero recoge las peticiones de los clientes: "¡una de gambas!"... "¡una de aceitunas!"... y las translada a la cocina.

En el primer caso, supongamos que entra un cliente y pide una ración de gambas. No hay problema, enseguida se le sirve. Pero, ¿y si pide aceitunas? El camarero no podría servirla hasta que todas las gambas estuvieran peladas. En este caso la latencia, que es el tiempo que pasa desde que se hace una petición hasta que ésta es atendida, sería muy alta.

En el segundo caso, pida lo que pida el cliente, estará disponible en poco tiempo, además prácticamente igual en ambos casos. La latencia será baja, pero a un coste: debido a los cambios de contexto se producirá una disminución del rendimiento, entendido como la parte del tiempo durante el cuál la CPU está haciendo tareas directamente productivas, en lugar de labores de soporte.

Evidentemente en este caso la solución ideal sería un término medio, que dependería del tamaño de las raciones y de la distribución estadística de las peticiones. La teoría de colas es la rama de la matemática que se encarga de estudiar estas situaciones y de darles soluciones óptimas.

Como se puede ver, latencia y rendimiento son opuestos. Por esta razón no es correcto afirmar que los kernels rt dan más rendimiento. Todo lo contrario, al bajar la latencia empeoran el rendimiento de la máquina y, por lo tanto, son una elección pésima para sistemas que no necesiten respuestas superrápidas como, por ejemplo, servidores web o de bases de datos.

Por el contrario, los kernels de baja latencia son ideales en situaciones donde se necesite la máxima velocidad de respuesta a los estímulos externos, como sistemas de control industrial o aplicaciones multimedia interactivas, sabiendo que estamos sacrificando parte de la potencia de la máquina en garantizar esa rápida reacción.

Prioridades

Una opción interesante en sistemas multitarea es dar distintas prioridades a las tareas, de tal forma que las más importantes reciban más tiempo del procesador y las menos importantes menos. En un kernel normal esto se hace con el comando 'nice'. Si nuestro cocinero espera servir más raciones de gambas que de aceitunas haría bien en dedicarle más tiempo a las primeras, lógicamente.

Kernel RT (o de baja latencia)

El problema de los kernel normales es que las tareas no se pueden interrumpir en cualquier sitio, hay que esperar a que lleguen a ciertos puntos de ejecución donde ya se pueden detener para conmutar a otra. Esto introduce lo que llamamos latencia.

Por ponerlo de una forma simplificada, los kernels RT permiten interrumpir las tareas en más cantidad de sitios que los kernel normales. Pueden hacer, por así decirlo, rodajas más finas de tiempo, así que la tarea actual será desalojada más rápidamente y nuestra tarea prioritaria podrá acceder antes a la CPU. Por lo tanto la latencia será más baja.

Digamos que un kernel RT nos permite dejar una gamba a medio pelar si lo que se necesita en ese momento, urgentemente, es ponerse a deshuesar una aceituna lo antes posible, mientras que en un kernel normal habría que terminar de pelar la gamba.

Además de hacer rodajas más finas, los kernels RT tienen un sistema de prioridades mucho más estricto, donde las tareas prioritarias pegan hachazos inmisericordes a las demás (preempting) para hacerse con el control de la CPU, ralentizando los demás programas lo que sea necesario para cumplir con sus requisitos.

¿Cuándo es importante usar un Kernel RT?

En dos casos:

1) Cuando necesitamos latencias muy bajas, es decir, reacciones muy rápidas de la máquina. El ejemplo más claro es la ejecución de instrumentos virtuales, donde necesitas que al pulsar una tecla de un teclado MIDI el instrumento suene inmediatamente.

2) Cuando necesitamos prioridades muy estrictas, es decir, que nuestra tarea de alta prioridad no se interrumpa por nada del mundo (a no ser en el caso catastrófico de que la CPU esté tan sobrecargada que se supere el 100% de utilización). Por ejemplo, estamos grabando una sesión de audio con Ardour y observando cómo suben y bajan los indicadores de los faders. No importa si perdemos algún cuadro de refresco de los faders con tal de que el transporte de sonido del micrófono al disco duro no se vea interrumpido. Un kernel RT ralentizará el refresco de los faders todo lo que sea necesario con tal de que no se pierda ni una muestra de audio.

Dicho esto, en general los kernels no RT más recientes han mejorado mucho su sistema de planificación de tareas y su gestión de prioridades. Si no tienes la CPU al límite de sus posibilidades (digamos por debajo del 50% de utilización) o si no te importa que de vez en cuando se produzca un pequeño microcorte (clic) en el sonido (los tan temidos xruns), un kernel normal da unas prestaciones perfectamente aceptables.

¿Qué latencia es aconsejable?

A mí personalmente cualquier cosa por debajo de 10 ms ya me va bien y a partir de 20 ms ya empiezo a notar el retardo claramente. Hay gente más exigente.

Instalación

En Ubuntu y derivados:


sudo apt-get install linux-headers-lowlatency
sudo apt-get install linux-lowlatency
sudo update-grub


Al arrancar se podrá disponer de las dos opciones (el kernel normal y el de baja latencia).


En Arch y derivados:


yaourt -S linux-rt
sudo update-grub


Fuente: Hispasonic