当前位置: 首页 > article >正文

使用Service发布前后端应用程序

使用Service发布前后端应用程序

文章目录

  • 使用Service发布前后端应用程序
    • @[toc]
    • 一、创建并发布后端应用程序
    • 二、创建并发布前端应用程序
    • 三、通过前端发送流量进行测试

部署前端(Frontend)微服务和后端(Backend)微服务是比较常见的应用场景。使用Service就可以在Kubernetes集群中实现这种部署,本例以nginx作为前端应用程序,Tomcat作为后端应用程序,分别创建两个Service,前端Service对外发布,前端的Pod通过后端Service的域名连接后端

一、创建并发布后端应用程序

将请求从前端发送到后端的关键是后端Service。为简化实验,本例的后端应用程序选择基本的Tomcat服务器。

(1)使用Deployment部署该应用程序

[root@master ~]# vim backend-deploy.yaml
[root@master ~]# cat backend-deploy.yaml 
apiVersion: apps/v1
kind: Deployment
metadata:name: backend
spec:selector:matchLabels:                      # 多标签选择器app: webapptier: backendreplicas: 3template:metadata:labels:app: webapptier: backendspec:containers:                     # 容器运行Tomcat服务器- name: tomcatimage: tomcat:8.0-alpineports:- containerPort: 8080

(2)执行创建Deployment

[root@master ~]# kubectl apply -f backend-deploy.yaml 
deployment.apps/backend created

(3)使用Service发布该应用程序

[root@master ~]# vim backend-service.yaml
[root@master ~]# cat  backend-service.yaml
apiVersion: v1
kind: Service
metadata:name: webapp
spec:selector:                 # 组合多标签选择器来选择目标Podapp: webapptier: backendports:- protocol: TCPport: 80targetPort: 8080

(4)执行创建Service

[root@master ~]# kubectl apply -f backend-service.yaml 
service/webapp created

(5)查看Service详细信息

[root@master ~]# kubectl get pods
NAME                      READY   STATUS              RESTARTS   AGE
backend-5c94c696c-2jb4g   1/1     Running             0          11m
backend-5c94c696c-8hmvv   0/1     ContainerCreating   0          11m
backend-5c94c696c-pw4mj   1/1     Running             0          11m
[root@master ~]# kubectl describe service webapp
Name:              webapp
Namespace:         default
Labels:            <none>
Annotations:       <none>
Selector:          app=webapp,tier=backend
Type:              ClusterIP
IP Family Policy:  SingleStack
IP Families:       IPv4
IP:                10.107.1.140
IPs:               10.107.1.140
Port:              <unset>  80/TCP
TargetPort:        8080/TCP
Endpoints:         10.244.166.135:8080,10.244.166.136:8080
Session Affinity:  None
Events:            <none>

至此,名为webapp的Service可以将请求流量发送到后端服务的2个副本上。Service用于发送网络流量,是的后端微服务总是可以访问,但是此Service在集群外部无法访问也无法解析。

二、创建并发布前端应用程序

接下来创建一个可在集群外部访问的前端应用程序,并通过代理前端的请求连接到后端应用程序。本例的前端应用程序选择nginx。与后端应用程序类似,前端应用程序包含一个Deployment和一个Service,唯一的区别是前端Service要提供外部访问。

(1)创建ConfigMap,将nginx的上游服务器配置为后端应用程序

nginx除了可以直接作为Web服务器使用外,还可以通过反向代理将请求转发给上游服务器。本例前端使用的是原生的nginx镜像,需要自定义配置文件,将请求转发给前面发布的后端Service。

首先创建一个nginx配置文件

