谷歌云代理商:如何配置谷歌云服务器的端口转发?

本文由【云老大】 TG@yunlaoda360 撰写

外部协议转发

  1. 创建防火墙规则:创建一个允许外部流量到达目标实例的防火墙规则。

    bash

    ini 复制代码
    gcloud compute firewall-rules create ALLOW_IPV4_FIREWALL_RULE_NAME \
        --target-tags=allow-ipv4-ext \
        --allow=tcp:80 \
        --source-ranges=0.0.0.0/0
  2. 创建虚拟机实例:创建一个虚拟机实例,并在实例上安装所需的服务器软件(如Apache)。

    bash

    sql 复制代码
    gcloud compute instances create VM_INSTANCE_NAME \
        --zone=ZONE \
        --image-family=debian-12 \
        --image-project=debian-cloud \
        --tags=allow-ipv4-ext \
        --metadata=startup-script='#! /bin/bash
        sudo apt-get update
        sudo apt-get install apache2 -y
        sudo a2ensite default-ssl
        sudo a2enmod ssl
        vm_hostname="$(curl -H "Metadata-Flavor:Google" \
        http://169.254.169.254/computeMetadata/v1/instance/name)"
        echo "Page served from: $vm_hostname" | \
        tee /var/www/html/index.html
        sudo systemctl restart apache2'
  3. 创建目标实例:创建一个目标实例,该实例包含上一步创建的虚拟机。

    bash

    ini 复制代码
    gcloud compute target-instances create TARGET_INSTANCE_NAME \
        --instance=VM_INSTANCE_NAME \
        --zone=ZONE
  4. 预留静态外部IP地址:预留一个静态外部IPv4地址。

    bash

    ini 复制代码
    gcloud compute addresses create IPV4_ADDRESS \
        --region=REGION
  5. 创建转发规则:创建一个转发规则,将TCP流量转发到目标实例。

    bash

    ini 复制代码
    gcloud compute forwarding-rules create IPV4_FORWARDING_RULE_NAME \
        --load-balancing-scheme=EXTERNAL \
        --region=REGION \
        --ip-protocol=TCP \
        --address=IPV4_ADDRESS \
        --ports=80 \
        --target-instance=TARGET_INSTANCE_NAME \
        --target-instance-zone=ZONE
  6. 测试设置 :获取转发规则的IP地址,并使用curl命令测试设置是否成功。

内部协议转发

  1. 创建目标实例:创建一个目标实例,该实例包含虚拟机。

    bash

    ini 复制代码
    gcloud compute target-instances create TARGET_INSTANCE_NAME \
        --instance=VM_INSTANCE_NAME \
        --zone=ZONE
  2. 创建转发规则:创建一个转发规则,将TCP流量转发到目标实例。

    bash

    ini 复制代码
    gcloud compute forwarding-rules create IPV4_FORWARDING_RULE_NAME \
        --load-balancing-scheme=INTERNAL \
        --network-tier=PREMIUM \
        --region=REGION \
        --ip-protocol=TCP \
        --ports=80 \
        --target-instance=TARGET_INSTANCE_NAME \
        --target-instance-zone=ZONE
  3. 创建测试客户端虚拟机:创建一个测试客户端虚拟机,用于发送流量到转发规则的IP地址。

    bash

    ini 复制代码
    gcloud compute instances create CLIENT_VM_NAME \
        --zone=ZONE \
        --image-family=debian-12 \
        --image-project=debian-cloud \
        --tags=allow-ssh
  4. 测试设置 :获取转发规则的IP地址,并使用curl命令测试设置是否成功。

相关推荐
Tony Bai4 小时前
【Go开发者的数据库设计之道】05 落地篇:Go 语言四种数据访问方案深度对比
开发语言·数据库·后端·golang
eqwaak05 小时前
Flask实战指南:从基础到高阶的完整开发流程
开发语言·后端·python·学习·flask
笨蛋不要掉眼泪5 小时前
SpringBoot项目Excel成绩录入功能详解:从文件上传到数据入库的全流程解析
java·vue.js·spring boot·后端·spring·excel
追逐时光者8 小时前
一款专门为 WPF 打造的开源 Office 风格用户界面控件库
后端·.net
Lin_Aries_04218 小时前
容器化 Flask 应用程序
linux·后端·python·docker·容器·flask
yuriy.wang9 小时前
Spring IOC源码篇六 核心方法obtainFreshBeanFactory.parseCustomElement
java·后端·spring
Eoch7710 小时前
HashMap夺命十连问,你能撑到第几轮?
java·后端
每天进步一点_JL10 小时前
🔥 一个 synchronized 背后,JVM 到底做了什么?
后端
SamDeepThinking11 小时前
有了 AI IDE 之后,为什么还还要 CLI?
后端·ai编程·cursor
yinke小琪11 小时前
线程池七宗罪:你以为的优化其实是在埋雷
java·后端·面试