프로젝트 문제 해결

프로젝트 작업 중 다음과 같은 문제가 발생할 수 있으며, 특정 작업을 완료하기 위해 대체 방법이 필요할 수 있습니다.

Commit 데이터를 가져오는 동안 오류가 발생했습니다(An error occurred while fetching commit data)

프로젝트를 방문할 때 브라우저에서 광고 차단기를 사용하는 경우 An error occurred while fetching commit data라는 메시지가 표시될 수 있습니다. 이 경우 문제를 해결하려면 GitLab 인스턴스에 대한 광고 차단기를 비활성화해야 합니다.

SQL 쿼리를 사용하여 프로젝트 찾기

Rails 콘솔 세션에서 다음과 같이 SQL 쿼리를 기반으로 프로젝트의 배열을 찾고 저장할 수 있습니다.

# '%ject'로 끝나는 프로젝트 찾기
projects = Project.find_by_sql("SELECT * FROM projects WHERE name LIKE '%ject'")
=> [#<Project id:12 root/my-first-project>>, #<Project id:13 root/my-second-project>>]

프로젝트나 저장소 캐시 지우기

프로젝트나 저장소가 업데이트되었지만 상태가 UI에 반영되지 않는 경우, 프로젝트나 저장소의 캐시를 지워야 할 수 있습니다. 이를 Rails 콘솔 세션을 통해 다음과 같이 수행할 수 있습니다.

경고: 데이터를 변경하는 명령은 올바르게 실행되지 않거나 적절한 조건에서 실행되지 않을 경우 피해를 줄 수 있습니다. 항상 먼저 테스트 환경에서 명령을 실행하고 복구할 수 있는 백업 인스턴스가 준비되어 있는지 확인하세요.

## 프로젝트 캐시 지우기
ProjectCacheWorker.perform_async(project.id)

## 저장소 .exists? 캐시 지우기
project.repository.expire_exists_cache

삭제 대기 중인 프로젝트 찾기

아직 삭제되지 않았지만 삭제 예정으로 표시된 모든 프로젝트를 찾으려면 Rails 콘솔 세션을 시작하고 다음을 실행하세요.

projects = Project.where(pending_delete: true)
projects.each do |p|
  puts "프로젝트 ID: #{p.id}"
  puts "프로젝트 이름: #{p.name}"
  puts "저장소 경로: #{p.repository.full_path}"
end

콘솔을 사용하여 프로젝트 삭제

프로젝트를 삭제할 수 없는 경우 Rails 콘솔을 통해 삭제를 시도할 수 있습니다.

경고: 데이터를 변경하는 명령은 올바르게 실행되지 않거나 적절한 조건에서 실행되지 않을 경우 피해를 줄 수 있습니다. 항상 먼저 테스트 환경에서 명령을 실행하고 복구할 수 있는 백업 인스턴스가 준비되어 있는지 확인하세요.

project = Project.find_by_full_path('<project_path>')
user = User.find_by_username('<username>')
ProjectDestroyWorker.new.perform(project.id, user.id, {})

만약 실패한다면, 이유를 표시할 수 있습니다.

project = Project.find_by_full_path('<project_path>')
project.delete_error

그룹 내 모든 프로젝트에 대한 기능 전환

프로젝트에서 특정 기능을 전환하는 것은 프로젝트 API를 통해 수행할 수 있지만, 대량의 프로젝트에 대해 수행해야 하는 경우가 있을 수 있습니다.

특정 기능을 전환하려면 Rails 콘솔 세션을 시작하고 다음 함수를 실행하세요.

경고: 데이터를 변경하는 명령은 올바르게 실행되지 않거나 적절한 조건에서 실행되지 않을 경우 피해를 줄 수 있습니다. 항상 먼저 테스트 환경에서 명령을 실행하고 복구할 수 있는 백업 인스턴스가 준비되어 있는지 확인하세요.

projects = Group.find_by_name('_group_name').projects
projects.each do |p|
  ## 적절한 기능 이름으로 <feature-name>을 대체하세요
  state = p.<feature-name>

  if state != 0
    puts "#{p.name}에는 이미 <feature-name>이(가) 활성화되어 있습니다. 건너뛰는 중..."
  else
    puts "#{p.name}에는 <feature-name>이(가) 활성화되어 있지 않습니다. 활성화 중..."
    p.project_feature.update!(<feature-name>: ProjectFeature::PRIVATE)
  end
end

전환할 수 있는 기능을 찾으려면 pp p.project_feature를 실행하세요. 사용 가능한 권한 수준은 concerns/featurable.rb에 나열되어 있습니다.