Manage & Maintain
How to: get access to EKS, get admin keys, read logs
Accessing EKS cluster
AWS Console
Step 1
Open AWS console -> Cloud Formation -> Stacks
Step 2
Make sure you're in the same region you chose in installation Step 3.
Step 3
Click the name (link like) of your top level stack, the one without the NESTED
badge.
Step 4
Open Outputs tab and copy the value of the EKSConstructClusterMasterRoleOutput***
, starting just after the role/
In the example from picture above the value which you should copy would be:
spv-wallet-EKSConstructEksMastersRole***3-J***t
Step 5
Open user menu at the right top corner and click Switch role
button
If you're setting role to switch for the first time, additional view will be displayed. All you need to do there is to click another Switch role
button
Step 6
Fill the form with:
Account - account number of your AWS account
Role - the role that you copied in Step 5
Display Name - whatever name meaningful for you (it will be listed later in the user menu)
After filling the form, click Switch Role
button. If everything is correct, you will be switched to that role (otherwise after clicking the button, it looks like nothing happend - so you need to fix the values provided in the form).
After switchin the role the user menu after clicking the role name at the top right should look like on the picture above.
Notice the role name and color of the badge at instead of user name.
If you want to switch back to your original role (which doesn't have permissions to access EKS but has different permissions) use the Switch back
button
Next time when you want to use this EKS Master Role, all you need to do is to open this menu again and click the role name on the Role history list.
Step 6
Navigate to Amazon Elastic Kubernetes Service (EKS)
Choose your active cluster.
Now in the tab Resources you can see all the pods, deployments, config maps that were created for you during the installation process.
Terminal (kubectl)
Step 1
Make sure you have AWS CLI installed and authenticated
Step 2
Make sure you have kubectl installed
Step 3
Now you need to obtain "update kubeconfig command" from outputs of the installed stack.
Step 3a
Open AWS console -> Cloud Formation -> Stacks
Step 3b
Make sure you're in the same region you chose in Step 3.
Step 3c
Click name of your top level stack, the one without the NESTED
badge. This should open the details of the stack.
Step 3d
Open Outputs
tab
Step 3e
Copy the aws eks update-kubeconfig
command from the EKSConstructClusterConfgi***
value.
Step 4
Issue copied command from the the previous step. It should look like this:
This will configure your kubectl context and use it, so just after issuing the command you should be able to use kubectl to manage your cluster.
If you have multiple kubectl contexts, you can also setup different name of the created context and of the created user configuration.
To do so, before you issue the coppied command, add those additional arguments to it:
--alias myContextName
- It will set the name of created context to the myContextName
--user-alias myUserConfigName
- it will set the name of created context config for user to the myUserConfigName
Step 5
Check if everything is configured properly configure by issueing any kubectl command, for example:
If everything is ok you should get the output like this:
Retrieving SPV Wallet Admin Keys
In order to maintain the application you may need to access the Admin Console using admin private key.
Also in case of developing own integration with SPV Wallet, it is common to have a need for authenticating as admin.
Admin keys are generated and stored in k8s secret during deployment by an automated script.
To retrieve it follow instructions below
Prerequisites
You need to have ability to Switch Role in AWS Console like in the instruction in the section AWS Console
Ensure that you switched the role to the "EKS Master" role.
Step 1
Navigate to Amazon Elastic Kubernetes Service (EKS) and choose your active cluster (click its name)
Step 2
Open Resources
tab.
Step 3
Choose Secrets
from the left menu
Step 4
Find spv-wallet-keys
on the list and click the name to see details
Step 5
Check the options to decode the values. And then you can copy admin xpriv and xpub values.
Retrieving Block Headers Service API key
In order to maintain or query Block Headers Service you may need to retrieve API key required for authentication within Block Headers Service. Below you can find instruction how to obtain this key.
Step 1
Navigate to Amazon Elastic Kubernetes Service (EKS) and choose your active cluster (click its name)
Step 2
Open Resources
tab.
Step 3
Choose Secrets
from the left menu
Step 4
Find block-headers-service-secret
on the list and click the name to see details
Step 5
Check the options to decode the values. And then you can copy value of block-headers-service-auth-token.
Accessing logs
Below you can find instructions how to access components logs.
We don't provide any integration with logs collectors / viewers, like Kibana or Cloud Watch. Although we're trying to output the logs in a format consumable by them, it is up to you to setup those tools correctly and collect the logs from the applications.
Prerequisites
You need to have kubectl installed and configured like in the instruction in the section Terminal (kubectl)
Step 1
First get the list of available deployments
It should output something like this:
Step 2
Now choose and copy the name from the list of the component you want to see the logs,
For example bsv-spv-wallet
Step 3
Issue the following command to get the logs of that component:
Where
${name} - is the deployment name you choose in Step 2
You can add the flag --follow
at the and of this command to follow the logs from the application.
Last updated