Explicacion PDF

Descargar como pdf o txt
Descargar como pdf o txt
Está en la página 1de 53

Presentacion

Introduccion a los Sistemas Operativos

Facultad de Informatica
Universidad Nacional de La Plata

2017
La Catedra
Sitio Web: http://catedras.info.unlp.edu.ar
(unico medio de comunicacion)
Explicaciones:
Turno manana: Jueves 8:00 - Aula 5
Turno manana: Jueves 19:00 - Aula 5
Resolucion de Ejercicios y consultas:
Turno manana: Viernes 13:00 - Aula 5
Turno manana: Viernes 17:30 - Aula 4
Integrantes:
JTP turno manana:
Nicolas del Rio: [email protected]
JTP turno tarde:
Martn Baez: [email protected]
Emanuel Nucilli: [email protected]
Nahuel Cuesta Luengo Carlos Meza Maximo Zarza
Maria Emilia Corrons Leonardo Otonelo Alejandra Sebastian
Claudia Quintana Adan Mauri Gonzalo Testa
Erica Padovani Agustn Parmisano Matas Bentez
Los Parciales
Entran todos los temas vistos en la practica (enunciados de
TP, explicaciones, material adicional brindado por la catedra,
respuestas al foro)
La materia consta de 2 parciales:
Sistemas Operativos Aplicados (practicas 1,2 y 3):
Primera fecha ! sabado 30 de Septiembre
Segunda fecha ! sabado 21 de Octubre
Practica Normal (practicas 4,5 y 6):
Primer fecha ! sabado 11 de Noviembre
Segunda fecha ! sabado 26 de Noviembre
Recuperatorio general: 14 Diciembre o Febrero (a confirmar)
Para rendir cada parcial se deben contestar las
autoevaluaciones de las practicas correspondientes
(OBLIGATORIAS!)
Para aprobar la cursada hay que aprobar ambos parciales
Conceptos Generales
Explicacion de practica 1

Introduccion a los Sistemas Operativos

Facultad de Informatica
Universidad Nacional de La Plata

2017
Que es un Sistema Operativo?

Es parte esencial de cualquier sistema de computo


Es un programa que actua, en principio, como intermediario
entre el usuario y el hardware
Su proposito: crear un entorno comodo y eficiente para la
ejecucion de programas
Su obligacion: garantizar el correcto funcionamiento del
sistema
Sus funciones principales
Administrar la memoria
Administrar la CPU
Administrar los dispositivos
Que es un Sistema Operativo? (cont.)

Segun Wikipedia:
...Es un conjunto de programas de computacion destinados a
realizar muchas tareas...
Segun un usuario standar: Lo que aparece cuando prendo la
PC
...
GNU/Linux

Es un Sistema Operativo tipo Unix (Unix like), pero libre


S.O. disenado por miles de programadores
S.O. gratuito y de libre distribucion (se baja desde la Web,
CD, etc.)
Existen diversas distribuciones (customizaciones)
Es codigo abierto, lo que nos permite estudiarlo,
personalizarlo, auditarlo, aprovecharnos de la documentacion,
etc...
Podemos ver como esta hecho!!!
GNU?

GNU = GNU No es Unix

Iniciado por Richard Stallman en 1983 con el fin de crear un


Unix libre (el sistema GNU)
Para asegurar que el mismo fuera libre, se necesito crear un
marco regulatorio conocido como GPL (General Public
License de GNU)
En 1985, Stallman crea la FSF (Free Software Foundation),
con el fin de financiar el proyecto GNU
En 1990, GNU ya contaba con un editor de textos (Emacs),
un compilador (GCC) y gran cantidad de bibliotecas que
componen un Unix tpico.
Faltaba el componente principal ! El Nucleo (Kernel)
GNU

Si bien ya se vena trabajando en un nucleo conocido como


