【易客吧】_全网激活码总代_激活码商城

您现在的位置是:首页 > 热门资讯 > 正文

热门资讯

Node.js 环境变量与云计算:在 AWS、Azure 和 GCP 等平台上的配置和使用 (node.js是什么)

用户投稿2024-04-15热门资讯33

简介

环境变量是存储在操作系统中的键值对,可用于存储和检索应用程序配置和其他信息。在云计算环境中,环境变量对于管理和配置应用程序至关重要。

Node.js 中的环境变量

在 Node.js 中,可以通过以下方式访问环境变量:```javascriptconst env = process.env;console.log(env.NODE_ENV); // "production"```

在 AWS、Azure 和 GCP 中配置环境变量

在 AWS、Azure 和 GCP 等云平台上,可以通过以下方式配置环境变量:

AWS

EC2 实例:使用 `--env-vars` 参数启动 EC2 实例。Lambda 函数:使用 `Environment` 字段在函数代码中设置环境变量。Elastic Beanstalk:使用 `Environment Properties` 选项卡进行配置。

Azure

App Service:使用 `Application settings` 选项卡进行配置。Virtual Machine:使用 `--environment-variables` 参数启动虚拟机。Azure Functions:使用 `environmentVariables` 字段在函数代码中设置环境变量。

GCP

App Engine:使用 `env_variables` 字段在 `app.yaml` 文件中进行配置。Compute Engine:使用 `--env-vars` 参数启动虚拟机实例。Cloud Functions:使用 `environmentVariables` 字段在函数代码中设置环境变量。

使用环境变量来配置 Node.js 应用程序

环境变量可以用于配置以下方面的应用程序:数据库连接信息API 密钥应用程序模式 (例如开发、生产)日志记录级别通过使用环境变量进行配置,可以轻松地将应用程序配置与代码分离,并根据不同的部署环境轻松地修改配置。

最佳实践

使用环境变量进行配置时,请遵循以下最佳实践:使用有意义的名称:选择易于理解和维护的环境变量名称。避免存储敏感信息:不要将机密信息(例如密码)存储在环境变量中。使用默认值:为非必需的环境变量设置默认值,以避免出现配置错误。使用类型转换:根据需要使用 `parseInt()` 或 `parseFloat()` 等函数将环境变量值转换为适当的类型。更新文档:记录环境变量的使用情况,以便其他人可以轻松理解应用程序配置。

结论

环境变量在云计算环境中管理和配置 Node.js 应用程序是至关重要的。通过了解如何在 AWS、Azure 和 GCP 中配置和使用环境变量,您可以提高应用程序的灵活性、可配置性和可维护性。

如何在Windows Azure上托管一个Node.js网站

通过Git将部署在Windows Azure网站上Windows Azure网站 (以下简称 WAWS)是微软六月份Meet Windows Azure活动中推出的新服务。 它提供了低成本、内置的模版,并易于部署到云端。 我认为WAWS是我们部署网站最简易的方式。 - IIS和IISNode已在WAWS环境中安装配置好,所以我们部署时不用安装任何东西。 - WAWS 支持多种部署方法,包括TFS、FTP以及Git。 对来说,FTP和Git较简单快捷。 - WAWS提供三种不同的扩展模式,他们都是免费的、共享的、保留的。 若我们只需一个具备数据库的网站,那这样的花费比Windows Azure云服务(以下简称 WACS)要低的。 - WAWS支持Windows Azure SQL数据库(以下简称WASD)和MySQL。 我们来看下,用在WAWS上建立一个网站是多么的简单、容易。 首先,我们需要创建一个新的WAWS。 由于本文后面我要示范如何从中用WASD,我们也将创建一个WASD。 前往windows azuredeveloper portal,从NEW button中选择COMPUTERàWEB SITEà CREATE WITH DATABASE。 网站一旦创建,我们前往它的控制面板,点击右侧的Set up Git publishing链接。 片刻之后,Windows Azure会完成Git部署配置。 如果这是你第一次在Windows Azure上配置Git或FTP 部署,你需要点击控制面板上的Reset deployment credentials链接来为部署提供用户名和密码。

什么是K8S?

k8s是什么?

Kubernetes 是一个可移植的,可扩展的开源容器编排平台,用于管理容器化的工作负载和服务,方便了声明式配置和自动化。它拥有一个庞大且快速增长的生态系统。Kubernetes 的服务,支持和工具广泛可用。

为什么现在流行使用容器?

早期: 在物理服务器上面部署应用程序存在资源分配问题,因为其不能在物理服务器中的应用程序定义资源边界,导致应用程序资源利用不足而无法扩展.

