세션 데이터 접근

GitLab의 세션 데이터는 Redis에 저장되며 다양한 방법으로 접근할 수 있습니다.

웹 요청 중에, 예를 들어:

  • Rails는 ActionDispatch::Session을 통해 컨트롤러 내에서 세션에 접근할 수 있도록 합니다.
  • 컨트롤러 외부에서는 Gitlab::Session을 통해 세션에 접근할 수 있습니다.

웹 요청 외부에서도 Redis에 저장된 세션에 접근할 수 있습니다. 예를 들어:

세션에 값을 저장할 때는 다음과 같은 점을 유의하는 것이 좋습니다:

  • 간단한 기본형을 사용하고 마샬링 문제를 피하기 위해 객체 저장을 피하세요.
  • 필요 없는 변수를 정리하여 Redis의 메모리 사용량을 줄이세요.

GitLab::Session

때때로 데이터베이스와 같은 다른 저장소 대신 세션에 데이터를 지속적으로 저장하고 싶을 때가 있습니다. Gitlab::Session은 세션을 광범위하게 전달하지 않고도 이를 접근할 수 있게 합니다. 예를 들어, 권한이 체크되는 각 장소에 세션을 전달할 필요 없이 정책 내에서 접근할 수 있습니다.

세션은 컨트롤러에서 사용할 때와 마찬가지로 해시와 유사한 인터페이스를 가지고 있습니다. 키-값 데이터를 해시에 저장하기 위한 NamespacedSessionStore도 있습니다.

# 현재 세션에 저장된 값 조회
Gitlab::Session.current[:my_feature]

# Redis에 저장된 현재 세션 수정
Gitlab::Session.current[:my_feature] = value

# 키 아래에 네임스페이스가 있는 키-값 데이터 저장
Gitlab::NamespacedSessionStore.new(:my_feature)[some_key] = value

# 코드 블록의 세션 설정, 예를 들어 테스트용
Gitlab::Session.with_session(my_feature: value) do
  # Session.current[:my_feature]를 사용하는 코드
end

Redis

세션 데이터는 Redis를 통해 직접 접근할 수 있습니다. 이는 디버깅 시 브라우저 세션을 확인하는 데 유용합니다.

# 세션 목록 가져오기
session_ids = Gitlab::Redis::Sessions.with do |redis|
  redis.smembers("#{Gitlab::Redis::Sessions::USER_SESSIONS_LOOKUP_NAMESPACE}:#{user.id}")
end

# 특정 세션 조회
session_data = Gitlab::Redis::Sessions.with { |redis| redis.get("#{Gitlab::Redis::Sessions::SESSION_NAMESPACE}:#{session_id}") }
Marshal.load(session_data)

ActiveSession을 사용하여 장치 정보 얻기

사용자 프로필의 활성 세션 페이지는 각 세션에 접근하는 데 사용된 장치에 대한 정보를 표시합니다. 세션을 나열하는 데 사용되는 메서드는 개발 시에도 유용할 수 있습니다.

# 특정 사용자에 대한 세션 목록 가져오기
# session_id와 UserAgent의 데이터를 포함합니다
ActiveSession.list(user)