Назад | Перейти на главную страницу

SvnServe.exe потребляет 200+ МБ памяти

Я установил CollabNet Subversion Server 1.6.2.37639 на Windows Server 2003 R2 (Enterprise, x86) и, очевидно, настроил его для работы как службы. Я размещаю только один репозиторий, это svnsync зеркало другого (размещенного на другой машине). Служба работает хорошо, но через несколько дней после запуска она без видимой причины занимает более 200 МБ ОЗУ. Кроме того, трафик в репозиторий очень незначителен. Никаких сбоев не зарегистрировано, и утечки памяти не наблюдается, так как потребление памяти никогда не выходит за рамки этого значения.

Размер репозитория составляет около 194 МБ, а количество коммитов / проверок - примерно 10 в день.

Кажется, довольно много «потраченной впустую» памяти, которую можно было бы выделить, например, для кэша базы данных.

Кто-нибудь знает больше об этой проблеме и как ее решить? Я предполагаю, что это может быть какая-то форма кеширования данных, выполняемая svnserve.exe, но я не нашел никаких подсказок об этом в Интернете.

Вы, вероятно, захотите установить, сколько именно времени нужно, чтобы достичь этого уровня использования памяти. Является ли это чисто вопросом времени, или вы можете ускорить процесс, выполнив больше коммитов или выполнив больше проверок и т. Д. Утечки памяти редки, но возможны и обычно приводят к проблемам с производительностью. Эти проблемы будут проявляться в разных точках для разных конфигураций. Репозиторий работает медленнее после достижения 200 МБ?

В большинстве случаев память не «тратится зря». Задача операционной системы - управлять распределением памяти в целом, но некоторые приложения могут иметь свою собственную стратегию. В этом случае SVN может иметь кеш, но он также может выделять больше памяти, так что это непрерывное распределение памяти. Обычно ОС должна видеть нехватку памяти и использовать ряд эвристических методов, чтобы другие приложения продолжали нормально работать.

Что бы я попробовал:

  • Используйте системный монитор (perfmon.exe) для сбора различной статистики использования памяти и т. Д.
  • Просмотрите журнал для каждого репозитория, чтобы узнать, какие типы операций были выполнены.
  • Перезапуск службы и запуск большого количества проверок, коммитов и т. Д. С использованием автоматизированного сценария. Выполните каждое из этих действий независимо, прежде чем пытаться сочетать два типа операций. Это может быть менее применимо, если у вас есть только чистая реплика другого сервера Subversion.

Пара вопросов к вам ...

  • насколько велик ваш репозиторий Subversion?
  • сколько коммитов, проверок и обновлений в час, день, неделю?
  • Сколько трафика обрабатывает другая машина?

Я не особо разбираюсь в Windows, но похоже на кеширование или ваш репозиторий довольно большой, поэтому индексы, необходимые для его эффективной работы, классифицируются как "короткие" :) Есть ли способ, как в случае с Linux, увидеть, как память распределяется / используется для каждого процесса, возможно, через диспетчер задач или Монитор ресурсов?

Изменить: это действительно должен быть комментарий к вашему вопросу, но комментарии, похоже, совершенно испортить все форматирование, и я действительно хотел, чтобы вопросы были отмечены списком. :-)

Это # интересно - я не слышал о большом использовании памяти Svnserve в списках рассылки, возможно, вы захотите разместить там.