首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >GCP/GKE添加网络标记

GCP/GKE添加网络标记
EN

Stack Overflow用户
提问于 2020-05-07 06:46:22
回答 1查看 3.9K关注 0票数 1

作为GCP中的代码情况,我试图找到一种方法来改进我们的基础设施。我希望我能

  1. 基于目标标记创建防火墙规则白名单
  2. 使目标标记成为部署yaml配置的一部分。

我希望通过在部署中添加标记,我可以让它自动将这些标记应用到它创建的任何计算资源或负载均衡器中。这样,就可以通过terraform创建一个防火墙规则,该规则适用于这些标记。

我是走错路了还是有办法这么做?这不仅是为了自动化防火墙规则管理,也是为了清理可能干扰操作的不必要规则。

EN

回答 1

Stack Overflow用户

发布于 2020-06-14 21:39:45

GCP正在积极使用network tags标记受防火墙规则影响的资源(允许,阻塞)。这些标记与Compute Engine实例、托管组和其他链接。

Kubernetes使用labels标记与服务一起使用的资源(公开应用程序)。

network tags labels 之上的是独立的资源,不能在 GCP/GKE environment.中一起使用。

请查阅有关这些资源的正式文件:

当您在LoadBalancer中创建GKE类型的服务时,您会自动为它创建一个转发规则。以后可以修改/编辑此规则。它可以被编辑成只允许来自某些IP地址的请求的状态,比如家庭/办公室等。

它可以用GCP Dashboard -> VPC Network -> Firewall手动修改。

我在Terraform中找到了一个解决方案,它允许修改由创建的现有转发规则。

考虑到以上所述,我为带有Terraform和GKELoadBalancer创建了一个LoadBalancer示例。步骤:

  • 产生工作量。
  • 将工作负载公开给外部使用。
  • 编辑现有的转发规则以阻止来自某些CIDR/s的通信量。

假设:

  • Terraform已安装并可访问GCP
  • GKE集群已经准备好了
  • kubectl设置为连接到上面的群集。

有关上述步骤的参考:Learn.hashicorp.com: Terraform:供应GKE集群

至于Ingress。管理它将在很大程度上取决于所使用的解决方案如下:

  • ingress-nginx
  • ingress-gce

产生工作量

下面的示例nginx deployment将用于响应请求:

代码语言:javascript
运行
AI代码解释
复制
resource "kubernetes_deployment" "nginx" {
  metadata {
    name = "scalable-nginx-example"
    labels = {
      App = "ScalableNginxExample"
    }
  }

  spec {
    replicas = 2
    selector {
      match_labels = {
        App = "ScalableNginxExample"
      }
    }
    template {
      metadata {
        labels = {
          App = "ScalableNginxExample"
        }
      }
      spec {
        container {
          image = "nginx:1.7.8"
          name  = "example"

          port {
            container_port = 80
          }

          resources {
            limits {
              cpu    = "0.5"
              memory = "512Mi"
            }
            requests {
              cpu    = "50m"
              memory = "50Mi"
            }
          }
        }
      }
    }
  }
}

将工作负载公开给外部使用

下面的定义将为nginx部署创建LoadBalancer类型的服务:

代码语言:javascript
运行
AI代码解释
复制
resource "kubernetes_service" "nginx" {
  metadata {
    name = "nginx-example"
  }
  spec {
    selector = {
      App = kubernetes_deployment.nginx.spec.0.template.0.metadata[0].labels.App
    }
    port {
      port        = 80
      target_port = 80
    }

    type = "LoadBalancer"
  }
}

output "lb_ip" {

value = kubernetes_service.nginx.load_balancer_ingress[0].ip

}

GKE将自动创建转发规则,并为负载均衡器分配IP地址。Terraform将不知道此转发规则,因此需要导入此转发规则才能修改它。

请对lb_ip部分进行详细的检查。在成功运行Terraform之后,该部分将输出LoadBalancer的IP。此值可用于标识与服务关联的转发规则。

编辑现有转发规则以阻止来自某些CIDR/s的通信量

如上所述:

Terraform将不知道此转发规则,因此需要导入此转发规则才能修改它。

这里的问题是,需要一些自我脚本来完全自动化这个解决方案.

转发规则名称是必要的,以有能力修改它。

GCP基础结构中提取转发规则名称的方法之一是:

  • 从:LoadBalancer IP获取
    • $ kubectl get svc nginx-example

  • 从:forwarding rule获取名称
    • $ gcloud compute firewall-rules list --format=json

免责声明:上面的命令将输出所有防火墙规则,包括目标标记、优先级和json格式的描述等细节。LoadBalancer IP将位于防火墙规则的LoadBalancer IP部分。

  • 提取的转发规则名称应该类似于:
    • k8s-fw-aefb2110aad9e11ea971d42010a9c00a

  • 使用上面的名称在Terraform中创建资源

转发规则的

代码语言:javascript
运行
AI代码解释
复制
- Create a desired definition of `forwarding rule` in file. Please take a look on below **example rule** and change according to your use case. This resource can be used as a template for another new resources. Please make sure that `target_tags` are the same as not modified version. 

示例定义:

代码语言:javascript
运行
AI代码解释
复制
resource "google_compute_firewall" "YOUR-NAME-OF-FORWARDING" {
  project = "PROJECT-NAME"
  provider = google-beta
  name = "k8s-fw-aefb2110aad9e11ea971d42010a9c00a"
  network = "PROJECT-NETWORK"
  source_ranges = ["1.2.3.4/32"]
  priority = "1000"
  allow {
    protocol = "tcp"
    ports = ["80"]
    }
  target_tags = ["gke-PROJECT-NAME-gke-c6d3956c-node"] # 
  direction = "INGRESS"
  }
  • 通过以下方式导入资源:
代码语言:javascript
运行
AI代码解释
复制
$ terraform import google_compute_firewall.YOUR-NAME-OF-FORWARDING projects/PROJECT-NAME/global/firewalls/k8s-fw-aefb2110aad9e11ea971d42010a9c00a`

在发布$ terraform apply时,您应该能够看到forwarding rule中所需的更改,如下所示(部分):

代码语言:javascript
运行
AI代码解释
复制
 ~ source_ranges           = [
     - "0.0.0.0/0",
     + "1.2.3.4/32",
   ]

应用防火墙规则转发流量后,应该修改!

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61660732

复制
相关文章
SpringBoot 创建可执行Jar
  我们也可以通过插件创建一个在生产环境中运行的可执行jar文件来完成我们的示例。
2019/02/21
1K0
SpringBoot 创建可执行Jar
maven打包可执行jar文件运行报错
项目中同时依赖了Spring和MyBatis,并使用mybatis-spring集成MyBatis和Spring。 使用maven打包为可执行jar文件运行,打包插件为:maven-shade-plugin。
编程随笔
2019/09/11
2.2K0
Intellij idea打带Manifest文件的jar包(可执行jar包)
老版本Intellij idea可以很方便地打带Manifest文件的jar包,也就是可行性的Jar包。今天使用新版的Intellij idea打jar包时遇到了坑,jar包中竟然没有MANIFEST文件。
程裕强
2019/05/27
4.8K0
Spring Boot Maven 打包可执行Jar文件!
Maven pom.xml 必须包含 [plain] view plain copy <packaging>jar</packaging>   [html] view plain copy <build>   <plugins>   <plugin>   <groupId>org.springframework.boot</groupId>   <artifactId>spring-boot-maven-plugin</artifactId>   <configuration>   <fo
庞小明
2018/07/06
9640
【Maven】maven打包生成可执行jar文件
maven默认打包生成的jar是不能够直接运行的,因为在jar文件的META-INF/MANIFEST.MF文中没有Main-Class一行,为了生成可执行的jar文件,需要借助maven的插件,maven-shade-plugin,配置该插件如下:
全栈程序员站长
2022/09/01
1K0
Java -jar参数详解:掌握Java可执行JAR文件的运行技巧
作为一种常用的开发语言,Java经常使用可执行的JAR(Java Archive)文件来打包和分发应用程序。使用java -jar命令运行JAR文件是一种方便快捷的方式。本文将详细介绍java -jar命令的各种参数,帮助您充分利用这个功能。
修己xj
2023/08/25
3.7K0
Java -jar参数详解:掌握Java可执行JAR文件的运行技巧
包和 jar 文件的创建
在之前的文章中,讲到了面向的 3 大特性(封装、继承、多态)和面向对象设计的 5 大原则(SRP、OCP、LSP、DIP、ISP)。此外,我们还讲了如何创建一个类,并且在创建类后如何构造一个对象。然后还介绍了类中的属性和方法,并对构造方法和引用也做了简单的讲解。
村雨遥
2022/10/28
9110
包和 jar 文件的创建
制作可自运行的jar可执行文件
今天看到有人把Java的jar包制作成一个可执行文件,于是乎我也试了一把,确实也挺简单的,记录一下。
kongxx
2018/11/09
1.5K0
Maven编译可执行jar包
文章目录 拷贝lib的jar,配置可执行main函数 拷贝lib的jar <plugin> <artifactId>maven-dependency-plugin</artifactId> <version>2.6</version> <executions> <execution> <id>copy-dependencies</id> <phase>package</phase> <goa
白凡
2018/08/07
8790
Intellij 打可执行jar包
如题,想使用Intellij 打可执行jar包,在网上搜索了很多解决方案,不是很麻烦就是尝试失败。其实,可执行的jar包无非是在MAINFEST.MF多一个配置项而已。那么用最直接的解决方法即可。
程序新视界
2022/05/06
5640
SpringBoot系列-- jar可执行原理
文章篇幅较长,但是包含了SpringBoot 可执行jar包从头到尾的原理,请读者耐心观看。
田维常
2020/02/13
9420
Linux下创建可执行bin安装文件
1、简化操作。一般的软件安装过程,如果想要精简步骤,我们一般会将需要在命令行中输入的命令写成一个脚本,同时将安装介质准备好。我们将脚本和安装介质上传到生产环境,然后通过执行脚本来完成安装。如果能够将这两个文件合并为一个可执行文件,那安装的过程就更简单明了。
大江小浪
2018/07/24
9.2K0
Linux下创建可执行bin安装文件
使用Intellij Idea生成可执行文件jar,开关exe文件步骤
步骤一:打开File -> Project Structure -> Artifacts,例如以下图
全栈程序员站长
2022/07/05
1.3K0
使用Intellij Idea生成可执行文件jar,开关exe文件步骤
【IntelliJ IDEA】导出可执行 JAR 包
选择 " 菜单栏 / File / New / Project " 选项 , 创建新应用 ,
韩曙亮
2023/03/29
3.9K0
【IntelliJ IDEA】导出可执行 JAR 包
解决maven下载的jar文件乱码问题
1.修改Eclipse中文本文件的默认编码:windows->Preferences->general->Workspace->Text file encoding设置为UTF-8 image.png
用户1437675
2020/05/18
8180
解决maven下载的jar文件乱码问题
Maven 生成打包可执行jar包
最近IDEA打可执行Jar包搞了三天,一直失败,好好学习一下Maven-assembly,在此记录一下
全栈程序员站长
2022/09/02
2.3K1
如何将Spring Boot应用程序打包为可执行的jar文件?
🏆本文收录于 《Spring Boot从入门到精通》 ,专门攻坚指数提升,2023 年国内最系统+最强(更新中)。
bug菌
2023/10/15
2.6K0
如何将Spring Boot应用程序打包为可执行的jar文件?
从源代码到可执行文件
在理解一个源代码是如何成为可执行文件时,我简单的回顾下硬件层面、操作系统层面的知识。
全栈程序员站长
2022/07/15
3270
springBoot 怎么利用maven 创建可以执行的jar文件?
1 为了可以使用maven 创建可执行的jar文件 ,首先需要再pom.xml 加入如下的依赖。
爱明依
2019/03/12
1K0
Linux系统创建可执行文件软链接
由于创建软链接这个事情,在算法开发的日常中使用到的并不是很多,因此本文也是做一个简单的回顾。这里我们使用的案例是通过TMalign这个蛋白质打分文件,在编译好可执行文件之后,可以使用建立软链接的方法快捷的使用该可执行文件。
DechinPhy
2022/05/09
2.8K0

相似问题

scala :从scala文件创建jar

10

从Scala文件创建jar文件

94

创建可执行jar文件时遇到的问题

10

Scala,jar文件的问题

21

从jar创建可执行文件

45
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文