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

相关文章

Nginx安全防护的多种方法

《Nginx安全防护的多种方法》在生产环境中,需要隐藏Nginx的版本号,以避免泄漏Nginx的版本,使攻击者不能针对特定版本进行攻击,下面就来介绍一下Nginx安全防护的方法,感兴趣的可以了解一下... 目录核心安全配置1.编译安装 Nginx2.隐藏版本号3.限制危险请求方法4.请求限制(CC攻击防御)

MySQL 主从复制部署及验证(示例详解)

《MySQL主从复制部署及验证(示例详解)》本文介绍MySQL主从复制部署步骤及学校管理数据库创建脚本,包含表结构设计、示例数据插入和查询语句,用于验证主从同步功能,感兴趣的朋友一起看看吧... 目录mysql 主从复制部署指南部署步骤1.环境准备2. 主服务器配置3. 创建复制用户4. 获取主服务器状态5

nginx中端口无权限的问题解决

《nginx中端口无权限的问题解决》当Nginx日志报错bind()to80failed(13:Permissiondenied)时,这通常是由于权限不足导致Nginx无法绑定到80端口,下面就来... 目录一、问题原因分析二、解决方案1. 以 root 权限运行 Nginx(不推荐)2. 为 Nginx

一文详解如何使用Java获取PDF页面信息

《一文详解如何使用Java获取PDF页面信息》了解PDF页面属性是我们在处理文档、内容提取、打印设置或页面重组等任务时不可或缺的一环,下面我们就来看看如何使用Java语言获取这些信息吧... 目录引言一、安装和引入PDF处理库引入依赖二、获取 PDF 页数三、获取页面尺寸(宽高)四、获取页面旋转角度五、判断

Spring Boot中的路径变量示例详解

《SpringBoot中的路径变量示例详解》SpringBoot中PathVariable通过@PathVariable注解实现URL参数与方法参数绑定,支持多参数接收、类型转换、可选参数、默认值及... 目录一. 基本用法与参数映射1.路径定义2.参数绑定&nhttp://www.chinasem.cnbs

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

Redis中Stream详解及应用小结

《Redis中Stream详解及应用小结》RedisStreams是Redis5.0引入的新功能,提供了一种类似于传统消息队列的机制,但具有更高的灵活性和可扩展性,本文给大家介绍Redis中Strea... 目录1. Redis Stream 概述2. Redis Stream 的基本操作2.1. XADD

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

nginx 负载均衡配置及如何解决重复登录问题

《nginx负载均衡配置及如何解决重复登录问题》文章详解Nginx源码安装与Docker部署,介绍四层/七层代理区别及负载均衡策略,通过ip_hash解决重复登录问题,对nginx负载均衡配置及如何... 目录一:源码安装:1.配置编译参数2.编译3.编译安装 二,四层代理和七层代理区别1.二者混合使用举例

Java JDK1.8 安装和环境配置教程详解

《JavaJDK1.8安装和环境配置教程详解》文章简要介绍了JDK1.8的安装流程,包括官网下载对应系统版本、安装时选择非系统盘路径、配置JAVA_HOME、CLASSPATH和Path环境变量,... 目录1.下载JDK2.安装JDK3.配置环境变量4.检验JDK官网下载地址:Java Downloads