TRIX, es en 1988 que se decide abandonarlo debido a su
complejidad (corra en hardware muy costoso)
En este momento se decide adoptar como base el nucleo
MACH para crear GNU Hurd, el cual tampoco prospero
Linus Torvalds ya vena trabajando desde 1991 en un Kernel
denominado Linux, el cual se distribuira bajo licencia GPL
En el ano 1992, Torvalds y Stallman deciden fusionar ambos
proyectos, y es all donde nace GNU/Linux
GNU/Linux pertenece al desarrollo del software libre
GNU (cont.)

GNU se refiere a 4 libertades principales de los usuarios del


software:
Libertad de usar el programa con cualquier proposito
Libertad de estudiar su funcionamiento
Libertad para distribuir sus copias
Libertad para mejorar los programas
Los programas son una forma de expresion de ideas. Son
propiedad de la humanidad y deben ser compartidos con todo
el mundo
Software libre?
Software libre?

Caractersticas del software libre:


Una vez obtenido, puede ser usado, copiado, estudiado,
modificado y redistribuido libremente
Generalmente es de costo nulo Es un gran error asociar el
software libre con el software gratuito Pensar en software
gratis que se distribuye con restricciones
Es comun que se distribuya junto con su codigo fuente
Correccion mas rapida ante fallas
Caractersticas que se refieren a la libertad de los usuarios para
ejecutar, copiar, distribuir, estudiar, cambiar y mejorar el
software
Software propietario?

Caractersticas del software propietario:


Generalmente tiene un costo asociado
No se lo puede distribuir libremente
Generalmente no permite su modificacion
Normalmente no se distribuye junto con su codigo fuente
La correccion de fallas esta a cargo del propietario
Menos necesidad de tecnicos especializados
GPL: Generic Public License

Licencia Publica General de GNU


Creada en el ano 1989 por la FSF
Su objetivo principal es proteger la libre distribucion,
modificacion y uso del software GNU
Su proposito es declarar que todo software publicado bajo esta
licencia, es libre y esta protegido teniendo en cuenta las 4
libertades principales ya vistas
La version actual de la licencia es la 3
Caractersticas generales de GNU/Linux

Es multiusuario
Es multitarea y multiprocesador
Es altamente portable
Posee diversos interpretes de comandos, de los cuales algunos
son programables
Permite el manejo de usuarios y permisos
Todo es un archivo (hasta los dispositivos y directorios)
Cada directorio puede estar en una particion diferente (/temp,
/home, etc.)
Es case sensitive
Es codigo abierto
Diseno

Fue desarrollado buscando la portabilidad de los fuentes


Desarrollo en capas
Separacion de funciones
Cada capa actua como una caja negra hacia las otras
Posibilita el desarrollo distribuido
Soporte para diversos File Systems
Memoria virtual = RAM + SWAP
Desarrollo mayoritario en C y assembler
Otros lenguajes: java, perl, python, etc.
Estructura basica del S.O. - Nucleo

Tambien conocido como Kernel


Ejecuta programas y gestiona dispositivos de hardware
Es el encargado de que el software y el hardware puedan
trabajar juntos
Sus funciones mas importantes son la administracion de
memoria, CPU y la E/S
En si, y en un sentido estricto, es el sistema operativo
Es un nucleo monoltico hbrido:
Los drivers y codigo del Kernel se ejecutan en modo
privilegiado
Lo que lo hace hbrido es la capacidad de cargar y descargar
funcionalidad a traves de modulos
Esta licenciado bajo la lecencia GPL v2
Nucleo - Un poco de historia

En 1991 Linus Torvalds inicia la programacion de un Kernel


Linux basado en Minix (clon de Unix desarrollado por
Tenembaum en 1987 con el fin de crear un S.O. de uso
didactico)
El 5 de octubre de 1991, se anuncia la primera version
oficial de Linux (0.02)
En 1992 se combina su desarrollo con GNU, formando
GNU/Linux
La version 1.0 aparecio el 14 de marzo de 1994
Desarrollo continuado por miles de programadores al rededor
del mundo
Nucleo - Un poco de historia (cont.)

