Cintillo Institucional
Diferencias entre las revisiones 1 y 2
Versión 1 con fecha 2008-07-28 14:22:19
Tamaño: 12116
Editor: eparedes
Comentario:
Versión 2 con fecha 2008-07-28 14:23:15
Tamaño: 10825
Editor: eparedes
Comentario:
Los textos eliminados se marcan así. Los textos añadidos se marcan así.
Línea 1: Línea 1:
===Sistema para el control de versiones: SVN===
== Sistema para el control de versiones: SVN ==
Línea 5: Línea 4:
El control de versiones permiten a un grupo de desarrollo, colaborar de manera organizada, evitando solapamiento de las modificaciones en los archivos, y mantener históricos de modificaciones. Acopia todos los archivos en versiones de forma centralizada, permitiendo el trabajo de cada colaborador en sus propias copias de trabajo.  El control de versiones permiten a un grupo de desarrollo, colaborar de manera organizada, evitando solapamiento de las modificaciones en los archivos, y mantener históricos de modificaciones. Acopia todos los archivos en versiones de forma centralizada, permitiendo el trabajo de cada colaborador en sus propias copias de trabajo.
Línea 24: Línea 23:
En la Fundación Cenditel esta instalado un servidor para la administración de los proyectos el cual brinda entre sus servicios un control de versiones por medio de la herramienta SVN.  En la Fundación Cenditel esta instalado un servidor para la administración de los proyectos el cual brinda entre sus servicios un control de versiones por medio de la herramienta SVN.
Línea 32: Línea 31:
Línea 35: Línea 33:

Línea 39: Línea 35:

Línea 43: Línea 37:

Línea 47: Línea 39:

Línea 53: Línea 43:

Línea 57: Línea 45:

Línea 61: Línea 47:

Línea 65: Línea 49:

Línea 69: Línea 51:

Línea 73: Línea 53:

Línea 77: Línea 55:
        ServerName svn.sitioweb.ext

       
ServerAdmin correo@sitioweb.ext

       
DocumentRoot /var/local/www/repositorio

       
<Directory /var/local/www/repositorio>

               
Options Indexes +Multiviews -FollowSymLinks

              
IndexOptions FancyIndexing \

                               
ScanHTMLTitles \

                             
NameWidth=* \

                             
DescriptionWidth=* \

                             
SuppressLastModified \

                             
SuppressSize

              
Order allow,deny

               
allow from all

       
</Directory>

       
AddDefaultCharset UTF-8

       
DirectoryIndex index.html

       
# Subversion host configuration

       
<Location /repositorio>

               
ErrorDocument 404 default

              
GforgeSysPath /var/local/www/repositorio

              
GforgeGroupsRoot /

              
GforgeAnonClause "groups.enable_anonscm >= '1'"

              
GforgeReadClause "cvs_flags >= '0'"

              
GforgeWriteClause "cvs_flags >= '1'"

               
DAV svn

               
SVNParentPath /var/lib/gforge/svnroot

               
SVNAutoversioning on

               
#SVNAutoversioning off

               
SVNIndexXSLT /svnindex.xsl

              
AuthType basic

              
AuthName "Subversion User Authentication"

              
#AuthUserFile /etc/apache2/dav_svn.passwd



               
Auth_PG_host 127.0.0.1

               
Auth_PG_database db_nombre

               
Auth_PG_port 5432

               
Auth_PG_user db_usuario



               
Auth_PG_pwd clavedeacceso

               
Auth_PG_pwd_table tablausuarios

               
Auth_PG_pwd_field campodepassword

               
Auth_PG_uid_field campodelogin



               
Auth_PG_encrypted on

               
Auth_PG_hash_type MD5

               
Auth_PG_authoritative on

               
#Satisfy Any

               
Require valid-user

                php_flag engine off

       
</Location>

       
ErrorLog /var/local/log/svn.fsl-error.log

       
CustomLog /var/local/log/svn.fsl-access.log combined

       
ServerSignature Off

       
#Seguridad
 . ServerName svn.sitioweb.ext
 ServerAdmin correo@sitioweb.ext
 DocumentRoot /var/local/www/repositorio
 <Directory /var/local/www/repositorio>
  . Options Indexes +Multiviews -FollowSymLinks
  IndexOptions FancyIndexing \
   . ScanHTMLTitles \
   NameWidth=* \
   DescriptionWidth=* \
   SuppressLastModified \
   SuppressSize
  . Order allow,deny
   . allow from all
 </Directory>
 AddDefaultCharset UTF-8
 DirectoryIndex index.html # Subversion host configuration
 <Location /repositorio>
  . ErrorDocument 404 default
  GforgeSysPath /var/local/www/repositorio
  GforgeGroupsRoot /
  GforgeAnonClause "groups.enable_anonscm >= '1'"
  GforgeReadClause "cvs_flags >= '0'"
  GforgeWriteClause "cvs_flags >= '1'" DAV svn SVNParentPath /var/lib/gforge/svnroot SVNAutoversioning on #SVNAutoversioning off SVNIndexXSLT /svnindex.xsl
  AuthType basic
  AuthName "Subversion User Authentication"
  #AuthUserFile /etc/apache2/dav_svn.passwd Auth_PG_host 127.0.0.1 Auth_PG_database db_nombre Auth_PG_port 5432 Auth_PG_user db_usuario Auth_PG_pwd clavedeacceso Auth_PG_pwd_table tablausuarios Auth_PG_pwd_field campodepassword Auth_PG_uid_field campodelogin Auth_PG_encrypted on Auth_PG_hash_type MD5 Auth_PG_authoritative on #Satisfy Any Require valid-user php_flag engine off
</Location>
 ErrorLog /var/local/log/svn.fsl-error.log
 CustomLog /var/local/log/svn.fsl-access.log combined
 ServerSignature Off #Seguridad
Línea 191: Línea 92:


       #SSLCertificateFile /etc/apache2/ssl/test/clave.svn2.pem

       
#SSLCACertificateFile /etc/apache2/ssl/test/svn2.crt



 . #SSLCertificateFile /etc/apache2/ssl/test/clave.svn2.pem #SSLCACertificateFile /etc/apache2/ssl/test/svn2.crt
Línea 203: Línea 96:



Línea 209: Línea 98:

Línea 213: Línea 100:

Línea 217: Línea 102:



Línea 223: Línea 104:


svn ckeckout [[http://svn.sitioweb.ext/repositorio|http://svn.sitioweb.ext/repositorio]] [destino]

svn ckeckout http://svn.sitioweb.ext/repositorio [destino]
Línea 231: Línea 108:



Línea 237: Línea 110:

Línea 241: Línea 112:

Línea 245: Línea 114:

Línea 249: Línea 116:

Línea 253: Línea 118:

Línea 257: Línea 120:

Línea 261: Línea 122:

Línea 265: Línea 124:


[[
http://rapidsvn.tigris.org/issues/show_bug.cgi?id=505|http://rapidsvn.tigris.org/issues/show_bug.cgi?id=505]]

http://rapidsvn.tigris.org/issues/show_bug.cgi?id=505
Línea 273: Línea 128:

Línea 277: Línea 130:

Línea 281: Línea 132:

Línea 285: Línea 134:

Línea 289: Línea 136:

Línea 293: Línea 138:

Línea 297: Línea 140:

Línea 301: Línea 142:

Línea 305: Línea 144:



Línea 311: Línea 146:

Línea 315: Línea 148:

Línea 319: Línea 150:


{{attachment:gráficos1.png}}

{{attachment:gráficos1.png|gráficos1.png}}
Línea 327: Línea 154:

Línea 331: Línea 156:


{{attachment:gráficos2.png}}

{{attachment:gráficos2.png|gráficos2.png}}
Línea 339: Línea 160:
[[http://svn.fsl.cenditel.gob.ve/svn/pdsl|http://svn.fsl.cenditel.gob.ve/svn/pdsl]]

http://svn.fsl.cenditel.gob.ve/svn/pdsl
Línea 345: Línea 164:

Línea 349: Línea 166:

Línea 353: Línea 168:

Línea 357: Línea 170:

Línea 361: Línea 172:

Línea 365: Línea 174:

Línea 369: Línea 176:

Línea 373: Línea 178:

Línea 379: Línea 182:

Línea 383: Línea 184:

Línea 387: Línea 186:

Línea 391: Línea 188:

Línea 395: Línea 190:

Línea 399: Línea 192:



Línea 405: Línea 194:

Línea 409: Línea 196:

Línea 413: Línea 198:



Línea 419: Línea 200:


{{attachment:gráficos3.png}}
{{attachment:gráficos3.png|gráficos3.png}}
Línea 425: Línea 204:

Línea 429: Línea 206:

Línea 433: Línea 208:
{{attachment:gráficos4.png}}





























{{attachment:gráficos4.png|gráficos4.png}}
Línea 467: Línea 212:


{{attachment:gráficos5.png}}
{{attachment:gráficos5.png|gráficos5.png}}

Sistema para el control de versiones: SVN

Introducción.

El control de versiones permiten a un grupo de desarrollo, colaborar de manera organizada, evitando solapamiento de las modificaciones en los archivos, y mantener históricos de modificaciones. Acopia todos los archivos en versiones de forma centralizada, permitiendo el trabajo de cada colaborador en sus propias copias de trabajo.

SVN: Es software libre bajo una licencia de tipo Apache/BSD y se lo conoce también como Subversion. Proviene del muy utilizado CVS, pero con muchas ventajas. Una característica importante de Subversion es que, a diferencia de CVS, los archivos versionados no tienen cada uno un número de revisión independiente. En cambio, todo el repositorio tiene un único número de versión que identifica un estado común de todos los archivos del repositorio en cierto punto del tiempo.

Ventajas:

  • Se sigue la historia de los archivos y directorios a través de copias y renombrados.
  • Las modificaciones (incluyendo cambios a varios archivos) son atómicas.
  • La creación de ramas y etiquetas es una operación más eficiente.
  • Se envían sólo las diferencias en ambas direcciones, no todo el archivo.
  • Puede ser servido, mediante Apache, sobre WebDAV/DeltaV. Esto permite que clientes WebDAV utilicen Subversion en forma transparente.
  • Maneja eficientemente archivos binarios, no los trata como texto.
  • Permite selectivamente el bloqueo de archivos. Se usa en archivos binarios que, al no poder fusionarse fácilmente, conviene que no sean editados por más de una persona a la vez.
  • Cuando se usa integrado a Apache permite la autenticación por medio de Sql, ldap, Ssl.

Servidores de SVN

Existen a la disposición de los grupos de desarrollo, dentro de la Internet sitios web que permiten alojar proyectos de desarrollo colaborativo y que ofrecen dentro de sus servicios, repositorios para alojar las versiones de los archivos, por ejemplo SourceForge, Berlios, tigris, o uno dce los mas recientemente utilizados como lo son GoogleCode, etc.

En la Fundación Cenditel esta instalado un servidor para la administración de los proyectos el cual brinda entre sus servicios un control de versiones por medio de la herramienta SVN.

Creación de un servidor SVN

El sistema para el control de versiones Subversion, esta en los repositorios de las principales distribuciones para el sistema operativo Linux, por lo que teniendo una conexión a internet, y configurando una conexión con dichos repositorios, por ejemplo en Debian, modificando el archivo que se source.list que se encuentra ubicado en el directorio: /etc/apt/ podemos realizar la instalación para conformar nuestro servidor:

previamente instalamos apache

aptitude install apache

ahora si instalamos el svn:

aptitude install subversion

No se presenta mayor configuración, simplemente utilizamos el comando para crear el repositorio, que incluirá en él su tronco principal y sus ramas, ejecutando el comando:

cd /var/local/www

svnadmin create reposito

podemos subir inicialmente en él el contendio de algun directorio para que contenga la carga inicial, recuerde que los desarrolladores trabajan en su copia de trabajo en sus computadores y luego sincronizarán con el repositorio central.

Para la carga del repositorio en su fase inicial su utiliza el comando:

svn import [origen] http://svn.sitioweb.ext/repositorio

Observer que el acceso es por medio de una dirección URL, ya que se utiliza la potencialidad de la red internet para poder accesar a este, con lo cual previamente en el servidor debe estar instalado un servicio web, el mas comunmente utilizado es el apache y para el cual se debe configurar un virtual host, es de libre elección la autenticación por medio de busqueda de los usuarios en una base de datos, o por medio de una herramienta como webdav o ldap, o por el medio mas simple que es con password ubicados en un archivo.

se presenta a continuación un ejemplo de como podria configurar un virtual host:

<VirtualHost *>

# SSLEngine on

# SSLCertificateFile /etc/apache2/ssl/test/svn.crt

# SSLCertificateKeyFile /etc/apache2/ssl/test/clave.svn2.pem

  • #SSLCertificateFile /etc/apache2/ssl/test/clave.svn2.pem #SSLCACertificateFile /etc/apache2/ssl/test/svn2.crt

</VirtualHost>

Este archivo debe estar en /etc/apache/site-available

y se debe habilitar por medio del comando:

a2ensite svn.sitioweb

Una vez habilitado el repositorio y asignado los permisos podemos realizar una copia de trabajo en nuestros computadores:

svn ckeckout http://svn.sitioweb.ext/repositorio [destino]

o por medio de las herramientas gráficas que se explican a continuación.

Clientes SVN

Los miembros del grupo de desarrollo, obtienen una copia para su trabajo (desarrollo y pruebas), lo cual denominamos clientes del repositorio, este puede ser sincronizado por medio de lineas de comando, o por medio de interfaz gráfica según el sistema operativo que se esta utilizando, entre los mas conocidos para usuarios de Debian, están: eSVN, RapidSVN, o los Plugin para herramientas para el desarrollo Eclipse; entre muchas otras.

Ejemplo para utilizar el RapidSVN, con un repositorio del servidor de la Fundación Cenditel, en el proyecto: “Plataforma para el Desarrollo de Software Libre".

Pasos preliminares:

Instalar el cliente desde los repositorios de Debian

aptitude install rapidsvn

para la traducción al castellano

obtenemos el archivo rapidsvn.po desde el sitio del proyecto:

http://rapidsvn.tigris.org/issues/show_bug.cgi?id=505

intalamos las heramientas gettext y poEdit

aptitude install gettext poEdit

Editamos y compilamos el archivo, (el poEdit al cerrar por configuración crea el archivo .mo)

ejecutamos la librería para incluirlo como lenguaje:

/var/lib/dpkg/info/rapidsvn.postinst rapidsvn.mo

Luego debemos crear un directorio en nuestra carpeta de usuario:

mkdir /home/usuario/directorio.

para nuestro ejemplo utilizaremos “pdsl“ por lo que se debe ejecutar:

mkdir /home/usuario/pdsl

Si utilizamos gnome podemos encontrar el acceso en el menú:

Aplicaciones >> Otros >> RapidSVN

Debe aparecer la siguiente interfaz gráfica:

[ANEXAR]

posteriormente se crea la copia de trabajo del repositorio central, en nuestro computador. En el RapidSVN, accedamos a la opción:

Repositorio >> Comprobación

[ANEXAR]

Colocamos en la URL:

http://svn.fsl.cenditel.gob.ve/svn/pdsl

y en el Directorio del destino:

/home/usuario/pdsl

aceptar los cambios y obsevar que la ejecución y mensajes de resultados aparece en la parte inferior de la herramienta, si no hay ningún problema observamos que en el árbol de marcadores aparece nuestro repositorio, con todas sus ramas y el tronco principal.

Interfaz Gráfica para buscar las diferencias entre el repositorio original y la copia de trabajo:

Instalar el meld:

aptitude install meld

Configurarlo en las preferencias del RapidSVN

Ver >> Preferencias

y en la pestaña Programas de la ventana emergente

colocar las direcciones donde se encuentran los ejecutables de los programas de preferencia que se utilizarán:

Editor Estandar

/home/usuario/Komodo/bin/komodo

nuestro caso utilizaremos OpenKomodo

y para el la herramienta Diff (para encontrar las diferencias entre las versiones)

/usr/bin/meld

Ya odemos editar nuestra copia de trabajo y subir las modificaciones versionadas al nuestro repositorio en el Gforge de la Fundación Cenditel.

Para la edición ubicamos el archivo que queremos trabajar o modificar, un vez ubicado y colocados sobre él, se presiona F3 o por medio del menú desplegable, que se abre con el boton derecho elegimos la primera opción Editar.

Observe que se abre la herramienta OpenKomodo previamente seleccionada en las preferencias.

Guardamos los cambios y podemos observar el cambio de estatus en el RapidSvn, colocando la etiqueta modificado. Este es una de las grades ventajas de utilizar esas herramientas de acceso gráfico, más que las lineas de comando.

[ANEXAR]

Luego de la edición podemos utilizar la herramienta de comparación para buscar las diferencias:

Ubicado el archivo con el botón derecho del mouse abrir el menú desplegable y utilizar la opción Diff...

Esta opción apertura la herramienta Meld que en dos columnas nos muestra la difrencias entre dos versiones del mismo archivo la actual y la seleccionada.

[ANEXAR]

Luego de seleccionar la revisión observamos las diferencias entre las dos columnas o ventanas de la herramienta: línea a línea.

[ANEXAR]

De esta forma podemos utilizar de forma correcta las herramientas que se encuentran a disposición y que facilitan el desarrollo colaborativo.

pdslsvnmanual (última edición 2008-07-28 15:38:26 efectuada por eparedes)