-
Notifications
You must be signed in to change notification settings - Fork 315
SODA core projects Local Cluster with Multi tenants Installation
Here is a tutorial guiding users and new contributors to get familiar with SODA Projects by installing a simple local cluster and managing lvm device. You can also use the ansible script to install automatically. See details in SODA Local Cluster Installation through ansible.
Before you start, please make sure you have all the following:
- Ubuntu environment (suggest v16.04 or v18.04).
- More than 30GB remaining disk.
- Make sure have access to the Internet.
- Some tools (
git
,make
andgcc
) prepared. - The HOST_IP environment variable has to be set to your local machine IP address
export HOST_IP={your_real_host_ip} echo $HOST_IP example: export HOST_IP=127.0.0.1
These are the projects provided to user: a) api b) controller c) dock d) Multi-Cloud(Gelato) e) Dashboard
First you need to download bootstrap script and run it locally with root access.
curl -sSL https://raw.githubusercontent.com/sodafoundation/installer/master/devsds/bootstrap.sh | sudo bash
If there is no error reported, you have all dependency packages installed.
git clone https://github.com/sodafoundation/installer.git $GOPATH/src/github.com/sodafoundation/installer
Because the default authentication strategy is noauth
, so if you want to enable multi-tenants feature or want to use Dashboard, please set the field OPENSDS_AUTH_STRATEGY=keystone
in local.conf file:
cd $GOPATH/src/github.com/sodafoundation/installer
vim devsds/local.conf
Don't be surprised, you could do it in one command:
cd $GOPATH/src/github.com/sodafoundation/installer && devsds/install.sh
If everything goes well, you will get some connection messages at the console output:
Execute commands below to set up ENVs which are needed by SODA CLI as well as Dashboard:
------------------------------------------------------------------
export OPENSDS_AUTH_STRATEGY=keystone
export OPENSDS_ENDPOINT=http://{your_real_host_ip}:50040
export OS_AUTH_URL=http://{your_real_host_ip}/identity
export OS_USERNAME=admin
export OS_PASSWORD=opensds@123
export OS_TENANT_NAME=admin
export OS_PROJECT_NAME=admin
export OS_USER_DOMAIN_ID=default
------------------------------------------------------------------
Enjoy it !!
Run command below to bootstrap multi-cloud.
curl -sSL https://raw.githubusercontent.com/sodafoundation/multi-cloud/master/script/bootstrap.sh | sudo bash
It will take a 10~15 minutes depending on the speed of your internet connection. After this docker and docker-compose which is needed by multi-cloud will be installed, and multi-cloud service will be started up too. If OPENSDS_AUTH_STRATEGY was set as keystone
, the script will create user, service, endpoint in keystone for multi-cloud automatically.
export HOST_IP={ your_host_ip }
docker run -d --net=host --name opensds-dashboard -e OPENSDS_AUTH_URL=http://$HOST_IP/identity -e OPENSDS_HOTPOT_URL=http://$HOST_IP:50040 -e OPENSDS_GELATO_URL=http://$HOST_IP:8089 opensdsio/dashboard:latest
Open your browser and input dashboard URL: http://$HOST_IP:8088 to enter OpenSDS dashboard. The following is the initial account for administrator user:
Username: admin
Password: opensds@123
We have provided CLI for SODA, if you simply want to test SODA api+controller+dock, and do not want to deploy dashboard, CLI is a good choice.
sudo cp $GOPATH/src/github.com/sodafoundation/api/build/out/bin/osdsctl /usr/local/bin
export OPENSDS_ENDPOINT=http://127.0.0.1:50040
export OPENSDS_AUTH_STRATEGY=noauth # Set the value to keystone for multi-tenants.
If you choose keystone for authentication strategy, you need to execute different commands for logging in as different roles:
- For admin role
export OPENSDS_AUTH_STRATEGY=keystone
export OPENSDS_ENDPOINT=http://localhost:50040
export OS_AUTH_URL=http://$HOST_IP/identity
export OS_USERNAME=admin
export OS_PASSWORD=opensds@123
export OS_TENANT_NAME=admin
export OS_PROJECT_NAME=admin
export OS_USER_DOMAIN_ID=default
NOTE: **Export HOST_IP env variable ex: export HOST_IP=127.0.0.1**
osdsctl volume create 1 --name=test-001
osdsctl volume list
osdsctl volume delete <your_volume_id>
It's also nice to uninstall the cluster with one command:
cd $GOPATH/src/github.com/sodafoundation/installer && devsds/uninstall.sh
If you want to destroy the cluster, please run the command below instead:
cd $GOPATH/src/github.com/sodafoundation/installer && devsds/uninstall.sh --purge
cd $GOPATH/src/github.com/sodafoundation/multi-cloud
docker-compose down
docker stop opensds-dashboard
docker rm opensds-dashboard
Hope you enjoyed it! Any suggestions are welcome.