En mayo de 1996 se decide adoptar a Tux como mascota


oficial de Linux

En julio de 1996 se lanza la version 2.0 y se define la


nomenclatura de versionado. Se desarrollo hasta febrero de
2004 y termino con la 2.0.40
En enero de 1999 se lanza la version 2.2, que provee mejoras
de portabilidad entre otras y se desarrolla hasta febrero de
2004 terminando en la version 2.2.26
En 2001 se lanza la version 2.4 y se deja de desarrollar a fines
del 2010 con la 2.4.37.11
La version 2.4 fue la que catapulto a GNU/Linux como un SO
estable y robusto. Durante este perodo es que se comienza a
utilizar Linux mas asiduamente
Nucleo - Un poco de historia (cont.)

A fines del 2003 se lanza la version 2.6


Esta version ha tenido muchas mejoras para el SO dentro de
las que se destacan soporte de hilos, mejoras en la
planificacion y soporte de nuevo hardware
El 3 de agosto de 2011 se lanza la version 2.6.39.4
anunciandose la misma desde meses previos como la ultima en
su revision
El 17 de julio de 2011 se lanza la version 3.01
No agrega mayores cambios. La decision del cambio son los 20
anos del SO y no superar los 40 numeros de revision
Totalmente compatible con 2.6
La ultima version estable es la 4.7.1 (agosto de 2016)
1
http://kernelnewbies.org/Linux_3.0
Nucleo - Rama 2.6 y 3.x

A: Denota version. Cambia con menor frecuencia. En 1994


(version 1.0) y en 1996 (version 2.0)
B: Denota mayor revision. Antes de la version 2.6, los
numeros impares indicaban desarrollo, los pares produccion
C: Denota menor revision. Solo cambia cuando hay nuevos
drivers o caractersticas
D: Cambia cuando se corrige un grave error sin agregar nueva
funcionalidad Casi no se usa en las ramas 3.x y 4.x,
viendose reflejado en C
Iterprete de comandos

Tambien conocido como CLI (Command Line Interface)


Modo de comunicacion entre el usuario y el SO
Ejecuta programas a partir del ingreso de comandos
Cada usuario puede tener una interfaz o shell
Se pueden personalizar
Son programables
Bourne Shell (sh), Korn Shell (ksh), Bourne Again Shell
(bash)(autocompletado, history, alias)
Sistemas de archivos

Organiza la forma en que se almacenan los archivos en


dispositivos de almacenamiento (fat, ntfsm ext2, ext3, reiser,
etc.)
El adoptado por GNU/Linux es el Extended (v2, v3, v4)
Hace un tiempo se esta debatiendo el reemplazo de ext por
Btrfs (B-tree FS) de Oracle
Soporte de mayor tamano de archivos
Mas tolerante a fallas y comprobacion sin necesidad de
desmontar el FS
Idexacion
Snapshots
Compresion
Defragmentacion
Sistemas de archivos - Directorios mas importantes

Directorios mas importantes segun FHS (Filesystem Hierarchy


Standard)
/ Tope de la estructura de directorios. Es como el C:\
/home Se almacenan archivos de usuarios (Mis documentos)
/var Informacion que vara de tamano (logs, BD, spools)
/etc Archivos de configuracion
/bin Archivos binarios y ejecutables
/dev Enlace a dispositivos
/usr Aplicaciones de usuarios
Estructura basica del S.O. - Utilidades
Paquete de software que permite diferenciar una distribucion
de otra.
Editores de texto:
vi
emacs
joe
Herramientas de networking:
wireshark
tcpdump
Paquetes de oficina:
OpenOffice
Iterface graficas:
GNOME / CINNAMON
KDE
LXDE
Distribuciones

Una distribucion es una customizacion de GNU/Linux


