Microsoft MVP성태의 닷넷 이야기
windows 2008 r2에서 ms-sql 2008 서버사용시 tls문제점 [링크 복사], [링크+제목 복사],
조회: 26970
글쓴 사람
임종복 (limjongbok at hanafos.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

안녕하세요?
오랜만에 글을 써봅니다.
제목처럼 windows 2008 r2에서 ms-sql 2008 서버사용시 tls문제점이란 내용이며

windows 2008 r2의 tls1.0을 비활성화하면(통신 보안채널-schannel)
ms-sql 2008 서비스가 동작을 하지 않습니다.
(사용환경은 iis 7.5를 통한 asp.net 웹서비스를 제공하는 용도의 DB, 또한 https만 사용)

아래는 MSSQL 에러로그 내용입니다.

1. 인증서사용을 강제하지 않는 경우의 tls1.0 사용 여부의 경우

--> tls1.0을 활성화한 후 정상일경우
A self-generated certificate was successfully loaded for encryption.

--> tls1.0을 해제한 후 비정상일경우 : 오류발생
The server could not load the certificate it needs to initiate an SSL connection....

2. 인증서사용을 강제할 경우의 tls1.0 사용 여부의 경우

--> tls1.0을 활성화한 후 정상일경우
..The certificate [Cert Hash(sha1) "0D5.....BB84F572"] was successfully loaded for encryption.

--> tls1.0을 해제한 후 비정상일경우 : 오류발생
..Unable to load user-specified certificate [Cert Hash(sha1) "0D50F0F....BB84F572"]. The server will not accept a connection. You should verify that the certificate is correctly installed. See "Configuring Certificate for Use by SSL" in Books Online.

ㅇ 궁굼한 점
tls1.0을 사용하지 않고 MS-SQL 서비스를 작동하여 https(443)서비스를 할 수 있는 방법이 없을까요?

또한 MS에 문의를 해보니 별도의 기술지원이 필요한 것으로 질문에 대한 해결 여부또는 알려주지 않는군요

한해의 마지막 날인데 이것때문에 몇일밤을 고생하네요.
좋은 답변 부탁드립니다.


[연관 글]






[최초 등록일: ]
[최종 수정일: 12/31/2014]


비밀번호

댓글 작성자
 



2015-01-01 02시55분
좀 더 정보가 필요할 것 같습니다. 그러니까, 오류가 MSSQL과 IIS 간에 발생한다는 것인가요? 그리고, 인증서를 MSSQL 측에 설치했다는 것인가요? 해당 현상을 재현할 수 있도록 좀 더 자세한 절차를 기술해 주세요. ^^
정성태
2015-01-02 05시11분
[임종복] 1. 테스트 환경은
  - WINDOWS 2008 R2
  - iis 7.5에서 https 구성 : openssl 1.0.1j로 CA 인증서(AES256-SHA256 설정, tls1.2 충족) 및 서버 인증서 설정
  - MSSQL 2008 R2(openssl 인증서를 이용하여, 구성관리자>SQL네트워크구성>MSSQL서버에대한프로토콜>우클릭>속성>플래그>암호화적용:yes,인증서 선택)

2. 시험 목적
  - iis에서 tls1.2 보안채널만 활성화하여 웹서비스 가능
  - 클라이언트(사용자의 PC)에서 브라우저를 접근할 때 서버는 ssl/tls 보안채널 가운데 tls1.2(ssl 3.2)만 활성화 되어야 보안상 취약하지 않다고 합니다.

3. 오류 내용
  - 보안채널 가운데 tls1.0이 비활성화 되면 구성관리자(SQL 서버 서비스)의 기본 서비스가 시작되지 않음, 수동으로 시작하면 ssl 오류가 발생

4. 오류의 원인
  - MSSQL과 WINDOWS 2008간의 문제로 MSSQL 서비스가 시작되지 않으므로 웹서비스를 할 수 없음

5. 오류 설명
OS는 보안채널을 사용하는데
레지스트리(HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\SecurityProviders\SCHANNEL\Protocols\PCT 1.0 ..... TLS 1.2)에 채널 설정이 있습니다.
IIS에 https로 구성한 뒤 보안채널을 tls 1.2 만 사용가능 하게 한 후 OS를 재시작하게 되면 MSSQL의 기본 서비스가 기동이 안되는 현상입니다.

6. 오류 원인 유추
- MSSQL 서버 서비스는 Os 및 IIS의 보안채널을 기본적으로 공유하는 것 같습니다.
- 또한 MSSQL 서버 서비스는 기본적으로 TLS1.0 보안채널만 사용하는 것 같습니다.
- 그리고 TLS1.0 보안채널은 OS의 RDP 서비스와도 연관이 있으므로 TLS1.0을 비활성화(disable)하면 원격서비스가 중지됩니다.

7. 기타 참고
- TLS1.0을 비활성화하면서 MSSQL 서버 서비스를 기동시키는 방법은
 실행>gpedit.msc(로컬그룹정책편집기)>로컬그룹정책>컴퓨터구성>보안설정>로컬정책>보안옵션 선택 후 우측의
"시스템 암호화: 암호화, 해시 및 서명 알고리즘을 포함한 FIPS 140 호환 암호화 알고리즘 사용" 을 활성화

방법이 존재하나 이는 TLS1.0을 기본으로 사용하는 것 같고
또한 활성화하면 asp.net 프로그램에 영향을 주어 web.config를 수정하면서 조절해야하나
웹 기능이 정상적으로 작동하지 않습니다. (또한 사이트를 조사해보니 MS조차도 이를 권장하지 않는다...고 하네요)

환경설정에 도움이 되셨으면 하고
좋은 결과가 있으면 좋겠네요.
[guest]
2015-01-03 08시48분
문제 재현을 했고 제 경우에도 SQL 서버는 TLS 1.0 또는 SSL 3.0을 반드시 활성화시켜야만 정상 서비스가 되었습니다. 대신, IIS 서비스는 TLS 1.2를 강제하면서 SQL 서비스는 1.0으로 잘 동작하는 레지스트리 구성이 있는데... 그런 식으로 우회해야 하지 않을까 싶습니다. 이에 관해서는 다음의 정리된 글을 참고하세요.

System.Data.SqlClient는 SSL 3.0/TLS 1.0만 지원하는 듯!
; http://www.sysnet.pe.kr/2/0/1833

TLS 1.2를 적용한 IIS 웹 사이트 구성
; http://www.sysnet.pe.kr/2/0/1834

SQL 서버 역시 SSL 3.0/TLS 1.0만을 지원하는 듯!
; http://www.sysnet.pe.kr/2/0/1835

임종복 님의 상황이 지금 어떤지는 자세하게 알 수 없으나, "클라이언트(사용자의 PC)에서 브라우저를 접근할 때 서버는 ssl/tls 보안채널 가운데 tls1.2(ssl 3.2)만 활성화 되어야 보안상 취약하지 않다고 합니다."라는 점을 감안했을 때, 제가 제시한 방법이 나쁘진 않을 듯 싶습니다. 어차피 주요 보안 사항이 웹 서버와 브라우저 간이므로.
정성태

... 76  77  78  79  80  81  82  83  84  [85]  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
353정성태4/20/200617909    답변글 [답변]: 이번겨울방학때세도나를 여행하려구하는데요,,,
351오기4/18/200610711aspx [2]
350유지연4/17/200611461smartclient DB connection관련 질문 입니다. [2]파일 다운로드1
349선재빠4/17/200611463object tag를 2개 넣으면 IE가 죽어버리네요. [2]
347박찬용4/13/200611485COM+에 관한 질문입니다. [2]
345선재빠4/11/200612297Winform을 띄울 수 있는 방법이 있나요? [3]
344선재빠4/10/200613550ASP.NET 2.0에서는 VIEWASTEXT 이란 태그옵션을 지원하지 않는군요 [3]
343선재빠4/10/200612661아래와 같은 에러가 나네요.
341선재빠4/8/200612357테스트 페이지를 보면 프레임만 나오고 안에 내용이 나오지 않는군요 [1]
340김형태4/4/200611521파일서버 관련 질문드립니다.. (데브피아 답변에 이어) [2]
339조남정4/4/200611687post 주소 읽어오기 [1]
338장두헌4/4/200613290SDK PlatForm 다시 질문 - 데브피아의 내용 [1]
337강완모4/3/200613573Cab파일이 아닌 설치용 파일로 OCX들 설치하기... [1]
335비니3/23/200614513밑에 Smart Client에 대해서 질문했던 초보입니다.. TreeView컨트롤은 보이는데 안에 내용이 안보여요. [1]
336비니3/24/200612431    답변글 [재질문]:자꾸 죄송합니다...링크페이지로 이동을 안해요.... [1]
334비니3/23/200612130Smart Client강의 따라해보다가 xml에서 활성스키마는 <Tree>,<L> 요소는 지원하지 않는다고 나와요.ㅠㅠ [1]
332정준명3/21/200612180[자문자답] VS.NET에서 COM을 참조했는데, 강력한 서명이 없다고 사용불가네요.
333정성태3/22/200610706    답변글 [답변]: [자문자답] VS.NET에서 COM을 참조했는데, 강력한 서명이 없다고 사용불가네요. [1]
330심현철3/3/200613831[질문] VS2005에서 C#으로 개발한 DLL을 Javascript에서 접근할 수 없습니다. (ActiveX with C#) [2]
329권인성2/27/200612016스마트클라이언트(clickonce) 버전관리 [1]
327권인성2/24/200611635clickonce를 통해 설치 및 업데이트하려고 하는데요...보안때문에요..
331정성태3/12/200612709    답변글 [답변]: clickonce를 통해 설치 및 업데이트하려고 하는데요...보안때문에요..
325권인성2/23/200611219SETUP 및 배포관련 [1]
326권인성2/23/200610699    답변글 [답변]: 한가지만 더 질문할게요.... [1]
323정보문2/21/200611034메일 내용에서 한글이 깨집니다. [1]파일 다운로드1
321셈토2/18/200610855SPOOL --> EMF --> TEXTOUT [1]
... 76  77  78  79  80  81  82  83  84  [85]  86  87  88  89  90  ...