세션 데이터 접근
GitLab의 세션 데이터는 Redis에 저장되며 다양한 방법으로 접근할 수 있습니다.
웹 요청 중에, 예를 들어:
- Rails는
ActionDispatch::Session
을 통해 컨트롤러 내에서 세션에 접근할 수 있도록 합니다. - 컨트롤러 외부에서는
Gitlab::Session
을 통해 세션에 접근할 수 있습니다.
웹 요청 외부에서도 Redis에 저장된 세션에 접근할 수 있습니다. 예를 들어:
- 세션 ID와 내용은 Redis에서 직접 조회할 수 있습니다.
- 세션과 관련된 UserAgent에 대한 데이터는
ActiveSession
을 통해 접근할 수 있습니다.
세션에 값을 저장할 때는 다음과 같은 점을 유의하는 것이 좋습니다:
- 간단한 기본형을 사용하고 마샬링 문제를 피하기 위해 객체 저장을 피하세요.
- 필요 없는 변수를 정리하여 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)