formada por una version de kernel y determinados programas
con sus configuraciones2

2
http://www.linux.com/directory/Distributions
Organizacion fsica de discos
Organizacion fsica de discos (cont.)
Organizacion fsica de discos (cont.)
Conceptos para la instalacion - MBR

Sector reservado del disco fsico (cilindro 0, cabeza 0, sector 1)


Existe un MBR en todos los discos
Si existiese mas de un disco rgido en la maquina, solo un es
designado como Primary Master Disk
Conceptos para la instalacion - MBR (cont.)

El tamano del MBR coincide con el tamano estandar de


sector, 512 bytes:
Los primeros bytes corresponden al Master Boot Code (MBC)
A partir del byte 446 esta la tabla de particiones. Es de 64
bytes
Al final existen 2 bytes libres o para firmar el MBR
Es creado con algun utilitario
El MBC es un pequeno codigo que permite arrancar el SO
La ultima accion del BIOS es leer el MBC. Lo lleva a memoria
y lo ejecuta
Si se tiene un sistema instalado ! bootloader de MBC tpico.
Sino ! uno diferente (multietapa)
Conceptos para la instalacion - Particiones

Es una forma de dividir logicamente el disco fsico:


DOS y W95 no pueden manejar filesystems mayores a 2GB
Cada sistema operativo es instalado en una particion separada
Cada particion se formatea con un tipo de filesystem destino
(fat, ntfs, ext, etc.)
Es una buena practica separar los datos del usuario de la
aplicaciones y/o sistema operativo instalado
Tener una particion de restore de todo es sistema
Poder ubicar el Kernel en una particion de solo lectura, o una
que ni siquiera se monta (no esta disponible para los usuarios)
Particionar demasiado un disco puede tener desventajas:
pensar..!
Conceptos para la instalacion - Particiones (cont.)

Debido al tamano acotado en el MBR para la tabla de


particiones:
Se restringe a 4 la cantidad de particiones primarias
3 primarias y una extendida con sus respectivas particiones
logicas
Una de las 4 particiones puede ser extendida, la cual se
subdivide en volumenes logicos
Particion primaria: division cruda del disco (puede haber 4 por
disco). Se almacena informacion de la misma en el MBR
Particion extendida: sirve para contener unidades logicas en su
interior. Solo puede existir una particion de este tipo por
disco. No se define un tipo de FS directamente sobre ella
Particion logica: ocupa la totalidad o parte de la particion
extendida y se le define un tipo de FS. Las particiones de este
tipo se conectan como una lista enlazada
Conceptos para la instalacion - Particiones (cont.)

Como mnimo es necesario una particion (para el /)


Es recomendable crear al menos 2 (/ y SWAP)
Para crearlas, se utiliza software denominado particionador.
Existen 2 tipos:
Destructivos: permiten crear y eliminar particiones (fdisk)
No destructivo: permiten crear, eliminar y modificar particiones
(fips, gparted) generalmente las distribuciones permiten
hacerlo desde la interfaz de instalacion
Para que podramos crear otras particiones?
Conceptos para la instalacion - Particiones (cont.)

Como mnimo es necesario una particion (para el /)


Es recomendable crear al menos 2 (/ y SWAP)
Para crearlas, se utiliza software denominado particionador.
Existen 2 tipos:
Destructivos: permiten crear y eliminar particiones (fdisk)
No destructivo: permiten crear, eliminar y modificar particiones
(fips, gparted) generalmente las distribuciones permiten
hacerlo desde la interfaz de instalacion
Para que podramos crear otras particiones?
Nuestro ambiente de trabajo

Vamos a trabajar en un ambiente controlado ! VirtualBox


Necesitamos crear una maquina virtual y asignarle recursos
Booteamos la maquina virtual iniciando desde algun medio de
instalacion
Seguimos las instrucciones de instalacion
Verificamos que podamos arrancar el/los sistemas operativos
instalados
Particionado de discos