后来: 为了解决该问题,引入了虚拟化技术, 虚拟化技术是指允许你在单个物理服务器的 CPU 上运行多个虚拟机,可以让多个应用程序在虚拟机之间进行隔离,具有一定的安全性, 每一个虚拟机就是一台完整的计算机, 在虚拟化硬件之上运行所有组件.

现在: 多数在物理服务器上面部署应用程序都是采kubectl用容器的方式,容器类似于虚拟机,它们都具有自己的文件系统、CPU、内存、进程空间等, 且由于它们与基础架构分离,因此可以跨云和 OS 发行版本进行移植。基于此特点被企业大范围使用.

为什么需要使用k8s容器?

若出现这样一个环境: 在生产环境中如果一个容器发生故障,则我们需要手动去启动另外一个容器,这样的操作是对我们的管理员来说是不太方便的, 若一个容器出现故障,另一个容器可以自动启动容器接管故障的容器,这样是最好的.

k8s就可以实现该效果,Kubernetes 提供了一个可弹性运行分布式系统的框架。 Kubernetes 会满足你的扩展要求、故障转移、部署模式等。

k8s功能: 服务发现和负载均衡, 存储编排, 自动部署和回滚, 自动完成装箱计算, 自我修复, 密钥与配置管理

名词解释

Secret有三种类型:

k8s的组成

k8s是由组件,API,对象等组成.

包含所有相互关联组件的 Kubernetes 集群图如下:

组件

Kubernetes 控制面 的核心是 API 服务器。 API 服务器负责提供 HTTP API,以供用户、集群中的不同部分和集群外部组件相互通信。

对象

Kubernetes对象是Kubernetes系统中的持久实体。Kubernetes使用这些实体来表示集群的状态.

具体来说,他们可以描述:

Kubernetes 架构

Kubernetes 架构由节点,控制面到节点通信, 控制器, 云控制器管理器组成.

master 流程图

节点

节点可以是一个虚拟机或者物理机器,取决于所在的集群配置。 每个节点包含运行 Pods 所需的服务, 这些 Pods 由 控制面 负责管理.

节点上的组件包括 kubelet、 容器运行时以及 kube-proxy。

节点状态

可以使用 kubectl 来查看节点状态和其他细节信息:

kubectl describe node <�节点名称>

一个节点包含以下信息:

控制面到节点通信

控制器

在 Kubernetes 中,控制器通过监控集群 的公共状态,并致力于将当前状态转变为期望的状态。

举个例子: 当前室内温度为20度, 我们通过调节遥控器,使其温度上升至24度, 这20度到24度的变化即为让其从当前状态接近期望状态。

控制器模式分为直接控制和通过API服务器来控制.

云控制器管理器

云控制器管理器是指嵌入特定云的控制逻辑的 控制平面组件。 云控制器管理器允许您链接聚合到云提供商的应用编程接口中, 并分离出相互作用的组件与您的集群交互的组件。

云控制器管理器中的控制器包括:

Kubernetes 安全性

云原生安全

云原生安全4个C: 云(Cloud)、集群(Cluster)、容器(Container)和代码(Code)

云原生安全模型的每一层都是基于下一个最外层,代码层受益于强大的基础安全层(云、集群、容器)。我们无法通过在代码层解决安全问题来为基础层中糟糕的安全标准提供保护。

基础设施安全

Kubetnetes 基础架构关注领域

建议

通过网络访问 API 服务(控制平面)

所有对 Kubernetes 控制平面的访问不允许在 Internet 上公开,同时应由网络访问控制列表控制,该列表包含管理集群所需的 IP 地址集。

通过网络访问 Node(节点)

节点应配置为 仅能 从控制平面上通过指定端口来接受(通过网络访问控制列表)连接,以及接受 NodePort 和 LoadBalancer 类型的 Kubernetes 服务连接。如果可能的话,这些节点不应完全暴露在公共互联网上。

Kubernetes 云访问提供商的 API

每个云提供商都需要向 Kubernetes 控制平面和节点授予不同的权限集。为集群提供云提供商访问权限时,最好遵循对需要管理的资源的最小特权原则。Kops 文档提供有关 IAM 策略和角色的信息。

访问 etcd

对 etcd(Kubernetes 的数据存储)的访问应仅限于控制平面。根据配置情况,你应该尝试通过 TLS 来使用 etcd。更多信息可以在 etcd 文档中找到。

etcd 加密

