Skip to content

Commit

Permalink
Added setup sub-command Documentation and README.md Updates
Browse files Browse the repository at this point in the history
  • Loading branch information
dev4unet committed Dec 5, 2024
1 parent 9259b27 commit ac14f48
Show file tree
Hide file tree
Showing 6 changed files with 132 additions and 8 deletions.
2 changes: 1 addition & 1 deletion Dockerfile_src
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
FROM amd64/golang:1.23-alpine

# 컨테이너 내의 작업 디렉토리 설정(RUN / CMD / ENTRYPOINT 명령이 실행될 기본 경로)
WORKDIR /go/src/github.com/cloud-barista/cb-mayfly
WORKDIR /go/src/github.com/cloud-barista/cm-mayfly
COPY . ./
RUN go mod download

Expand Down
17 changes: 10 additions & 7 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,8 @@ This management tool provides and is expected to provide the following features:


## Pre-Install
- [Install Go](https://golang.org/doc/install)
- [Install Go](https://golang.org/doc/install)
- Optional and only necessary if you want to run or build the source code.
- [Install Docker Engine on Ubuntu](https://docs.docker.com/engine/install/ubuntu/)


Expand All @@ -54,7 +55,7 @@ cm-mayfly$ make clean


# How to use CM-Mayfly
For now, it supports docker / rest / api sub-commands.
For now, it supports infra / rest / api / setup / tool sub-commands.

Use the -h option at the end of the sub-command requiring assistance, or executing 'mayfly' without any options will display the help manual.

Expand All @@ -70,6 +71,7 @@ Available Commands:
help Help about any command
infra Installing and managing cloud-migrator's infrastructure
rest rest api call
setup Support for Additional Tasks After Container Setup
tool Provides additional functions for managing Docker Compose or the Cloud-Migrator system.
Flags:
Expand All @@ -79,15 +81,16 @@ Use "mayfly [command] --help" for more information about a command.
```

For more detailed explanations, see the articles below.
- [infra sub-command guide](https://github.com/cloud-barista/cm-mayfly/blob/main/docs/cb-mayfly-docker-compose-mode.md)
- [rest sub-command guide](https://github.com/cloud-barista/cm-mayfly/blob/main/docs/cb-mayfly-rest.md)
- [api sub-command guide](https://github.com/cloud-barista/cm-mayfly/blob/main/docs/cb-mayfly-api.md)
- [infra sub-command guide](https://github.com/cloud-barista/cm-mayfly/blob/main/docs/cm-mayfly-docker-compose-mode.md)
- [setup sub-command guide](https://github.com/cloud-barista/cm-mayfly/blob/main/docs/cm-mayfly-setup.md)
- [rest sub-command guide](https://github.com/cloud-barista/cm-mayfly/blob/main/docs/cm-mayfly-rest.md)
- [api sub-command guide](https://github.com/cloud-barista/cm-mayfly/blob/main/docs/cm-mayfly-api.md)


# How to Build a Cloud-Migrator Infrastructure
`A quick guide` on how to easily build a Cloud-Migrator infrastructure.
If you need a more detailed explanation, check out the article below.
- [infra sub-command guide](https://github.com/cloud-barista/cm-mayfly/blob/main/docs/cb-mayfly-docker-compose-mode.md)
- [infra sub-command guide](https://github.com/cloud-barista/cm-mayfly/blob/main/docs/cm-mayfly-docker-compose-mode.md)


## Pre-Install
Expand Down Expand Up @@ -344,7 +347,7 @@ Flags:
Use "mayfly api [command] --help" for more information about a command.
```
For more information, see the [API Sub Command Guide](https://github.com/cloud-barista/cm-mayfly/blob/main/docs/cb-mayfly-api.md).
For more information, see the [API Sub Command Guide](https://github.com/cloud-barista/cm-mayfly/blob/main/docs/cm-mayfly-api.md).
Expand Down
File renamed without changes.
File renamed without changes.
File renamed without changes.
121 changes: 121 additions & 0 deletions docs/cm-mayfly-setup.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,121 @@

## setup 명령 사용 가이드

`setup` 서브 커맨드는 Cloud-Migrator 시스템 설치(구축) 이후 설정을 보조하기 위해 가볍게 제공되는 기능으로서 이 가이드에서는 `cm-mayfly``setup` 서브 커맨드를 이용하여 Cloud-Migrator 시스템에 특정 CSP의 Credential 정보 및 공통 리소스를 등록하는 방법에 대해 소개합니다.


## 순서
1. setup 명령 기능
1. Credential 등록 방법
1. 공통 리소스 등록 방법


## setup 명령 기능
Cloud-Migrator 시스템을 이용하기 위해서는 사용하려는 CSP의 Credential 정보와 공통 리소스 등록이 필요합니다.

이를 위해 cb-tumblebug에서는 [init script](https://github.com/cloud-barista/cb-tumblebug/tree/main/init)를 제공하며 setup 커맨드의 credential 커맨드가 init script에서 진행하는 Credential 등록 기능과 동일합니다.


```
$ ./mayfly setup
Supports installation tasks for specific containers after setting up the Cloud-migrator's infrastructure.
Usage:
mayfly setup [flags]
mayfly setup [command]
Available Commands:
credential Registration of CSP-Specific Credentials and Default Resources
Flags:
-h, --help help for setup
Use "mayfly setup [command] --help" for more information about a command.
```


## Credential 등록 방법

cb-tumblebug에서 제공하는 `공개키 기반의 암호화 방식`으로 `CSP의 Credential 정보를 등록`합니다.
자세한 사용 방법은 `-h` 옵션을 입력하면 `세부 flag`를 살펴 볼 수 있으며, 보통은 `./conf/api.yaml` 설정 파일을 이용해서 기본 정보를 사용하기 때문에 `단순히 credential 커맨드만 입력`하면 필요한 절차를 실행합니다.

현재 지원되는 세부 기능은 아래와 같습니다.
```
$ ./mayfly setup credential -h
Supports the registration of CSP credentials and initial data
The basic information of the subsystem is utilized from the api.yaml file, but the user can change the API authentication information including host and port.
Usage:
mayfly setup credential [flags]
Flags:
--authToken string sets the auth token of the 'Authorization' header for all HTTP requests.(The default auth scheme is 'Bearer')
-c, --config string config file (default "./conf/api.yaml")
--csp string The cloud service provider (CSP) to register
-H, --header strings Pass custom header(s) to server
-h, --help help for credential
--host string The server address where Tumblebug is running (Default: localhost) (default "localhost")
-p, --password string Password for basic authentication
--port string The port number Tumblebug is using (Default: 1323) (default "1323")
-u, --user string Username for basic authentication
-v, --verbose Show more detail information
```

아무런 옵션 없이 credential 명령만 실행하면 등록 가능한 CSP 목록을 조회해서 선택할 수 있도록 Guide 하며, 선택된 CSP에 맞는 입력 값을 요청합니다.

```
$ ./mayfly setup credential
```

또는 --csp 플래그를 이용해서 특정 CSP를 직접 지정할 수 있습니다.
```
./mayfly setup credential --csp aws
```

*[주의] 비밀키 등 민감한 정보의 경우 입력된 Key값이 노출되지 않도록 콘솔에 입력된 정보가 출력되지 않도록 했기 때문에 `절대로 입력 도중 Ctrl+C 키를 누르면 안됩니다.`*

**실행 예시**
```
./mayfly setup credential
Configuration file[./conf/api.yaml] processing...
Configuration file[./conf/api.yaml] processed.
Tumblebug Base URL : http://localhost:1323/tumblebug
Available CSPs:
1. alibaba
2. aws
3. azure
4. gcp
5. ibm
6. ktcloud
7. ktcloudvpc
8. ncp
9. ncpvpc
10. nhncloud
11. openstack
12. tencent
0. Exit
Please select a CSP by number: 2
Processing authentication information for selected [aws] CSP
Retrieving credential input format for aws
Successfully retrieved credential meta information for aws
Please enter ClientId:
Please enter ClientSecret:
Do you want to review the entered credentials? (yes/no): no
Is this correct? (yes/no/retry): yes
```



## 공통 리소스 등록 방법
사용하려는 CSP들의 Credential 정보가 등록되었으면 `cb-tumblebug에서 제공하는 loadassets Rest API를 호출`하면 cb-tumblebug 자체에 존재하는 로컬 파일 기반으로 필요한 공통 리소스 정보가 등록됩니다.
cm-mayfly 에서는 `api 서브 커맨드`를 제공하므로 api 커맨드를 이용해서 손쉽게 호출 가능합니다.

```
$ ./mayfly api -s cb-tumblebug -a loadassets
```

`api 서브 커맨드`에 대한 보다 자세한 내용은 [api sub-command guide](https://github.com/cloud-barista/cm-mayfly/blob/main/docs/cm-mayfly-api.md) 문서를 살펴 보시기 바랍니다.


0 comments on commit ac14f48

Please sign in to comment.