Google Cloud Security: Creating Firewall Rules on a VPC Network
data:image/s3,"s3://crabby-images/cd442/cd442121ff1da2f7813393c1bf69d5825b8d6e34" alt="Google Cloud Security: Creating Firewall Rules on a VPC Network"
I will configure two different firewall rules: (1) to allow SSH access to all instances on the network, and (2) another one using specific network tags to only allow ICMP (ping) access to one instance, and only from a specific subnet. This will show using both wide-scope and narrow-scope firewall rules.
Allow SSH Access to all Virtual Machine Instances
- Scroll Down to VPC Network and click on Firewall rules and createa firewall rule and name it "allow-ssh"
- In the Network dropdown menu, select "custom-vpc"
- Targets: Select,"All instances in the network"
- Source IP Range: Type,
0.0.0.0/0
- Protocols and ports: select "Specified protocols and ports
"tcp: "22"
data:image/s3,"s3://crabby-images/c77c0/c77c028fc90115f15cbc1ae3b96d1127633fb390" alt="This image has an empty alt attribute; its file name is image-63.png"
data:image/s3,"s3://crabby-images/7837e/7837ef8f3ce8295db58e55fd854819b754b86906" alt="This image has an empty alt attribute; its file name is image-64.png"
data:image/s3,"s3://crabby-images/4d7ce/4d7ce6891dc3f3cf9fa420ef4e8b42a9b8784050" alt="This image has an empty alt attribute; its file name is image-65.png"
data:image/s3,"s3://crabby-images/7bf12/7bf127234d2dff235febfffc79610cdcf7f72bfa" alt="This image has an empty alt attribute; its file name is image-66.png"
data:image/s3,"s3://crabby-images/17da5/17da5144964bbd5cb152230c9294f8ac62131274" alt="This image has an empty alt attribute; its file name is image-67.png"
data:image/s3,"s3://crabby-images/579b2/579b21c82518c8ecc0e5bcb2053f01ee7ee47587" alt="This image has an empty alt attribute; its file name is image-68.png"
Apply Network Tag to VM
- Select, Compute Engine and click on "instance-2"
- Scroll Down to Network tags and enter "icmp-allow"
data:image/s3,"s3://crabby-images/f8a54/f8a54640e089b5c7ceb9f92562cca6e75f6d1d6d" alt="This image has an empty alt attribute; its file name is image-69.png"
data:image/s3,"s3://crabby-images/a3487/a3487de02b69bd2ef0275ed261f87b27035aa0f5" alt="This image has an empty alt attribute; its file name is image-70.png"
data:image/s3,"s3://crabby-images/5861b/5861b401e5b666cbdf34c0ad0568b18f04ad3b2b" alt="This image has an empty alt attribute; its file name is image-71.png"
data:image/s3,"s3://crabby-images/eb47c/eb47c5fce87e356e01450b19dc38c5b83c86da0c" alt="This image has an empty alt attribute; its file name is image-72.png"
data:image/s3,"s3://crabby-images/cd1db/cd1dbeafd2c15b3d22b5bb4f5f0b33a3da95e6a4" alt="This image has an empty alt attribute; its file name is image-73.png"
Create a narrow-scope firewall rule for virtuam machine "instance-2"
- Go back to your firewall menu, and create a new rule and name rule "allow-icmp"
- Choose the custom-vpc network
- In the Targets dropdown menu, set to specified target tags if not already the default
- In the Target tags field, type
icmp-allow
and hit Enter - In the Source filter dropdown, choose IP Range
- Enter the IP range of our subnet-a subnet
- In Protocols and ports, choose Specified protocols and ports
- Place a check in Other protocols, and type in
icmp
(there is no port number for ICMP
data:image/s3,"s3://crabby-images/dda15/dda15d105a7214b428f62998db562c880504bd3a" alt="This image has an empty alt attribute; its file name is image-74.png"
data:image/s3,"s3://crabby-images/6dfd6/6dfd6d107b0eafa38b791f8a1574a53bd77bb3a3" alt="This image has an empty alt attribute; its file name is image-75.png"
data:image/s3,"s3://crabby-images/38abd/38abdeabb0c648c2733ae578ece7e90f6547cd75" alt="This image has an empty alt attribute; its file name is image-76.png"
data:image/s3,"s3://crabby-images/aa826/aa826893b337ead3b95c0ccc71c42808db88d1ba" alt="This image has an empty alt attribute; its file name is image-77.png"
Test ICMP Firewall Rule
- Go back to Compute Engine and test this rule through the other virtuam machine instances
data:image/s3,"s3://crabby-images/ca62b/ca62b8f2eee5a462d664b7069876d2c476bd812a" alt="This image has an empty alt attribute; its file name is image-78.png"
instance-1a
- You will see that I can ping "instance-2" from ssh terminal of the this instance.
data:image/s3,"s3://crabby-images/cab53/cab53751ef658ea20142e4e4a48d92a3c83cd7d4" alt="This image has an empty alt attribute; its file name is image-79.png"
instance-1b
- You will see that I can ping "instance-2" from ssh terminal of the this instance.
data:image/s3,"s3://crabby-images/b14bd/b14bd057aaf35ed98bd2e250ce3284c674afd9c6" alt="This image has an empty alt attribute; its file name is image-80.png"
instance-3
- You will see that when you ping "instance-2" from ssh terminal of the this instance, that it will pause for a long time and evenually time out. Because the rule to source traffic from subnet-a only.
data:image/s3,"s3://crabby-images/345ae/345aec8cb9f8c50695c9f1d9c14f1d6c8d674dba" alt="This image has an empty alt attribute; its file name is image-81.png"