Particionando - 3 escenatios posibles:


Usar espacio libre no particionado
Usar particion no usada
Usar espacio libre de una particion actvia (mas complicado):
Cambio destructivo
Cambio no destructivo
En nuestra instalacion:
/dev/hda1: DOS con Wndows (2 GB) es mucho!
/dev/hda2: /boot ! 60 MB aproximadamente
/dev/hda3: / ! 6 GB aproximadamente
/dev/hda4: area de intercambio (SWAP)
Verificando la configuracion de nuestro disco

Desde Windows: utilizamos el administrador de discos


Desde DOS: usamos fdisk
Para instalar un nuevo SO necesitamos espacio libre sin
particionar
Si no lo tenemos, debemos generarlo. Para esto existen
diversos escenarios:
Eliminar una particion existente
Redimensionar una particion
Que ocurre en cada caso? Que software vamos a usar?
Emuladores/Virtualizadores

Para los fines de este curso, permiten virtualizar plataformas


Permite que en un equipo puedan correr varios SO en forma
simultanea compartiendo recursos de hardware
El pionero en esta tecnologa fue IBM con el IBM System/360
en los anos 1960
Emuladores/Virtualizadores (cont.)

Basicamente se pueden considerar 3 tipos:


Emulacion:
Emulan hardware
Tienen que implementar todas las instrucciones de la CPU
Es muy costosa y poco eficiente
Permite ejecutar arquitecturas diferentes a las soportadas por
el hardware
Virtualizacion completa:
Permiten ejecutar SO huespedes en un sistema anfitrion (host)
Utilizan en el medio un hypervisor o monitor de maquinas
virtuales
El SO huesped debe estar soportado en la arquitectura
anfitriona
Es mas eficiente que la emulacion (Intel-VT y AMD-V)
Paravirtualizacion:
Permite correr SOs modificados exclusivamente para actuar en
entornos virtualizados
Mayor eficiencia que la virtualizacion
Emuladores/Virtualizadores (cont.)

Las principales diferencias entre ellos son:


Los virtualizadores aprovechan el CPU sobre la que estan
trabajando, lo cual los hace mas veloces
En un emulador se puede correr cualquier arquitectura. En un
virtualizador solo se puede correr la arquitectura virtualizada
Gestor de arranque

La finalidad del bootloader es la de cargar una imagen de


Kernel (sistema operativo) de alguna particion para su
ejecucion
Se ejecuta luego del codigo del BIOS
Existen 2 modos de instalacion:
En el MBR (puede llegar a utilizar MBR gap)
En el sector de arranque de la particion raz o activa (Volume
Boot Record)
GRUB, LILO, NTLDR, GAG, YaST, etc.
Grub Legacy

GRand Unified Bootloader: gestor de arranque multiple mas


utilizado
En el MBR solo se encuentra la fase 1 del que solo se encarga
de cargar la fase 1.5
Fase 1.5: ubicada en los siguientes 30 KB del disco (MBR
gap). Carga la fase 2
Fase 2: interfaz de usuario y carga el Kernel seleccionado
Se configura a traves del archivo /boot/grub/menu.lst
Algunas lneas:
default: define el SO por defecto a bootear
timeout: tiempo de espera para cargar el SO por defecto
t i t l e D e b ia n GNU/ L i n u x
r o o t ( hd0 , 1 ) #( D i s c o , P a r t i c i o n )
k e r n e l / v m l i n u z 2 . 6 . 2 6 r o q u i e t r o o t =/dev / hda3
i n i t r d / i n i t r d 2 . 6 . 2 6 . img
Grub 2

Utilizado en la mayoria de las distribuciones