[root@master ~]# cat nginx.conf 
# Backend 是 Nginx 的内部标识符,用于命名以下特定的上游服务器(upstream)
upstream Backend {# webapp 是 Kubernetes 中的后端服务所使用的内部DNS名称server webapp;
}
server {listen 80;location / {# 以下语句将流量通过代理方式转发到名为Backend的上游服务器proxy_pass http://Backend;}
}

Service具有服务发现机制,前端应用程序通过后端Service的域名就可以将请求发送到后端Pod

然后基于该配置文件创建名为nginx-config的ConfigMap,供前端使用

[root@master ~]# kubectl create configmap nginx-config --from-file=nginx.conf
configmap/nginx-config created

(2)创建Deployment

[root@master ~]# vim frontend-deploy.yaml
[root@master ~]# cat frontend-deploy.yaml 
apiVersion: apps/v1
kind: Deployment
metadata:name: frontend
spec:selector:matchLabels:app: webapptier: frontendreplicas: 1                              # 前端只提供一个副本template:metadata:labels:app: webapptier: frontendspec:containers:- name: nginximage: nginx:1.14.2volumeMounts:                     # 挂载由ConfigMap提供的配置文件- name: nginx-configmountPath: /etc/nginx/conf.d/default.confsubPath: nginx.confvolumes:                               # 定义由ConfigMap提供的特殊卷- name: nginx-configconfigMap:name: nginx-configitems:- key: nginx.confpath: nginx.conf[root@master ~]# 

注意,这里的容器挂载了由上述ConfigMap提供的nginx配置文件

(3)执行创建

[root@master ~]# kubectl apply -f frontend-deploy.yaml 
deployment.apps/frontend created

(4)创建Service

[root@master ~]# cat frontend-service.yaml 
apiVersion: v1
kind: Service
metadata:name: frontend
spec:type: NodePort              # Service类型为NodePortselector:app: webapptier: frontendports:- protocol: TCPport: 80targetPort: 80nodePort: 30080             # 节点上绑定的端口

实际应用中,大多会使用LoadBalancer类型的Service,利用云提供商的负载均衡器实现从集群外部访问的目的。为了便于实验,这里改用NodePort类型的Service,通过节点IP地址和端口对外发布应用程序。

(5)执行创建

[root@master ~]# kubectl apply -f frontend-service.yaml 
service/frontend created

(6)列出该Service的基本信息

[root@master ~]# kubectl get svc frontend
NAME       TYPE       CLUSTER-IP       EXTERNAL-IP   PORT(S)        AGE
frontend   NodePort   10.101.220.232   <none>        80:30080/TCP   47s

(7)该Service仅运行一个Pod副本,执行以下命令列出该Pod信息。

[root@master ~]# kubectl get po --selector="tier=frontend" -o wide
NAME                        READY   STATUS    RESTARTS   AGE    IP             NODE    NOMINATED NODE   READINESS GATES
frontend-85bf7d77d8-xfzbl   1/1     Running   0          5m3s   10.244.104.1   node2   <none>           <none>

可以发现,该Service的Pod副本在node2节点上运行。但是,外部用户可以通过集群中任一节点的IP地址(域名)和节点端口来访问该Service发布的应用程序。至此,前端和后端的连接已经完成。


三、通过前端发送流量进行测试

可以使用curl命令通过前端Service的集群节点IP地址和端口访问服务端点,进行简单的测试,结果发现能够访问后端的Tomcat服务器。例如,访问node1节点:

[root@master ~]# curl http://192.168.10.31:30080
...<h1>Apache Tomcat/8.0.53</h1>
...
[root@master ~]# 

使用浏览器访问该前端Service,这里访问另一个节点node2(IP地址为192.168.10.32),进一步验证了前后端的成功连接。

在这里插入图片描述

测试完毕后,删除创建的对象

[root@master ~]# kubectl get pods
NAME                        READY   STATUS              RESTARTS   AGE
backend-5c94c696c-2jb4g     1/1     Running             0          36m
backend-5c94c696c-8hmvv     0/1     ContainerCreating   0          36m
backend-5c94c696c-pw4mj     1/1     Running             0          36m
frontend-85bf7d77d8-xfzbl   1/1     Running             0          12m
[root@master ~]# kubectl delete services frontend webapp
service "frontend" deleted
service "webapp" deleted
[root@master ~]# kubectl delete deployment frontend backend
deployment.apps "frontend" deleted
deployment.apps "backend" deleted
[root@master ~]# kubectl delete cm nginx-config
configmap "nginx-config" deleted
[root@master ~]# kubectl get pods
NAME                      READY   STATUS        RESTARTS   AGE
backend-5c94c696c-8hmvv   0/1     Terminating   0          37m
[root@master ~]# kubectl get svc
NAME         TYPE        CLUSTER-IP   EXTERNAL-IP   PORT(S)   AGE
kubernetes   ClusterIP   10.96.0.1    <none>        443/TCP   27d
[root@master ~]# kubectl get cm
NAME               DATA   AGE
kube-root-ca.crt   1      27d
[root@master ~]# kubectl delete pod backend-5c94c696c-8hmvv --grace-period=0 --force
Warning: Immediate deletion does not wait for confirmation that the running resource has been terminated. The resource may continue to run on the cluster indefinitely.
pod "backend-5c94c696c-8hmvv" force deleted
[root@master ~]# kubectl get pods
No resources found in default namespace.
[root@master ~]# 

相关文章:

使用Service发布前后端应用程序

使用Service发布前后端应用程序 文章目录 使用Service发布前后端应用程序[toc]一、创建并发布后端应用程序二、创建并发布前端应用程序三、通过前端发送流量进行测试 部署前端&#xff08;Frontend&#xff09;微服务和后端&#xff08;Backend&#xff09;微服务是比较常见的应…...

Ubuntu20.04下Docker方案实现多平台SDK编译

0 前言 熟悉嵌入式平台Linux SDK编译流程的小伙伴都知道,假如平台a要求必须在Ubuntu18.04下编译,平台b要求要Ubuntu22.04的环境,那我只有Ubuntu20.04,或者说我的电脑硬件配置最高只能支持Ubuntu20.04怎么办?强行在Ubuntu20.04下编译,编又编不过,换到旧版本我又不愿意,…...

-SSRF 服务端请求Gopher 伪协议无回显利用黑白盒挖掘业务功能点

1 、 SSRF 漏洞原理 SSRF(Server-Side Request Forgery: 服务器端请求伪造 ) 一种由攻击者构造形成由服务端发起请求的一个安全漏洞 ; 一般情况下&#xff0c; SSRF 攻击的目标是从外网无法访问的内部系统。 &#xff08;正是因为它是由服务端发起的&#xff0c;所以它能…...

事件冒泡与捕获

一、事件流基础&#xff1a;事件冒泡与捕获的起源 事件流概念 事件发生时在DOM节点上的传播顺序&#xff0c;触发一个节点的事件会连锁触发相关节点的事件。 两种对立模型 事件捕获&#xff08;微软提出&#xff09;&#xff1a;事件从文档根节点&#xff08;如document&#…...

《AI大模型应知应会100篇》第27篇:模型温度参数调节:控制创造性与确定性

第27篇&#xff1a;模型温度参数调节&#xff1a;控制创造性与确定性 摘要 在大语言模型的使用中&#xff0c;“温度”&#xff08;Temperature&#xff09;是一个关键参数&#xff0c;它决定了模型输出的创造性和确定性之间的平衡。通过调整温度参数&#xff0c;您可以根据任…...

聊聊Doris的数据模型,如何用结构化设计解决实时分析难题

传统 OLAP 系统的局限 在大数据实时分析领域&#xff0c;数据模型设计直接决定了系统的查询性能、存储效率与业务适配性。Apache Doris作为新一代MPP分析型数据库&#xff0c;通过独创的多模型融合架构&#xff0c;在业内率先实现了"一份数据支持多种分析范式"的能力…...

LNA设计

设计目的 为后级提供足够的增益以克服后级电路噪声 尽可能小的噪声和信号失真 确保输入和输出端的阻抗匹配 确保信号线性度 评价标准 噪声系数 功率增益 工作频率和带宽 输入信号功率动态范围 端口电压驻波比 稳定性 基于SP模型的LNA设计 直流分析 S参数分析 设计指标 &#xf…...

小红书爬虫,小红书api,小红书数据挖掘

背景&#xff1a; 小红书&#xff08;Xiaohongshu&#xff09;是一款结合社交、购物和内容分享的移动应用&#xff0c;近年来在中国以及全球范围内拥有大量的用户群体。小红书上的内容包括用户的消费体验、生活方式、旅行分享、时尚搭配等。通过这些内容&#xff0c;用户可以了…...

C++ STL 环形队列模拟实现

C STL 环形队列模拟实现 下面是一个使用C STL实现的环形队列&#xff08;Circular Queue&#xff09;的完整示例&#xff1a; #include <iostream> #include <vector> #include <stdexcept>template <typename T> class CircularQueue { private:std…...

C++中unique_lock和lock_guard区别

目录 1.自动锁定与解锁机制 2.灵活性 3.所有权转移 4.可与条件变量配合使用 5.性能开销 在 C 中&#xff0c;std::unique_lock 和 std::lock_guard 都属于标准库 <mutex> 中的互斥锁管理工具&#xff0c;用于简化互斥锁的使用并确保线程安全。但它们存在一些显著区别…...

Vue 3 组合式 API 规范配合 Pinia

实现效果&#xff1a; 根据pinia中存储的不同状态&#xff0c; 点击不同的按钮&#xff0c;切换不同的弹窗和标题1. Pinia Store&#xff08;组合式写法&#xff09; // stores/dataStore.ts import { defineStore } from pinia import { reactive } from vuetype DialogType …...

JavaSpring 中使用 Redis

创建项目 配置 Redis 服务地址 创建 Controller 类 由于当前只是些简单的测试代码&#xff0c;所以就不进行分层了&#xff0c;只创建一个 Controller 来实现 jedis 通过 jedis 对象里的各种方法来操作 Redis 此处通过 StringRedisTemplate 来操作 Redis 最原始提供的类是 Re…...

多线程使用——线程安全、线程同步

一、线程安全 &#xff08;一&#xff09;什么是线程安全问题 多个线程&#xff0c;同时操作同一个共享资源的时候&#xff0c;可能会出现业务安全的问题。 &#xff08;二&#xff09;用程序摹拟线程安全问题 二、线程同步 &#xff08;一&#xff09;同步思想概述 解决线…...

Spring Boot 集成 tess4j 实现图片识别文本

tesseract是一个开源的光学字符识别&#xff08;OCR&#xff09;引擎&#xff0c;它可以将图像中的文字转换为计算机可读的文本。支持多种语言和书面语言&#xff0c;并且可以在命令行中执行。它是一个流行的开源OCR工具&#xff0c;可以在许多不同的操作系统上运行。 Tess4J是…...

JAVA IO、BIO、NIO、AIO及零拷贝

概述 IO,常写作 I/O,是 Input/Output 的简称,是 Input/Output 的简称,即输入/输出。通常指数据在内部存储器(内存)和外部存储器(硬盘、优盘等)或其他周边设备之间的输入和输出。 目前有三种 IO 共存。分别是 BIO、NIO 和 AIO。 BIO 全称 Block-IO 是一种同步且阻塞的…...

Redis命令——list

列表类型是用来存储多个有序的字符串&#xff0c;列表中的每个字符串称为元素&#xff08;element&#xff09;&#xff0c;⼀个列表最多可以存储个元素 在 Redis 中&#xff0c;可以对列表两端插入&#xff08;push&#xff09;和弹出&#xff08;pop&#xff09;&#xff0c;…...

MicroDEM 与 OpenEV(FWTtools工具包):两款开源DEM相关小软件

大家好&#xff0c;今天为大家介绍的软件是MicroDEM 与 OpenEV&#xff0c;这两款小软件分别主要用于DEM数据的处理、数据查看与分析。MICRODEM是一款专注于地理空间分析和遥感数据处理的开源小软件。 MICRODEM官网网址为&#xff1a;https://microdem.org/&#xff0c;官网比较…...

大学英语四级选词填空阅读题和段落匹配解析

Leisure and well - being休闲和幸福 The vital role of leisure in enhancing well - being休闲在增进福祉方面的重要作用 A) The perception of leisure activities has a significant impact on the mental health advantages they offer. 对休闲活动的看法对其提供的心理…...

