It will ask you to enable the API’s if they are not enabled already for your account. Please click on enable as shown in the screenshot.
It will take you to the agreement page. On this page, you can change the project from the project selector on top navigator bar as shown in the below screenshot.
Accept the Terms and agreements by ticking the checkbox and clicking on the AGREE button.
It will show you the successfully agreed popup page. Click on Deploy.
On deployment page, give a name to your deployment.
In Deployment Service Account section, click on Existing radio button and Choose a service account from the Select a Service Account dropdown.
If you don't see any service account in dropdown, then change the radio button to New Account and create the new service account here.
If after selecting New Account option, you get below permission error message then please reach out to your GCP admin to create service account by following Step by step guide to create GCP Service Account and then refresh this deployment page once the service account is created, it should be available in the dropdown.
You are missing resourcemanager.projects.setIamPolicy permission, which is needed to set the required roles on the created Service Account
Select a zone where you want to launch the VM(such as us-east1-a)
Optionally change the number of cores and amount of memory. ( This defaults to 1 vCPUs and 3.75 GB RAM)
Optionally change the boot disk type and size. (This defaults to ‘Standard Persistent Disk’ and 30 GB respectively)
Optionally change the network name and subnetwork names. Be sure that whichever network you specify has ports 22 (for ssh), 3389 (for RDP) and 443 (for HTTPS) exposed.
Click Deploy when you are done.
Salt-Stack DevOps Automation Powered by Semaphore UI will begin deploying.
A summary page displays when the compute engine is successfully deployed. Click on the Instance link to go to the instance page .
On the instance page, click on the “SSH” button, select “Open in browser window”.
This will open SSH window in a browser. Switch to ubuntu user and navigate to ubuntu home directory.
sudo su ubuntu
cd /home/ubuntu/
Run below command to set the password for “ubuntu” user
sudo passwd ubuntu
Now the password for ubuntu user is set, you can connect to the VM’s desktop environment from any local windows machine using RDP or linux machine using Remmina.
To connect using RDP via Windows machine, first note the external IP of the VM from VM details page as highlighted below
Then From your local windows machine, goto “start” menu, in the search box type and select “Remote desktop connection”
In the “Remote Desktop connection” wizard, paste the external ip and click connect
This will connect you to the VM’s desktop environment. Provide “ubuntu” as the userid and the password set in step 6 to authenticate. Click OK
Now you are connected to out of box Salt-Stack DevOps Automation Powered by Semaphore UI VM’s desktop environment via Windows machines.
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.
In the “Remmina Remote Desktop Client” wizard, select the RDP option from dropdown and paste the external ip and click enter.
This will connect you to the VM’s desktop environment. Provide “ubuntu” as the userid and the password set in step 6 to authenticate. Click OK
Now you are connected to out of box Salt-Stack DevOps Automation Powered by Semaphore UI VM’s desktop environment via Linux machine.
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.
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.
Browser will display a SSL certificate warning message. Accept the certificate warning and Continue.
Login with admin user and provide the password set in above step 17.
Now you are logged in to Semaphore Web Interface where you can manage salt-stack automation task.
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.
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.
Salt master base repository for salt sls files is /srv/salt.
Semaphore config directory is /home/ubuntu/semaphore.
If you want to further configure SaltStack then please visit Configuring SaltStack page.