在所有可能的情况下,最好对所有驱动器进行静态数据加密,但是由于 etcd 拥有整个集群的状态(包括机密信息),因此其磁盘更应该进行静态数据加密。

集群组件安全

容器安全

代码安全

Kubernetes架构常见问题

Kubernetes ATTACK 矩阵

信息泄露

云账号AK泄露

API凭证(即阿里云AccessKey)是用户访问内部资源最重要的身份凭证。用户调用API时的通信加密和身份认证会使用API凭证.

API凭证是云上用户调用云服务API、访问云上资源的唯一身份凭证。

API凭证相当于登录密码,用于程序方式调用云服务API.

k8s configfile泄露

kubeconfig文件所在的位置:

$HOME//config

Kubeconfig文件包含有关Kubernetes集群的详细信息,包括它们的位置和凭据。

云厂商会给用户提供该文件,以便于用户可以通过kubectl对集群进行管理. 如果攻击者能够访问到此文件(如办公网员工机器入侵、泄露到Github的代码等),就可以直接通过API Server接管K8s集群,带来风险隐患。

Master节点SSH登录泄露

常见的容器集群管理方式是通过登录Master节点或运维跳板机,然后再通过kubectl命令工具来控制k8s。

云服务器提供了通过ssh登陆的形式进行登陆master节点.

若Master节点SSH连接地址泄露,攻击者可对ssh登陆进行爆破,从而登陆上ssh,控制集群.

容器组件未鉴权服务

Kubernetes架构下常见的开放服务指纹如下:

注:前六个重点关注: 一旦被控制可以直接获取相应容器、相应节点、集群权限的服务

了解各个组件被攻击时所造成的影响

组件分工图:

假如用户想在集群里面新建一个容器集合单元, 流程如下:

攻击apiserver

apiserver介绍:在Kubernetes中,对于未鉴权对apiserver, 能访问到 apiserver 一般情况下就能获取了集群的权限.

在攻击者眼中Kubernetes APIServer

默认情况下apiserver都有鉴权:

未鉴权配置如下:

对于这类的未鉴权的设置来说,访问到 apiserver 一般情况下就获取了集群的权限:

如何通过apiserver来进行渗透,可参考:攻击kubelet

每一个Node节点都有一个kubelet(每个节点上运行的代理)服务,kubelet监听了,,等端口。

端口,是kubelet与apiserver进行通信对主要端口, 通过该端口,kubelet可以知道当前应该处理的任务.该端口在最新版Kubernetes是有鉴权的, 但在开启了接受匿名请求的情况下,不带鉴权信息的请求也可以使用提供的能力, 在Kubernetes早期,很多挖矿木马基于该端口进行传播.

在配置文件中,若进行如下配置,则可能存在未授权访问漏洞.

/var/bin/kubulet/config/yaml

若端口存在未授权访问漏洞,我们可以直接访问/pods进行查看

根据在pods中获取的信息,我们可以在容器中执行命令

curl -Gks{namespace}/{podname}/{containername} \-d input=1 -d output=1 -d tty=1 \-d command=whoami

上述命令得到websocket地址,连接websocket得到命令结果:

使用wscat工具连接websocket

wscat -c “{websocket}” --no-check

即可得到我们执行命令的结果.

获取token

/var/run/secrets//serviceaccount

然后即可访问kube-api server,获取集群权限

curl -ks -H Authorization: Bearer \ ttps://master:6443/api/v1/namespaces/{namespace}/secrets

攻击kubelet总体步骤如下:

攻击dashboard

dashboard登陆链接如下:

界面如下:

dashboard是Kubernetes官方推出的控制Kubernetes的图形化界面.在Kubernetes配置不当导致dashboard未授权访问漏洞的情况下,通过dashboard我们可以控制整个集群。

默认情况下, dashboard是需要进行鉴权操作的,当用户开启了enable-skip-login时可以在登录界面点击Skip跳过登录进入dashboard.

通过skip登陆的dashboard默认是没有操作集群的权限,因为Kubernetes使用RBAC(Role-based access control)机制进行身份认证和权限管理,不同的serviceaccount拥有不同的集群权限。

但有些开发者为了方便或者在测试环境中会为Kubernetes-dashboard绑定cluster-admin这个ClusterRole(cluster-admin拥有管理集群的最高权限).

为Kubernetes-dashboard绑定cluster-admin 设置如下:

后通过skip登陆dashboard便有了管理集群的权限.

创建Pod控制node节点,该pod主要是将宿主机根目录挂载到容器tmp目录下。

新建一个Pod如下:

通过该容器的tmp目录管理node节点的文件

攻击etcd

Kubernetes默认使用了etcd v3来存储数据, 若能naetcd对内暴露2379端口,本地127.0.0.1可免认证访问. 其他地址要带—endpoint参数和cert进行认证。

未授权访问流程:

攻击docker remote api(Docker daemon公网暴露)

2375是docker远程操控的默认端口,通过这个端口可以直接对远程的docker 守护进程进行操作。Docker 守护进程默认监听2375端口且未鉴权.

当机器以方式启动daemon时,可以在外部机器对该机器的docker daemon进行直接操作:

docker daemon -H=0.0.0.0:2375

之后依次执行systemctl daemon-reload、systemctl restart docker

外部主机使用 即可操作暴露2375端口的主机.

因此当你有访问到目标Docker API 的网络能力或主机能力的时候,你就拥有了控制当前服务器的能力。我们可以利用Docker API在远程主机上创建一个特权容器,并且挂载主机根目录到容器.

检测目标是否存在docker api未授权访问漏洞的方式也很简单,访问路径是否含有ContainersRunning、DockerRootDir等关键字。

攻击kubectl proxy

二次开发所产生的问题

管理Kubernetes无论是使用 kubectl 或 Kubernetes dashboard 的UI功能,其实都是间接在和 APIServer 做交互.

如果有需求对k8s进行二次开发的话,大部分的开发功能请求了 APIServer 的 Rest API 从而使功能实现的。

例如:

  • DELETE类似于这样去调用apiserver, 攻击者若修改namespace、pod和容器名, 那么即可造成越权.

    推荐工具

    Kube-Hunter扫描漏洞

    kube-hunter是一款用于寻找Kubernetes集群中的安全漏洞扫描器

    下载地址:强推)

    CDK是一款为容器环境定制的渗透测试工具,在已攻陷的容器内部提供零依赖的常用命令及PoC/EXP。集成Docker/K8s场景特有的 逃逸、横向移动、持久化利用方式,插件化管理。

    下载地址:参考链接

    软件开发平台有哪些?

    软件开发平台:

    软件开发平台是指提供软件开发环境、工具和资源的集成平台,用于简化和加速软件开发过程。以下是一些常见的软件开发平台:

    平台:

    -JavaSE(JavaStandardEdition):用于开发标准的Java应用程序。

    -JavaEE(JavaEnterpriseEdition):用于开发企业级Java应用程序。

    -Android开发:用于移动应用开发的Java平台。

    平台:

    平台:包括C#、等语言,用于Windows应用程序、Web应用程序和服务端开发。

    -VisualStudio:Microsoft的集成开发环境,支持多种编程语言。

    开发平台:

    :用于服务器端JavaScript开发。

    -React、Angular、:用于构建前端Web应用。

    4.移动应用开发平台:

    -Flutter:Google推出的UI工具包,用于跨平台移动应用开发。

    -ReactNative:Facebook开发的框架,用于使用JavaScript构建原生移动应用。

    -Xamarin:允许使用C#构建跨平台移动应用。

    5.数据科学与人工智能平台:

    -TensorFlow:用于机器学习和深度学习的开源平台。

    -PyTorch:用于深度学习的开源机器学习库。

    6.数据库平台:

    -MySQL、PostgreSQL、Oracle:关系型数据库平台。

    -MongoDB:非关系型数据库平台。

    7.游戏开发平台:

    -Unity:用于跨平台游戏开发的综合性引擎。

    -UnrealEngine:用于创建高度真实的游戏的引擎。

    Node.js 环境变量与云计算:在 AWS、Azure 和 GCP 等平台上的配置和使用 (node.js是什么) 第1张

    8.云计算平台:

    -AmazonWebServices(AWS):提供各种云计算服务。

    -MicrosoftAzure:微软的云计算平台。

    -GoogleCloudPlatform(GCP):谷歌的云计算服务。

    这些平台提供了丰富的工具和资源,开发者可以根据项目需求选择合适的平台进行软件开发。

    以上内容是由 猪八戒网精心整理,希望对您有所帮助。

若对本页面资源感兴趣,请点击下方或右方图片,注册登录后

搜索本页相关的【资源名】【软件名】【功能词】或有关的关键词,即可找到您想要的资源

如有其他疑问,请咨询右下角【在线客服】,谢谢支持!

Node.js 环境变量与云计算:在 AWS、Azure 和 GCP 等平台上的配置和使用 (node.js是什么) 第2张

发表评论

评论列表

  • 这篇文章还没有收到评论,赶紧来抢沙发吧~
欢迎你第一次访问网站!