STM32使用rand()生成随机数并显示波形

一、随机数生成 1、加入头文件&#xff1a;#include "stdlib.h" 2、定义一个用作生成随机数种子的变量并加入到滴答定时器中不断自增&#xff1a;uint32_t run_times 0; 3、设置种子&#xff1a;srand(run_times);//每次生成随机数前调用一次为佳 4、生成一个随…...

大语言模型智能体:安全挑战与应对之道

在当今科技飞速发展的时代&#xff0c;大语言模型驱动的智能体正逐渐融入我们生活和工作的方方面面&#xff0c;给我们带来了诸多便利。但与此同时&#xff0c;它们的安全问题也引起了广泛的关注。今天&#xff0c;咱们就一起来深入了解一下可信大语言模型智能体所面临的安全挑…...

每日OJ_牛客_kotori和素因子_DFS_C++_Java

目录 牛客_kotori和素因子_DFS 题目解析 C代码 Java代码 牛客_kotori和素因子_DFS kotori和素因子 描述&#xff1a; kotori拿到了一些正整数。她决定从每个正整数取出一个素因子。但是&#xff0c;kotori有强迫症&#xff0c;她不允许两个不同的正整数取出相同的素因子…...

Vue 开发实战:从入门到精通的经验之谈

零基础入门 Vue&#xff0c;10 分钟快速上手教程 一、初识 Vue二、搭建 Vue 开发环境&#xff0c;迈开第一步 Vue 核心概念大揭秘&#xff0c;响应式系统原来是这么回事儿三、Vue 核心概念&#xff1a;响应式系统 模板语法与表达式&#xff0c;玩转 Vue 就靠它啦四、模板语法与…...

快手OneRec 重构推荐系统:从检索排序到生成统一的跃迁

文章目录 1. 背景2. 方法2.1 OneRec框架2.2 Preliminary2.3 生成会话列表2.4 利用奖励模型进行迭代偏好对齐2.4.1 训练奖励模型2.4.2 迭代偏好对齐 3. 总结 昨天面试的时候聊到了OneRec&#xff0c;但是由于上次看这篇文章已经是一个月之前&#xff0c;忘得差不多了&#xff0c…...

c# 简单实现将Message的内容保存到txt中,超过100个则清理旧文件

using System; using System.IO; using System.Threading;public static class LogManager {private static readonly object _fileLock new object(); // 线程安全锁private const int MaxFiles 100; // 最大文件数限制private const string LogDire…...

精打细算 - GPU 监控

精打细算 - GPU 监控 在上一篇,咱们历经千辛万苦,终于让应用程序在 Pod 的“驾驶舱”里成功地“点火”并用上了 GPU。太棒了!但是,车开起来是一回事,知道车速多少、油耗多少、引擎水温是否正常,则是另一回事,而且同样重要,对吧? 我们的 GPU 应用跑起来了,但新的问题…...

软件测试的页面交互标准:怎样有效提高易用性

当用户遇到"反人类"设计时 "这个按钮怎么点不了&#xff1f;"、"错误提示完全看不懂"、"我输入的内容去哪了&#xff1f;"——这些用户抱怨背后&#xff0c;都指向同一个问题&#xff1a;页面交互的易用性缺陷。作为软件测试工程师&a…...

共享单车出行规律与决定因素的空间交互分析——以北京六大区为例

共享单车出行规律与决定因素的空间交互分析——以北京六大区为例 原文&#xff1a;Spatial Interaction Analysis of Shared Bicycles Mobility Regularity and Determinants: A Case Study of Six Main Districts, Beijing 这篇文章主要研究了北京六个主要城区共享单车的流动…...

Windows上安装FFmpeg的详细指南

1.下载FFmpeg 访问FFmpeg官方下载页面&#xff1a;https://ffmpeg.org/download.html 点击"Windows builds from gyan.dev"或"Windows builds by BtbN" gyan.dev版本&#xff1a;https://www.gyan.dev/ffmpeg/builds/ BtbN版本&#xff1a;https://githu…...

React-在使用map循环数组渲染列表时须指定唯一且稳定值的key

在渲染列表的时候&#xff0c;我们须给组件或者元素分配一个唯一值的key, key是一个特殊的属性&#xff0c;不会最终加在元素上面&#xff0c;也无法通过props.key来获取&#xff0c;仅在react内部使用。react中的key本质是服务于diff算法, 它的默认值是null, 在diff算法过程中…...

Nodejs数据库单一连接模式和连接池模式的概述及写法

概述 单一连接模式和连接池模式是数据库连接的两种主要方式&#xff1a; 单一连接模式&#xff1a; 优点&#xff1a;实现简单&#xff0c;适合小型应用缺点&#xff1a;每次请求都需要创建新连接&#xff0c;连接创建和销毁开销大&#xff0c;并发性能差&#xff0c;容易出…...