k8s、Deployment多副本资源详解、SERVICE通信、案例一nginx端口暴漏、案例二tomcat端口暴漏、案例三jenkins端口暴漏

本文主要是介绍k8s、Deployment多副本资源详解、SERVICE通信、案例一nginx端口暴漏、案例二tomcat端口暴漏、案例三jenkins端口暴漏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 案例一
    • 创建SERVICE
    • 案例一nginx端口暴露
    • 案例二tomcat端口暴露
    • 案例三jenkins端口暴漏

使用yaml创建Deployment
k8s deployment资源创建流程:
1. 用户通过 kubectl 创建 Deployment。
2. Deployment 创建 ReplicaSet。
3. ReplicaSet 创建 Pod。

对象的命名方式是:子对象的名字 = 父对象名字 + 随机字符串或数字
在这里插入图片描述
Deployment是一个定义及管理多副本应用(即多个副本 Pod)的新一代对象,与Replication Controller相比,它提供了更加完善的功能,使用起来更加简单方便

案例一

例1:
apiVersion: apps/v1
kind: Deployment
metadata:name: nginx-deployment
spec:selector:matchLabels:app: nginxreplicas: 2template:metadata:labels:app: nginxspec:containers:- name: nginximage: nginx:1.7.9ports:- containerPort: 80

启动一个pod 看看有几个副本

[root@k8s-mastet deployment.yaml]# kubectl apply -f nginx-depl.yml
deployment.apps/dep01 unchanged
service/mysvc unchanged

在这里插入图片描述

创建SERVICE

自己理解就是将自己的端口暴露给外界,让外界能访问

[root@kub-k8s-master prome]# vim nginx-depl.yml
apiVersion: apps/v1
kind: Deployment
metadata:name: dep01
spec:selector:matchLabels:	#必须设定的app: webreplicas: 2template:metadata:name: testnginx9labels:app: webspec:containers:- name: testnginx9image: daocloud.io/library/nginxports:- containerPort: 80

创建pod

[root@kub-k8s-master prome]# kubectl apply -f nginx-depl.yml 
  1. 创建service并且以nodePort的方式暴露端口给外网:
[root@kub-k8s-master prome]# vim nginx_svc.yaml
apiVersion: v1
kind: Service
metadata:name: mysvc
spec:type: NodePort  #类型ports:- port: 8080nodePort: 30001targetPort: 80selector:   #选择器app: web

创建pod

[root@kub-k8s-master prome]# kubectl apply -f nginx_svc.yaml 
service/mysvc created

3.测试

[root@kub-k8s-master prome]# kubectl get svc
NAME         TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)          AGE
kubernetes   ClusterIP   10.96.0.1        <none>        443/TCP          5d18h
mysvc        NodePort    10.100.166.208   <none>        8080:30001/TCP   21s

案例一nginx端口暴露

我直接写到一起拉 直接创建一个pod就可以
vim nginx-depl.yml

apiVersion: apps/v1
kind: Deployment
metadata:name: dep01
spec:selector:matchLabels:app: nginxreplicas: 2template:metadata:name: testnginx9labels:app: nginxspec:containers:- name: testnginx9image: daocloud.io/library/nginx:1.12.0-alpineports:- containerPort: 80
---
apiVersion: v1
kind: Service
metadata:name: mysvc
spec:type: NodePortports:- port: 8080nodePort: 30001targetPort: 80selector:app: nginx

在这里插入图片描述通信原理概念图
在这里插入图片描述创建pod测试

kubectl apply -f nginx-depl.yml

访问10.8.156.119:3001
在这里插入图片描述访问10.8.156.120:3001
在这里插入图片描述

案例二tomcat端口暴露

我先用node节点把镜像拉下来拉,先拉后拉都一样,没有会自己拉取
node节点都操作
在这里插入图片描述

docker pull daocloud.io/library/tomcat:8.0.45

在这里插入图片描述master节点操作
vim tomcat-depl.yml

---
apiVersion: apps/v1
kind: Deployment
metadata:name: dep01
spec:selector:matchLabels:app: tomcatreplicas: 2template:metadata:name: testomcatlabels:app: tomcatspec:containers:- name: testtomcatimage: daocloud.io/library/tomcat:8.0.45ports:- containerPort: 8080
---
apiVersion: v1
kind: Service
metadata:name: mysvc
spec:type: NodePortports:- port: 8081nodePort: 30003targetPort: 8080selector:app: tomcat

在这里插入图片描述创建一个pod测试

[root@k8s-mastet deployment.yaml]# kubectl apply -f tomcat-depl.yml
deployment.apps/dep01 created
service/mysvc created
[root@k8s-mastet deployment.yaml]# kubectl get pods
NAME                     READY   STATUS    RESTARTS   AGE
dep01-76b88bb67b-8kgmh   1/1     Running   0          7s
dep01-76b88bb67b-s66z8   1/1     Running   0          7s
[root@k8s-mastet deployment.yaml]#

在这里插入图片描述测试10.8.156.119:3003
在这里插入图片描述
测试10.8.156.120:3003
在这里插入图片描述

案例三jenkins端口暴漏

步骤一:先去拉去镜像,或者自己dockerfile自己编写一个
在这里插入图片描述
node节点上面都拉取一下
master节点去编写 vim jenkins-depl.yml

---
apiVersion: apps/v1
kind: Deployment
metadata:name: dep02
spec:selector:matchLabels:app: jenkinsreplicas: 2template:metadata:name: testjenkinslabels:app: jenkinsspec:containers:- name: testjenkinsimage: daocloud.io/library/jenkins:2.60.2
---
apiVersion: v1
kind: Service
metadata:name: mysvc
spec:type: NodePortports:- port: 8083nodePort: 30011targetPort: 8080selector:app: jenkins

跟上面思路一样,
在这里插入图片描述
创建 pod

kubectl apply -f jenkins-depl.yml

访问测试
10.8.156.118:30011
在这里插入图片描述
访问测试
10.8.156.120:30011
在这里插入图片描述

这篇关于k8s、Deployment多副本资源详解、SERVICE通信、案例一nginx端口暴漏、案例二tomcat端口暴漏、案例三jenkins端口暴漏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/875786

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

客户案例:安全海外中继助力知名家电企业化解海外通邮困境

1、客户背景 广东格兰仕集团有限公司(以下简称“格兰仕”),成立于1978年,是中国家电行业的领军企业之一。作为全球最大的微波炉生产基地,格兰仕拥有多项国际领先的家电制造技术,连续多年位列中国家电出口前列。格兰仕不仅注重业务的全球拓展,更重视业务流程的高效与顺畅,以确保在国际舞台上的竞争力。 2、需求痛点 随着格兰仕全球化战略的深入实施,其海外业务快速增长,电子邮件成为了关键的沟通工具。

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

90、k8s之secret+configMap

一、secret配置管理 配置管理: 加密配置:保存密码,token,其他敏感信息的k8s资源 应用配置:我们需要定制化的给应用进行配置,我们需要把定制好的配置文件同步到pod当中容器 1.1、加密配置: secret: [root@master01 ~]# kubectl get secrets ##查看加密配置[root@master01 ~]# kubectl get se

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识