News

[긴급] 레디스 DB 시스템에서 원격 코드 실행 취약점 발견... 소규모 기업 주의

imaginefuture-1 2024. 11. 20. 10:34

https://www.boannews.com/media/view.asp?idx=134444

 

[긴급] 레디스 DB 시스템에서 원격 코드 실행 취약점 발견... 소규모 기업 주의

오픈소스 기반의 비관계형 데이터베이스 관리 시스템 ‘Redis(레디스)’에서 원격 코드 실행 취약점(RCE)이 발견됐다. 악의적 코드 실행·데이터 탈취 및 서버 제어 위험이 있어 신속한 보안 업데

www.boannews.com

 

 

오 nosql db 시스템은 처음 본다 신기하네. 비관계형 데이터베이스 시스템

생각해보니 사진, 영상 같은 틀로 관리하기 어려운 것들은 어떻게 저장하나 싶었는데 이런게 있었구나

신기하다, 확실히 버퍼 오버플로우는..크흐흑. 고질적인 문제인 것 같다. 

canary나 pie나 relro나 nx 설정해서 패치하나? 궁금하네, 실무에서는 어떻게 프로그램을 패치하는지..궁금!

 

 

 

 

지피티야 이 뉴스에서. 프로그램에 스택오버플로우 취약점이 발견되면,
실무에서는 어떻게 대처해?
프로그램 소스코드내에 canary나 pie나 relro나 nx 설정해서 패치하나?
따로 스택오버플로우 방지하는 프로그램을 또 이용하나?

 

 

 

 

알겠습니다! **Redis** 데이터베이스 시스템에서 발견된 **원격 코드 실행 취약점**에 대한 내용이군요. 이와 관련하여 **스택 오버플로우**가 발생할 위험이 있다는 언급이 있었는데, 이를 해결하기 위한 **패치** 방법에 대해 설명드리겠습니다.

### **Redis의 원격 코드 실행 취약점**
Redis는 오픈 소스 **키-값 저장소**로, 주로 캐시나 데이터베이스로 사용됩니다. 최근 Redis에서 **스택 오버플로우** 취약점이 발견되었고, 이를 악용하면 **원격 코드 실행**(Remote Code Execution, RCE)이 가능해질 수 있습니다. 이는 공격자가 Redis 서버에 원격으로 악성 코드를 실행시킬 수 있는 심각한 보안 위협입니다.

### **스택 오버플로우 취약점**
스택 오버플로우는 **버퍼 크기**를 초과하여 데이터를 스택에 쓰는 것을 말합니다. 이로 인해 공격자는 스택에 악성 코드를 삽입하고 이를 실행할 수 있습니다. Redis와 같은 시스템에서 **원격 코드 실행** 취약점이 발생할 수 있습니다. 이는 **외부에서 네트워크를 통해 악성 데이터를 전송**해 Redis 서버의 취약한 코드 경로를 타고 스택 오버플로우를 유발하는 방식으로 이루어집니다.

### **실무에서 대처 방법**

1. **패치 적용**
   - 취약점이 발견되었을 경우, Redis 개발팀에서는 **패치**를 통해 해당 취약점을 수정합니다. 이 패치는 **스택 오버플로우**가 발생하지 않도록 코드를 수정하거나, **입력 검증**을 강화하여 악성 코드 실행을 방지합니다.
   - Redis는 **보안 업데이트**를 정기적으로 배포하므로, 해당 취약점에 대한 패치를 적용하는 것이 우선적입니다. 패치가 제공되면 시스템 관리자들은 즉시 해당 버전으로 **업데이트** 해야 합니다.

2. **보안 설정 강화**
   - Redis는 기본적으로 **보안 기능**이 약한 부분이 있기 때문에, 취약점이 발견되면 추가적인 보안 설정이 필요합니다.
   - **비밀번호 설정**: Redis는 기본적으로 비밀번호가 설정되어 있지 않으므로, 보안 설정에서 `requirepass` 옵션을 활성화하여 비밀번호를 요구하도록 설정할 수 있습니다.
   - **접근 제어**: Redis는 외부에서 접근할 수 있는 포트를 열어두기 때문에, `bind`와 `protected-mode` 설정을 사용하여 접근을 제어할 수 있습니다. 예를 들어, `protected-mode yes`를 설정하면 외부에서 Redis 서버에 접근하는 것이 제한됩니다.
   
3. **Memory Protection Features 활성화**
   - **NX 비트**(No Execute Bit)와 같은 **메모리 보호 기능**을 활성화하여 **데이터 영역**에 악성 코드가 실행되지 않도록 할 수 있습니다. 이는 **스택 오버플로우**가 일어나더라도 악성 코드가 실행되지 않도록 도와줍니다.
   
4. **Redis를 방화벽 뒤에 두기**
   - Redis 서버는 **인터넷에 직접 노출되지 않도록** 방화벽 뒤에 배치해야 합니다. 가능하다면 **VPC(Virtual Private Cloud)** 또는 **내부 네트워크**에 Redis를 두고, 외부에서 접근할 수 없도록 설정해야 합니다.
   
5. **정기적인 보안 점검과 모니터링**
   - **정기적인 보안 점검**을 통해 취약점이 없는지 확인하고, **로그 모니터링**을 통해 Redis 서버에서 발생하는 비정상적인 동작을 실시간으로 감지해야 합니다.
   - 취약점이 발견되면 **즉시 패치**하거나, 우회적인 방법으로 공격이 발생하지 않도록 설정을 강화해야 합니다.

### **스택 오버플로우 방지를 위한 기술적 대처 방법**
- **Canary**나 **PIE** (Position Independent Executable), **RELRO**와 같은 기법들이 서버 애플리케이션에서 **버퍼 오버플로우**를 방지하는 데 유용하지만, Redis와 같은 시스템에서는 보안 기능을 강화하고 코드가 외부 입력을 신뢰하지 않도록 하는 **입력 검증**이 중요합니다.
- Redis의 경우, **메모리 할당** 및 **입력 데이터 검증**을 강화하는 것도 중요한 대처 방법입니다. 

### 결론
Redis에서 **스택 오버플로우** 취약점이 발견되면, 실무에서는 **패치**를 통해 취약점을 수정하는 것이 가장 우선적인 대응입니다. 또한, Redis의 보안을 강화하기 위해 **접근 제어**, **패스워드 설정**, **방화벽** 등 기본적인 보안 설정을 강화하는 것이 필요합니다. 이와 함께 **NX 비트**, **PIE**, **RELRO**와 같은 메모리 보호 기능을 활성화하여 추가적인 보안을 확보할 수 있습니다.

 

 

신기하구만, 실무는 확실히 좀 더 넓고, 당연하겠지만 최대한 보안할 수 있는 모든 방법을 총 동원하는 것 같다

신기행!