Documente Academic
Documente Profesional
Documente Cultură
Gestión de configuración - 1
Gestión de configuración
Gestión de configuración - 2
Gestión de configuración
3. Conceptos generales
• Control de versiones
• Control de configuración
• Control de cambios
• Revisiones y variantes
• Repositorio
3.4 Variantes
• Configuraciones alternativas
Gestión de configuración - 3
Gestión de configuración
3.5 Repositorio
• Es un almacén general de versiones:
o Es habitual centralizar el almacenamiento de los componentes de un mismo
sistema, incluyendo las distintas versiones de cada componente. Este almacén
común se denomina REPOSITORIO
o El repositorio permite ahorrar espacio de almacenamiento, evitando guardar por
duplicado elementos comunes a varias versiones o configuraciones
o El repositorio facilita el almacenar información de la evolución del sistema
(historia), y no sólo de los componentes en sí
Gestión de configuración - 4
Gestión de configuración
4. Control de versiones
Como se ha dicho, se refiere a la evolución de un único componente. La evolución puede
representarse gráficamente en forma de grafo, en el que los nodos son las versiones y los
arcos corresponden a a creación de una nueva versión a partir de otra ya existente.
Esta forma de evolución no presenta problemas desde el punto de vista de organización del
repositorio. Las versiones se pueden designar simplemente mediante números correlativos,
como en la figura.
4.2 Variantes
Cuando hay variantes, es decir, cuando existen simultáneamente varias versiones del
componente, entonces el grafo de evolución ya no es una secuencia lineal, sino que adopta
la forma de un árbol. Si queremos seguir numerando las versiones se necesitará ahora una
numeración a dos niveles. El primer número designa la variante (línea de evolución), y el
segundo la versión particular (revisión) a lo largo de dicha variante.
La terminología usada para referirse a los elementos del grafo es la propia de un árbol:
• TRONCO (trunk): Es la variante principal, p.ej. 1.1-1.2...
• RAMAS (branches): Son las variantes secundarias, p.ej: 2.1..., 3.1...
Gestión de configuración - 5
Gestión de configuración
Gestión de configuración - 6
Gestión de configuración
Gestión de configuración - 7
Gestión de configuración
• Deltas inversos (RCS): Se almacena completa la última versión del tronco y los
cambios necesarios para reconstruir cada versión anterior a partir de la siguiente. En
las ramas se mantiene el uso de deltas directos.
Ventajas: Es menos costoso recuperar las últimas versiones que las primeras, pero
sólo en el tronco o rama principal.
Inconvenientes: En las otras ramas es más constoso recuperar las últimas versiones
que si se aplicaran sólo deltas directos.
• Marcado selectivo (SCCS): Se almacena el texto refundido de todas las versiones
como una secuencia lineal, marcando cada sección del conjunto con los números
de versiones a los que corresponde. Usando una notación simbólica tendríamos, por
ejemplo:
x x x x x
x x x x x
<<1.3,1.2
y y y y
>>
<<1.2
z z z z z z
z z z z z z
>>
x x x x x
<<1.3
t t t
>>
x x x x x
x x x x x
Ventajas: Cuesta lo mismo recuperar cualquier versión, tanto reciente como antigua
y de cualquier rama.
Inconvenientes: A medida que aumenta el número de versiones aumenta también el
costo de recuperar cualquier de ellas.
Gestión de configuración - 8
Gestión de configuración
Gestión de configuración - 9
Gestión de configuración
5. Control de configuración
Como se ha dicho antes, aplicaremos esta denominación al control de la evolución de un
conjunto de elementos.
• La evolución del sistema consiste en:
o Añadir componentes
o Suprimir componentes
o Modificar componentes
• Evolución temporal: revisiones
o Son cambios a lo largo del tiempo
• Evolución espacial: variantes
o Son versiones (configuraciones) simultáneas
Gestión de configuración - 10
Gestión de configuración
O bien, dibujando repetidas las versiones que se mantienen sin cambios en cada revisión
del conjunto:
Gestión de configuración - 11
Gestión de configuración
Como puede verse la numeración de las versiones individuales no tiene una relación sencilla
con la numeración de las versiones del conjunto. Hace falta mantener una tabla o índice
que asocie cada versión del conjunto con las versiones individuales de sus componentes.
Gestión de configuración - 12
Gestión de configuración
De esta manera se pueden nombrar de manera uniforme las versiones de los componentes
individuales, y el índice nos dará el nombre de la versión del componente que se habría
almacenado por separado mediante un sistema simple de control de versiones. Ejemplo:
B-X-3 # B 1.2
Gestión de configuración - 13
Gestión de configuración
Gestión de configuración - 14
Gestión de configuración
Gestión de configuración - 15
Gestión de configuración
Gestión de configuración - 16
Gestión de configuración
Gestión de configuración - 17
Gestión de configuración
Gestión de configuración - 18
Gestión de configuración
Gestión de configuración - 19
Gestión de configuración
Gestión de configuración - 20
Gestión de configuración
Gestión de configuración - 21
Gestión de configuración
7. Control de cambios
La ingeniería de software recomienda realizar el desarrollo de manera disciplinada. Las
herramientas de control de versiones no garantizan un desarrollo razonable si cualquier
miembro del equipo puede realizar los cambios que quiera e integrarlos en el repositorio
sin ningun tipo de control.
Gestión de configuración - 22
Gestión de configuración
Gestión de configuración - 23