Getting Started¶
In your created GCP project, click the Cloud Shell button in the top right corner. This will launch a shell session in a persistent container, giving you full shell access for your project. It also comes with a number of useful tools pre-installed. Using Cloud Shell for this lab ensures firewalls or VPNs won’t prevent access to the management interface of your lab firewall.
data:image/s3,"s3://crabby-images/0fe36/0fe3632e62368bd0db656226c486091ab32e6caf" alt="../_images/cloud-shell.png"
You can also click the Open in new window icon to make Cloud Shell take an entire browser tab.
data:image/s3,"s3://crabby-images/f2407/f24074676f5fb7ad7951c4fec1e2e0e6fb24b943" alt="../_images/cloud-shell-tab.png"
Clone the repository containing our sample playbooks from GitHub, and change into the playbooks directory:
git clone https://github.com/PaloAltoNetworks/ansible-lab.git
cd ansible-lab/playbooks
data:image/s3,"s3://crabby-images/a3011/a30115e081c5b6f7806014c0bc9c253eae1f1750" alt="../_images/git-clone.png"
Ansible does not come installed by default in the Cloud Shell environment, so install it and add it to your shell’s PATH.
pip3 install --upgrade pip
pip3 install --user ansible
export PATH=$HOME/.local/bin:$PATH
data:image/s3,"s3://crabby-images/f257c/f257c0f28fe498a2c62ac405ad0385b4303ce8a7" alt="../_images/install-ansible.png"
Now, install the latest version of the PAN-OS Ansible collection from Ansible Galaxy, and the Python libraries it depends on.
ansible-galaxy collection install paloaltonetworks.panos
pip3 install --user -r requirements.txt
data:image/s3,"s3://crabby-images/9a915/9a915a3e89afa6fb11d90b358d92e746f4c25b79" alt="../_images/pip-install.png"
Now, you’ll need to modify the IP address in host_vars/lab-fw.yml
to match the
management interface of the VM-Series that was launched for you in GCP. In the
GCP console, click on Menu > Compute Engine > VM instances.
data:image/s3,"s3://crabby-images/5b4c3/5b4c36e0feb2c3d31f525574108f7b8ca6411245" alt="../_images/vm-instances.png"
The External IP of the launched instance is the management interface IP address.
data:image/s3,"s3://crabby-images/68361/68361a8b888c5ad887dc794954b5f2afd09469da" alt="../_images/vm-external-ip.png"
In your Cloud Shell tab, click the pencil icon to launch the Cloud Shell Editor.
Click File and Open… then navigate to the file ansible-lab/playbooks/host_vars/lab-fw.yml
,
and replace the ip_address value with the IP address of your VM-Series.
Your changes to the file will be saved automatically by default.
data:image/s3,"s3://crabby-images/c0b29/c0b295e948a0e22170263f67876f3414a1036d05" alt="../_images/lab-fw.png"
Log in to the firewall web UI using the following credentials. It could take up to 10 minutes for the firewall to be fully booted.
- Username:
admin
- Password:
Ignite2020!
data:image/s3,"s3://crabby-images/639f2/639f25c502b9e50d9558e73e75b298e63aa672ba" alt="../_images/web-ui.png"
We’ll use the web UI to observe the changes we make to the firewall using Ansible.
data:image/s3,"s3://crabby-images/73a54/73a5428dfbe73892928689fb2c91c6dc56be16bc" alt="../_images/web-ui-auth.png"