Go back

Setup and installation of 'Salt-Stack DevOps Automation Powered by Semaphore UI' on AWS

This section describes how to launch and connect to ‘Salt-Stack DevOps Automation Powered by Semaphore UI’ VM solution on AWS.




  1. Open Salt-Stack DevOps Automation Powered by Semaphore UI VM listing on AWS marketplace

/img/aws/saltstack-semaphore/marketplace.png

  1. Click on View purchase options.
  • Login with your credentials and follow the instruction.
  • Subscribe to the product and click on Continue to configuration button.
  • Select a Region where you want to launch the VM(such as US East (N.Virginia))

/img/aws/saltstack-semaphore/region.png

  • Click on Continue to Launch Button.
  • Choose Action: You can launch it through EC2 or from Website.(Let’s choose Launch from website)

/img/aws/saltstack-semaphore/launch.png

  • Optionally change the EC2 instance type. (This defaults to t2.medium instance type, 2 vCPUs and 4 GB RAM.)
  • Optionally change the network name and subnetwork names.

/img/aws/minikube/vpc.png

  • Select the Security Group. Be sure that whichever Security Group you specify have ports 22 (for SSH), 3389 (for RDP) and 443 (for HTTPS) exposed. Or you can create the new SG by clicking on “Create New Based On Seller Settings” button. Provide the name and description and save the SG for this instance.

/img/aws/desktop-linux-ubuntu2404/create-new-sg.png

/img/aws/saltstack-semaphore/SG.png

  • Be sure to download the key-pair which is available by default, or you can create the new key-pair and download it. /img/aws/minikube/key-pair.png

  • Click on Launch..

  • Salt-Stack DevOps Automation Powered by Semaphore UI will begin deploying.

  1. A summary page displays. To see this instance on EC2 Console click on EC2 Console link.

/img/aws/saltstack-semaphore/deployed.png

  1. To connect to this instance through putty, copy the IPv4 Public IP Address from the VM’s details page.

/img/aws/saltstack-semaphore/public-ip.png

  1. Open putty, paste the IP address and browse your private key you downloaded while deploying the VM, by going to SSH->Auth->Credentials, click on Open. Enter ubuntu as userid

/img/aws/desktop-linux/putty-01.png

/img/aws/nvidia-aiml/putty-02.png

/img/aws/saltstack-semaphore/ssh-login.png

  1. Once connected, change the password for ubuntu user using below command
sudo passwd ubuntu

/img/aws/saltstack-semaphore/ssh.png

  1. Now the password for ubuntu user is set, you can connect to the VM’s desktop environment from any local Windows Machine using RDP protocol or Linux Machine using Remmina.

From your local windows machine, goto “start” menu, in the search box type and select “Remote desktop connection”. In the “Remote Desktop connection” wizard, copy the public IP address and click connect

/img/aws/desktop-linux/rdp.png

  1. This will connect you to the VM’s desktop environment. Provide the username “ubuntu” and the password set in the above “Reset password” step to authenticate. Click OK

/img/aws/desktop-linux/rdp-login.png

  1. Now you are connected to the out of box Salt-Stack DevOps Automation Powered by Semaphore UI VM’s desktop environment via Windows Machine.

/img/azure/nacos/rdp-desktop.png

  1. To connect using RDP via Linux machine, first note the external IP of the VM from VM details page,then from your local Linux machine, goto menu, in the search box type and select “Remmina”.

Note: If you don’t have Remmina installed on your Linux machine, first Install Remmina as per your linux distribution.

/img/gcp/common/remmina-search.png

  1. In the “Remmina Remote Desktop Client” wizard, select the RDP option from dropdown and paste the external ip and click enter.

/img/gcp/common/remmina-external-ip.png

  1. This will connect you to the VM’s desktop environment. Provide “ubuntu” as the userid and the password set in above reset password step to authenticate. Click OK

/img/gcp/common/remmina-rdp-login.png

  1. Now you are connected to out of box Salt-Stack DevOps Automation Powered by Semaphore UI VM’s desktop environment via Linux machine.

/img/azure/nacos/rdp-desktop.png

  1. To access the Semaphore Web Interface, first reset semaphore admin password by running below command in the SSH terminal -
semaphore user change-by-login --login admin --password NEWPASSWORD --config /home/ubuntu/semaphore/config.json

Replace NEWPASSWORD with your desired password in above command.

/img/gcp/saltstack-semaphore/update-password.png

  1. Once Semaphore password is ready, copy the public ip of the vm from VM’s details page and paste it in the browser using https://VM_Public_IP. Make sure to use https and not http.

/img/aws/saltstack-semaphore/public-ip.png

Browser will display a SSL certificate warning message. Accept the certificate warning and Continue.

/img/gcp/saltstack-semaphore/browser-warning.png

  1. Login with admin user and provide the password set in above step.

/img/gcp/saltstack-semaphore/semaphore-login-page.png

  1. Now you are logged in to Semaphore Web Interface where you can manage salt-stack automation task.

/img/gcp/saltstack-semaphore/semaphore-homepage.png

  1. The VM comes with various Salt models preconfigured out of the box for you. The Salt Configuration files are located at /etc/salt directory. You can access these files and folders from SSH or RDP sessions.

/img/gcp/saltstack-semaphore/salt-directory.png

salt-master

  • salt-master is the central server in the SaltStack architecture. It manages communication with Salt minions (client machines), orchestrates tasks, and executes commands or states across the infrastructure.

salt-minion

  • salt-minion is the client component in the SaltStack architecture. It runs on managed systems (servers, virtual machines, etc.) and communicates with the Salt-Master to receive instructions, execute commands, and return results.

salt-cloud

  • salt-cloud is a component of SaltStack that manages cloud infrastructure. It allows you to automate the creation, configuration, and destruction of virtual machines (VMs) across multiple cloud providers like AWS, Google Cloud, Azure, and others.

salt-api

  • salt-api is an interface that allows external applications and services to interact with a Salt-Master via a RESTful API. It provides programmatic access to Salt’s capabilities.

salt-proxy

  • Salt-Proxy is a component in SaltStack used to manage devices or systems that cannot run the standard Salt Minion due to limitations, such as network devices, IoT devices, or certain appliances.

salt-syndic

  • Salt-Syndic is a component of SaltStack used in large-scale environments to create a multi-tiered Salt architecture. It acts as an intermediary between a Salt-Master and multiple Salt-Masters (or other syndics).

salt-ssh

  • salt-ssh is a mode of operation in SaltStack that allows you to manage and automate remote systems using SSH instead of the typical Salt-Master/Minion setup.

salt-roster

  • salt-roster is a configuration file in SaltStack used in conjunction with Salt-SSH. It defines the list of target systems (or minions) that Salt-SSH will manage, including connection details such as hostnames, IP addresses, and user credentials for SSH access.

salt-pki

  • salt-pki (Public Key Infrastructure) is a system in SaltStack used to manage the security keys and certificates that facilitate secure communication between Salt-Masters and Salt-Minions.
  1. Salt master base repository for salt sls files is /srv/salt.

/img/gcp/saltstack-semaphore/salt-master-directory.png

  1. Semaphore config directory is /home/ubuntu/semaphore.

/img/gcp/saltstack-semaphore/semaphore-config-directory.png


If you want to further configure SaltStack then please visit Configuring SaltStack page.

For more details on SaltStack or Semaphore please refer to Official Documentation Page

Go back