티스토리 뷰
[Hyperledger Fabric v1.1] 4. Operations Guides: Securing Communication With Transport Layer Security (TLS)
miiingo 2018. 5. 28. 19:46해당 글은 Hyperledger Fabric 페이지의 게시글을 번역 및 정리한 자료입니다.
원본 사이트 : http://hyperledger-fabric.readthedocs.io/en/release-1.1/enable_tls.html
Securing Communication With Transport Layer Security (TLS)
패브릭은 TLS를 사용하는 노드 간의 보안 통신을 지원합니다. TLS 통신은 단방향 (서버 만) 및 양방향 (서버 및 클라이언트) 인증을 모두 사용할 수 있습니다.
Configuring TLS for peers nodes
피어 노드는 TLS 서버와 TLS 클라이언트입니다. 다른 피어 노드, 응용 프로그램 또는 CLI가 다른 피어 노드 또는 순서 지정자와 연결될 때 다른 피어 노드, 응용 프로그램 또는 CLI가 이 노드에 연결하고 후자를 피어 노드로 연결하면 전자가 됩니다.
피어 노드에서 TLS를 사용하도록 설정하려면 다음 피어 구성 속성을 설정하십시오.
peer.tls.enabled
=true
peer.tls.cert.file
= TLS 서버 인증서가 포함 된 파일의 정규화 된 경로peer.tls.key.file
= TLS 서버 개인 키가 들어있는 파일의 정규화 된 경로peer.tls.rootcert.file
= TLS 서버 인증서를 발급한 인증 기관(CA)의 인증서 체인을 포함하는 파일의 정규화 된 경로
기본적으로 TLS 클라이언트 인증은 피어 노드에서 TLS를 사용하도록 설정하면 해제됩니다. 즉, 피어 노드는 TLS 핸드 셰이크 중에 클라이언트 (다른 피어 노드, 응용 프로그램 또는 CLI)의 인증서를 확인하지 않습니다. 피어 노드에서 TLS 클라이언트 인증을 사용하려면 피어 구성 속성 peer.tls.clientAuthRequired
를 true
로 설정하고 peer.tls.clientRootCAs.files
속성을 조직의 클라이언트에 대해 TLS 인증서를 발급한 CA 인증서 체인이 포함 된 CA 체인 파일로 설정합니다.
기본적으로 피어 노드는 TLS 서버 및 클라이언트로 작동 할 때 동일한 인증서 및 개인 키 쌍을 사용합니다. 클라이언트 측에 대해 다른 인증서와 개인 키 쌍을 사용하려면 peer.tls.clientCert.file
및 peer.tls.clientKey.file
구성 등록 정보를 각각 클라이언트 인증서와 키 파일의 정규화된 경로로 설정하십시오.
클라이언트 인증을 사용하는 TLS는 다음 환경 변수를 설정하여 활성화 할 수도 있습니다.
CORE_PEER_TLS_ENABLED
=true
CORE_PEER_TLS_CERT_FILE
= 서버 인증서의 정규화 된 경로CORE_PEER_TLS_KEY_FILE
= 서버 개인 키의 정규화 된 경로CORE_PEER_TLS_ROOTCERT_FILE
= CA 체인 파일의 정규화 된 경로CORE_PEER_TLS_CLIENTAUTHREQUIRED
=true
CORE_PEER_TLS_CLIENTROOTCAS_FILES
= CA 체인 파일의 정규화 된 경로CORE_PEER_TLS_CLIENTCERT_FILE
= 클라이언트 인증서의 정규화 된 경로CORE_PEER_TLS_CLIENTKEY_FILE
= 클라이언트 키의 정규화 된 경로
클라이언트 인증이 피어 노드에서 활성화되면 클라이언트는 TLS 핸드 셰이크 중에 인증서를 보내야합니다. 클라이언트가 인증서를 보내지 않으면 핸드 셰이크가 실패하고 피어는 연결을 닫습니다.
피어가 채널에 조인하면 채널 구성원의 루트 CA 인증서 체인이 채널의 config 블록에서 읽히고 TLS 클라이언트 및 서버 루트 CA 데이터 구조에 추가됩니다. 따라서 피어 투 피어 통신, 피어 투 발주자 통신은 매끄럽게 작동해야합니다.
Configuring TLS for orderer nodes
orderer 노드에서 TLS를 사용하려면 다음 orderer 구성 등록 정보를 설정하십시오.
General.TLS.Enabled
=true
General.TLS.PrivateKey
= 서버 개인용 키가 들어있는 파일의 완전한 경로General.TLS.Certificate
= 서버 인증서를 포함하는 파일의 정규화 된 경로General.TLS.RootCAs
= TLS 서버 인증서를 발급 한 CA의 인증서 체인을 포함하는 파일의 정규화 된 경로
기본적으로 TLS 클라이언트 인증은 피어의 경우와 마찬가지로 orderer에서 해제됩니다. TLS 클라이언트 인증을 사용하려면 다음 구성 등록 정보를 설정하십시오.
General.TLS.ClientAuthRequired
=true
General.TLS.ClientRootCAs
= TLS 서버 인증서를 발급 한 CA의 인증서 체인을 포함하는 파일의 정규화 된 경로
클라이언트 인증을 사용하는 TLS는 다음 환경 변수를 설정하여 활성화 할 수도 있습니다.
ORDERER_GENERAL_TLS_ENABLED
=true
ORDERER_GENERAL_TLS_PRIVATEKEY
= 서버 개인용 키가 들어있는 파일의 완전한 경로ORDERER_GENERAL_TLS_CERTIFICATE
= 서버 인증서를 포함하는 파일의 정규화 된 경로ORDERER_GENERAL_TLS_ROOTCAS
= TLS 서버 인증서를 발급 한 CA의 인증서 체인을 포함하는 파일의 정규화 된 경로ORDERER_GENERAL_TLS_CLIENTAUTHREQUIRED
=true
ORDERER_GENERAL_TLS_CLIENTROOTCAS
= TLS 서버 인증서를 발급 한 CA의 인증서 체인을 포함하는 파일의 정규화 된 경로
Configuring TLS for the peer CLI
TLS 사용 가능 피어 노드에 대해 피어 CLI 명령을 실행하는 경우 다음 환경 변수를 설정해야합니다.
CORE_PEER_TLS_ENABLED
=true
CORE_PEER_TLS_ROOTCERT_FILE
= TLS 서버 인증서를 발급한 CA의 인증서 체인을 포함하는 파일의 정규화 된 경로
원격 서버에서 TLS 클라이언트 인증을 사용하는 경우 위의 변수 외에 다음 변수를 설정해야합니다.
CORE_PEER_TLS_CLIENTAUTHREQUIRED
=true
CORE_PEER_TLS_CLIENTCERT_FILE
= 클라이언트 인증서의 정규화 된 경로CORE_PEER_TLS_CLIENTKEY_FILE
= 클라이언트 개인 키의 완전한 경로
피어 채널 <create | update | fetch> 또는 피어 체인 코드 <invoke | instantiate> 와 같이 orderer 서비스에 연결하는 명령을 실행하는 경우 주문자에서 TLS를 사용하는 경우 다음 명령 줄 인수도 지정해야합니다.
- -tls
- -cafile <orderer의 인증 코드 체인을 포함하는 파일의 완전한 경로 CA>
TLS 클라이언트 인증이 orderer에 대해 사용 가능한 경우 다음 인수도 지정해야합니다.
- -clientauth
- -keyfile <클라이언트 개인 키가 들어있는 파일의 완전한 경로>
- -certfile <클라이언트 인증서가 들어있는 파일의 전체 경로>
Debugging TLS issues
TLS 문제를 디버깅하기 전에 TLS 클라이언트와 서버 측 모두에서 GRPC debug
를 활성화 하여 추가 정보를 얻는 것이 좋습니다. GRPC debug
를 사용하려면 CORE_LOGGING_GRPC
환경 변수를 DEBUG
로 설정하십시오.
클라이언트 쪽에서 remote error: tls: bad certificate
오류 메시지가 표시 되면 일반적으로 TLS 서버에서 클라이언트 인증을 사용하고 서버가 올바른 클라이언트 인증서를 받지 못했거나 신뢰할 수없는 클라이언트 인증서를 받았다는 의미입니다. 클라이언트가 인증서를 보내고 피어 또는 orderer 노드가 신뢰하는 CA 인증서 중 하나가 서명했는지 확인하십시오.
체인 코드 로그에 remote error: tls: bad certificate
오류 메시지가 표시되면 Fabric v1.1 이상에서 제공되는 체인 코드 심을 사용하여 체인 코드가 빌드되었는지 확인하십시오. chaincode에 shim의 판매자 된 사본이 없으면 chaincode 컨테이너를 삭제하고 해당 피어를 다시 시작하면 현재 shim 버전을 사용하여 chaincode 컨테이너를 다시 작성합니다. 체인 코드가 이전 버전의 shim을 제공했다면, vend -vendored-shim 을 업그레이드 하는 방법에 대한 문서를 검토하십시오.
'Blockchain > Hyperledger Fabric' 카테고리의 다른 글
- Total
- Today
- Yesterday
- 빅데이터
- 빅데이터 교육
- 블록 체인
- Hyperledger Fabric v1.2
- 알고리즘
- 직딩잇템
- docker
- 코테
- Hyperledger Indy
- 블록체인
- 문제풀이
- codility
- 어서와 데이터는 처음이지
- ambrosus
- 하이퍼레저 페브릭
- javascript
- Private Data
- DOCs
- 빅데이터 강의
- 하이퍼레저 패브릭
- 코딩테스트
- 암브로셔스
- 하이퍼레저 인디
- Hyperledger Fabric v1.1
- Hyperledger Fabric
- 빅데이터 기초
- Blockchain
- 코딜리티
- ubuntu
- 기초 of 기초 데이터 개념
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |