Skip to content

Commit

Permalink
Merge pull request cloud-barista#1220 from innodreamer/master
Browse files Browse the repository at this point in the history
[NHN Cloud] Use VPC ID instead of VPC Name to get the first Subnet ID, and Add Notice of Internet Gateway Setting
  • Loading branch information
powerkimhub authored Jul 1, 2024
2 parents bf73df7 + e3b87f9 commit 789d606
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 10 deletions.
10 changes: 9 additions & 1 deletion cloud-control-manager/cloud-driver/drivers/nhncloud/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -134,11 +134,19 @@ ssh -i /private_key_파일_경로/private_key_파일명(~~.pem) cb-user@해당_V
- (주의) 이와 같이, u2 type의 VMSpec으로 생성된 VM의 MyImage를 이용해 신규 VM을 생성할 경우, 그 신규 VM도 u2 type의 VMSpec을 이용해야함.

​O NHN Cloud에서 Windows VM instance 생성을 위한 제약 조건으로 아래의 사항을 공지함.
- VM 생성시, Linux 계열 VM과 같이 KyePair를 지정해야하며, Windows VM 생성 완료 후 콘솔에서 그 KeyPair를 이용해서 default 미밀번호를 확인할 수 있음.
- 비밀번호 적용 및 확인 방법으로, 본 드라이버를 이용해서 Windows 계정 VM 생성시 비밀번호를 지정하여 생성 가능하며, 사용자 계정은 'cb-user'로 생성됨을 주의해야함.(Administrator 계정은 생성 불가)
- NHN Cloud에서 기본적으로 제공하는 방법으로서, Linux 계열 VM과 같이 VM 생성시 KyePair를 지정하고 Windows VM 생성 완료 후 콘솔에서 그 KeyPair를 이용해서 default 비밀번호를 확인할 수 있음.
- RAM이 최소 2GB 이상인 VMSpec 사용해야함.
- 50GB 이상의 루트 블록 스토리지 필요
- U2 type의 VMSpec은 Windows image를 사용할 수 없음.

​O Public IP를 통해 외부에서 VM과 통신하기 위해서는 VPC의 routing table에 Internet Gateway를 연결 후 사용해야함.
- REST API를 통해 Internet Gateway 정보 조회, 제어가 불가능하므로, VM의 public IP를 통해 외부 네트워크에서 VM에 접속하기 위해서 미리 콘솔에서 수작업으로 Internet Gateway를 생성하고 해당 VPC의 routing table에 연결해줘야함.
- NHN Cloud 웹 콘솔에서는 Internet Gateway 정보 조회 및 제어 기능을 지원하지만, REST API는 미지원하므로 웹 콘솔 UI를 통해서만 Internet Gateway 조회, 제어 가능

![image](https://github.com/cloud-barista/cb-spider/assets/51111668/c5fc39cf-5a0e-4f10-89d7-0c80c655dd9e)


​ O 본 드라이버를 통해 미국 region infra는 사용 불가
- 현재 한국 : 2개 region X 2개 zone, 일본 : 1개 region X 2개 zone 지원
- NHN Cloud에서 미국 region은 API endpoint를 제공하지 않으므로 미국 region은 console을 통해서만 사용 가능
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,7 @@ func (nlbHandler *NhnCloudNLBHandler) CreateNLB(nlbReqInfo irs.NLBInfo) (irs.NLB
return irs.NLBInfo{}, newErr
}

subnetId, err := nlbHandler.getFirstSubnetIdWithVPCName(nlbReqInfo.VpcIID.NameId)
subnetId, err := nlbHandler.getFirstSubnetIdWithVPCId(nlbReqInfo.VpcIID.NameId)
if err != nil {
newErr := fmt.Errorf("Failed to Get FirstSubnetId with VPC Name. : [%s]", err)
cblogger.Error(newErr.Error())
Expand Down Expand Up @@ -316,13 +316,13 @@ func (nlbHandler *NhnCloudNLBHandler) GetNLB(nlbIID irs.IID) (irs.NLBInfo, error
if len(nlbList) > 0 {
nlbInfo, err = nlbHandler.mappingNlbInfo(nlbList[0])
if err != nil {
newErr := fmt.Errorf("Failed to Get NLB Info from NHN NLB. : [%v]", err)
newErr := fmt.Errorf("Failed to Get NLB Info from NHN Cloud. : [%v]", err)
cblogger.Error(newErr.Error())
LoggingError(callLogInfo, newErr)
return irs.NLBInfo{}, newErr
}
} else {
newErr := fmt.Errorf("Failed to Get Any NLB Info. with the NLB ID!!")
newErr := fmt.Errorf("Failed to Get Any NLB Info with the NLB ID!!")
cblogger.Error(newErr.Error())
LoggingError(callLogInfo, newErr)
return irs.NLBInfo{}, newErr
Expand Down Expand Up @@ -960,24 +960,24 @@ func (nlbHandler *NhnCloudNLBHandler) getListenerInfo(listenerId string) (irs.Li
return listenerInfo, nil
}

func (nlbHandler *NhnCloudNLBHandler) getFirstSubnetIdWithVPCName(vpcName string) (subnetId string, err error) {
func (nlbHandler *NhnCloudNLBHandler) getFirstSubnetIdWithVPCId(vpcId string) (subnetId string, err error) {
cblogger.Info("NHN Cloud Driver: called getFirstSubnetIdWithVPCName()")
callLogInfo := getCallLogScheme(nlbHandler.RegionInfo.Region, "NETWORKLOADBALANCE", vpcName, "getFirstSubnetIdWithVPCName()")
callLogInfo := getCallLogScheme(nlbHandler.RegionInfo.Region, "NETWORKLOADBALANCE", vpcId, "getFirstSubnetIdWithVPCName()")

if strings.EqualFold(vpcName, "") {
newErr := fmt.Errorf("Invalid VPC Name required")
if strings.EqualFold(vpcId, "") {
newErr := fmt.Errorf("Invalid VPC ID required!!")
cblogger.Error(newErr.Error())
LoggingError(callLogInfo, newErr)
return "", newErr
}

callLogStart := call.Start()
listOpts := vpcs.ListOpts{
Name: vpcName,
ID: vpcId,
}
allPages, err := vpcs.List(nlbHandler.NetworkClient, listOpts).AllPages()
if err != nil {
newErr := fmt.Errorf("Failed to Get NHN VPC List with the Name : [%s]", vpcName)
newErr := fmt.Errorf("Failed to Get NHN VPC Info with the ID : [%s]", vpcId)
cblogger.Error(newErr.Error())
LoggingError(callLogInfo, newErr)
return "", newErr
Expand Down

0 comments on commit 789d606

Please sign in to comment.