Первые несколько ресурсов:
- Инструмент Clearvision CC2SVN
- SVN Importer от Polarion
- Статья и ресурсы в CollabNet
Размер реального хранилища, количество файлов или их размеры не являются ограничивающим фактором для SVN. Количество разработчиков, параллелизм изменений, сложность процесса интеграции и выпуска, необходимость слияния и управления версиями каталогов (рефакторинг) могут создавать проблемы для большого проекта. Если ваш проект просто большой, но он достаточно стабилен, с небольшим количеством разработчиков, небольшим количеством веток и не требует переноса множества исправлений в несколько предыдущих выпусков, SVN подойдет для вас.
Я написал специальный инструмент переноса данных, выводящий данные из ClearCase, и это не простая задача. Каждые две системы имеют разные модели данных и операции над данными. Я бы не советовал пытаться написать какой-либо пользовательский инструмент миграции, потому что на самом деле очень сложно получить данные из ClearCase любым значимым способом. Для получения подробной информации об ограничениях коммерческих решений я бы предложил связаться с поставщиками решений, указанными в ресурсах.
Лично я бы попытался собрать как можно больше данных, но вы должны знать об ограничениях SVN по сравнению с ClearCase. Любая история управления версиями (рефакторинг) каталога может быть потеряна во время этой миграции. SVN не поддерживает разреженные ветки, такие как ClearCase, что может привести к увеличению размера вашего SVN-хранилища, если вы используете ветки задач. В этом случае вы, вероятно, захотите ограничиться только системными ветками. Файлы в ClearCase имеют индивидуальную структуру ветвления, в то время как SVN имеет разновидности веток для каждого продукта, что приводит к значительному переводу ветвей в процессе. Ограничив себя системными ветками и, возможно, просто помеченной версией в этих ветвях для полностью интегрированных меток в серии, вы можете сэкономить много хлопот. Если ваша команда использует UCM, вы можете забыть все метаданные UCM. Они не будут переводиться в SVN.
Сроки зависят в основном от используемых инструментов. Для такого крупного проекта, как у вас, это может быть даже недели. У базы данных ClearCase по какой-то странной причине много блокировок даже при операциях чтения, и есть одна центральная таблица всего, что создает множество проблем при крупномасштабном доступе, которые может вызвать миграция. Когда я впервые запустил свой инструмент для продукта, несколько большего, чем у вас, мы рассчитали, что он будет работать в течение 3 лет, после значительной оптимизации, распараллеливания и постепенной миграции он сократился примерно до недели. Но ожидайте, что в зависимости от того, насколько хорошо инструмент сделан, может быть много различий во времени, которое требуется. Хотя, поскольку вы мигрируете в SVN и игнорируете большую часть истории и метаданных из ClearCase, ваша миграция должна быть намного быстрее.
ClearVision на своих страницах упоминает, что его инструмент CC2SVN может создать мост между двумя продуктами. Хотя я не использовал этот инструмент, если он работает так, как я предполагаю, он позволит вам синхронизировать 2 репозитория после некоторой обработки, что позволит вам переключиться на выходные с нулевым временем простоя разработки. Если это невозможно, попробуйте запросить какую-нибудь альтернативу, например, инкрементную миграцию, где вы сначала переносите до некоторой даты, а затем переносите меньший кусок данных, измененных с этой даты.
Очень важной частью этого процесса является фаза после миграции. Пожалуйста, не сбрасывайте со счетов головные боли, которые коммутатор принесет вашим разработчикам. Вы не должны недооценивать необходимость обучения и четкой документации. Вам также понадобится обученная группа поддержки в вашем отделе разработки программного обеспечения, способная управлять обеими системами SCM и объяснять разработчикам, как делать то, к чему они привыкли в новой системе. Это на самом деле точка, которая может сломать вам шею при миграции. Разработчики противостоят любым изменениям и любым преимуществам, которые SVN приносит проекту, по сути, это значительно уступает системе. ClearCase предоставляет вашим разработчикам такую гибкость, которой у них никогда не будет с SVN, и, если вы не включите их на раннем этапе процесса, вы можете потерять их или, что еще хуже, полностью перевернуть всю миграцию, объявить катастрофу и потерять свою работу. *