Dentro de sus mejoras, incluye el soporte a nuevas
arquitecturas, soporte de caracteres no ASCII, idiomas,
customizacion de menues, etc.
En Grub 2 la fase 1.5 ya no existe mas
El archivo de configuracion ahora es /boot/grub/grub.cfg y
no debera editarse manualmente ! update-grub
Mas informacion en:
https://help.ubuntu.com/community/Grub2
Proceso de arranque

Es el proceso de inicio de una maquina y carga del sistema


operativo y se denomina bootstrap
En las arquitecturas x86, el BIOS (Basic I/O System) es el
responsable de iniciar la carga del SO a traves del MBC:
Esta grabado en un chip (ROM, NVRAM)
En otras arquitecturas tambien existe, pero se lo conoce con
otro nombre:
Power on Reset + IPL en mainframe
OBP (OpenBoot PROM): en SPARC
Carga el programa de booteo (desde el MBR)
El gestor de arranque lanzado desde el MBC carga el Kernel:
Prueba y hace disponibles los dispositivos
Luego pasa el control al proceso init
El proceso de arranque se ve como una serie de pequenos
programas de ejecucion encadenada
Problemas del arranque basado en BIOS

Es de la decada del 80
La ultima accion del BIOS es leer el MBC del MBR
El firmware del BIOS no facilita la lectura de filesystems
El MBC no puede ocupar mas de 446 bytes
Por ejemplo Grub, utiliza los 446 bytes del MBR y luego utiliza
sectores del disco adyacentes que deberan estar libres (MBR
gap)
Extensible Firmware Interface

EFI: nexo entre el SO y el firmware


Utiliza el sistema GPT (GUID partition table) para solucionar
limitaciones del MBR, como la cantidad de particiones
GPT especifica la ubicacion y formato de la tabla de
particiones en un disco duro
Es parte de EFI. Puede verse como una sustitucion del MBR
La especificacion EFI es propiedad de Intel
GPT

Se mantiene un MBR para tener compatibilidad con el


esquema BIOS
GPT usa un modo de direccionamiento logico (logical block
addressing LBA) en lugar de cylinder-header-sector
El MBR heredado se almacena en el LBA 0
En el LBA 1 esta la cabecera GPT. La tabla de particiones en
s esta en los bloques sucesivos
La cabecera GPT y la tabla de particiones estan escritas al
principio y al final del disco (redundancia)
GPT (cont.)
Unified Extensible Firmware Interface

UEFI Forum
Alianza entre varias companias con el objetivo de modernizar
el proceso de arranque
Representantes de AMD, American Megatrends, Apple, HP,
Dell, IBM, Insyde Software, Intel, Lenovo, Microsoft, Phoenix
Technologies
EFI es propiedad de Intel
UEFI es propiedad del UEFI Forum
UEFI aporta criptografa, autenticacion de red y una interface
grafica
UEFI (cont.)

Define la ubicacion de gestor de arranque


Define la interfaz entre el gestor de arranque y el firmware
Expone informacion para los gestores de arranque con:
Informacion de hardware y configuracion del firmware
Punteros a rutinas que implementan los servicios que el
firmware ofrece a los bootloaders u otras aplicaciones UEFI
Provee un BootManager para cargar aplicaciones UEFI (e.j.:
Grub) y drivers desde un UEFI filesystem
El booloader ahora es un tipo de aplicacion UEFI:
El Grub sera una aplicacion UEFI, que reside en el UEFI
filesystem donde estan los drivers necesarios para arrancar el
sistema operativo (FAT32)
Para el Grub deja de ser necesario el arranque en varias etapas.
Secure Boot

Propone mecanismos para un arranque libre de codigo


malicioso
Las aplicaciones y drivers UEFI (imagenes UEFI) son
validadas para verificar que no fueron alteradas
Se utilizan pares de claves asimetricas
Se almacenan en el firmware una serie de claves publicas que
sirven para validar que las imagenes esten firmadas por un
proveedor autorizado
Si la clave privada esta vencida o fue revocada la verificacion
puede fallar
Preguntas?

También podría gustarte