Ingress-nginx 与 Nginx-ingress
一、概述
Ingress-nginx:它是由Kubernetes社区基于Nginx Web服务器开发的,并补充了一组用于实现额外功能的Lua插件,作为“官方”默认控制器支持当然最优。
Github:https://github.com/kubernetes/ingress-nginx
说明文档:https://kubernetes.github.io/ingress-nginx/deploy/
Nginx-ingress:这是Nginx官方社区开发产品,Nginx ingress具有很高的稳定性,持续的向后兼容性,没有任何第三方模块,并且由于消除了Lua代码而保证了较高的速度。
Github:https://github.com/nginxinc/kubernetes-ingress
说明文档:https://docs.nginx.com/nginx-ingress-controller/installation/installation-with-manifests/
差异对比:

更多详情:https://github.com/nginxinc/kubernetes-ingress/blob/master/docs/nginx-ingress-controllers.md
二、自定义配置
Ingress-nginx:
apiVersion: v1
kind: ConfigMap
metadata:
labels:
helm.sh/chart: ingress-nginx-2.13.0
app.kubernetes.io/name: ingress-nginx
app.kubernetes.io/instance: ingress-nginx
app.kubernetes.io/version: 0.35.0
app.kubernetes.io/managed-by: Helm
app.kubernetes.io/component: controller
name: ingress-nginx-controller
namespace: ingress-nginx
data:
proxy-connect-timeout: 5
proxy-read-timeout: 60
client-body-buffer-size: "8k"
worker-processes: ""
max-worker-connections: 16384
更多公共配置参考:https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/
特定Ingress配置:https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/annotations/
Nginx-ingress:
apiVersion: v1
metadata:
name: nginx-config
namespace: nginx-ingress
data:
proxy-connect-timeout: "60s"
proxy-read-timeout: "60s"
client-max-body-size: "80m"
worker-processes: ""
worker-connections: ""
external-status-address: "10.88.88.108"
常用配置说明:
proxy-connect-timeout: 定义与代理服务器建立连接的超时,默认60s。请注意,此超时通常不能超过75秒。
proxy-read-timeout: 定义用于从代理服务器读取响应的超时,默认60s。超时仅在两次连续的读取操作之间设置,而不用于传输整个响应。
如果代理服务器在此时间内未传输任何内容,则连接将关闭。
client-max-body-size: 设置客户端请求正文的最大允许大小,默认1m,在“ Content-Length”请求标头字段中指定。
如果请求中的大小超过配置的值,则会向客户端返回413(请求实体太大)错误。
请注意,浏览器无法正确显示此错误。设置size为0将禁用客户端请求主体大小的检查。
worker-processes: 定义工作进程数。最佳值取决于许多因素,包括(但不限于)CPU内核数,存储数据的硬盘驱动器数以及加载模式。
如有疑问,将其设置为可用的CPU内核数将是一个不错的开始(默认值“auto”将尝试自动检测)。worker-connections: 设置工作进程可以打开的最大同时连接数,默认1024。
应当记住,该数目包括所有连接(例如,与代理服务器的连接等),而不仅包括与客户端的连接。
另一个需要考虑的因素是,并发连接的实际数量不能超过打开文件最大数量的当前限制,可以通过worker_rlimit_nofile进行更改 。external-status-address: 设置要在Ingress资源状态下负载的地址,需要-report-status命令行参数,并且将覆盖-external-service参数。
三、资源定义
1) 同一域名,不同URL被转发不同服务
Ingress-nginx:
apiVersion: networking.k8s.io/v1beta1
kind: Ingress
metadata:
name: ymtapi
namespace: ymt
annotations:
kubernetes.io/ingress.class: "nginx"
spec:
rules:
- host: k8s.ymtapi.org
http:
paths:
- path: /wxapi
backend:
serviceName: apprestserver
servicePort: 8114
- path: /api
backend:
serviceName: appsocialmanservice
servicePort: 8113
Nginx-ingress:
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: ymtapi
namespace: ymt
annotations:
kubernetes.io/ingress.class: "nginx"
spec:
rules:
- host: k8s.ymtapi.org
http:
paths:
- path: /wxapi
backend:
serviceName: apprestserver
servicePort: 8114
- path: /api
backend:
serviceName: appsocialmanservice
servicePort: 8113
2) 不同域名被转发不同服务
Ingress-nginx:
apiVersion: networking.k8s.io/v1beta1
kind: Ingress
metadata:
name: prometheus
namespace: monitoring
annotations:
kubernetes.io/ingress.class: "nginx"
spec:
rules:
- host: k8s.grafana.com
http:
paths:
- path: /
backend:
serviceName: grafana
servicePort: 3000 - host: k8s.prometheus.com
http:
paths:
- path: /
backend:
serviceName: prometheus-k8s
servicePort: 9090 - host: k8s.alertmanager.com
http:
paths:
- path: /
backend:
serviceName: alertmanager-main
servicePort: 9093
Nginx-ingress:
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: prometheus
namespace: monitoring
spec:
rules:
- host: k8s.grafana.com
http:
paths:
- path: /
backend:
serviceName: grafana
servicePort: 3000 - host: k8s.prometheus.com
http:
paths:
- path: /
backend:
serviceName: prometheus-k8s
servicePort: 9090 - host: k8s.alertmanager.com
http:
paths:
- path: /
backend:
serviceName: alertmanager-main
servicePort: 9093
3)不使用域名的转发
Ingress-nginx:
apiVersion: networking.k8s.io/v1beta1
kind: Ingress
metadata:
name: ymtapi
namespace: ymt
annotations:
kubernetes.io/ingress.class: "nginx"
spec:
rules:
- http:
paths:
- path: /WxTransWeb
backend:
serviceName: wxtransweb
servicePort: 8080
Nginx-ingress:
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: ymtapi
namespace: ymt
annotations:
kubernetes.io/ingress.class: "nginx"
nginx.org/server-snippets: "server_name ~^.*$;"
spec:
rules:
- host: k8s.ymtapi.org
http:
paths:
- path: /WxTransWeb
backend:
serviceName: wxtransweb
servicePort: 8080
注意:Nginx-ingress要求host必须存在,也就是必须使用域名,如果想直接使用IP访问,则只能通过设置"server_name ~^.*$;"实现,即同时支持域名和IP访问,但是仅能设置一个Ingress。
Github issue:https://github.com/nginxinc/kubernetes-ingress/issues/209#issuecomment-581691384
4)基于TLS的安全设置
Ingress-nginx:
apiVersion: networking.k8s.io/v1beta1
kind: Ingress
metadata:
name: dashboard
namespace: kubernetes-dashboard
annotations:
kubernetes.io/ingress.class: "nginx"
nginx.ingress.kubernetes.io/ssl-redirect: "true"
nginx.ingress.kubernetes.io/backend-protocol: "HTTPS"
spec:
tls:
- hosts:
- k8s.dashboard.com
secretName: tls-secret
rules:
- host: k8s.dashboard.com
http:
paths:
- path: /
backend:
serviceName: kubernetes-dashboard
servicePort: 443
Nginx-ingress:
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: dashboard
namespace: kubernetes-dashboard
annotations:
nginx.org/redirect-to-https: "true"
ingress.kubernetes.io/ssl-redirect: "true"
nginx.org/ssl-services: "kubernetes-dashboard"
spec:
tls:
- hosts:
- k8s.dashboard.com
secretName: tls-secret
rules:
- host: k8s.dashboard.com
http:
paths:
- path: /
backend:
serviceName: kubernetes-dashboard
servicePort: 443
作者:Leozhanggg
出处:https://www.cnblogs.com/leozhanggg/p/13603215.html
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
Ingress-nginx 与 Nginx-ingress的更多相关文章
- 使用 NGINX 和 NGINX Plus 的 Ingress Controller 进行 Kubernetes 的负载均衡
运行和管理跨机器集群的大规模的容器微服务应用是一个极具挑战的任务.Kubernetes 提供了一个强大的容器编排解决方案,从而帮助我们迎接这个挑战.它包含了一些重要特性,比如容错,自动伸缩,滚动升级, ...
- Nginx配置文件nginx.conf中文详解(转)
######Nginx配置文件nginx.conf中文详解##### #定义Nginx运行的用户和用户组 user www www; #nginx进程数,建议设置为等于CPU总核心数. worker_ ...
- 苹果下如果安装nginx,给nginx安装markdown第三方插件
用brew install nginx 这样安装的是最新版的nginx, 但是在有些情况下,安装第三方插件需要特定的版本,更高一级的版本可能装不上. 它的原理是下载安装包进行自动安装,建立软链,这样就 ...
- Nginx research, nginx module development
catalog . 初探nginx架构 . handler模块 . Nginx编译.安装.配置 . Hello World模块开发 1. 初探nginx架构 nginx在启动后,在unix系统中会以d ...
- 通过Nginx和Nginx Plus阻止DDoS攻击
分布式拒绝服务攻击(DDoS)指的是通过多台机器向一个服务或者网站发送大量看似合法的数据包使其网络阻塞.资源耗尽从而不能为正常用户提供正常服务的攻击手段.随着互联网带宽的增加和相关工具的不断发布,这种 ...
- 解决Nginx: [error] open() "/usr/local/Nginx/logs/Nginx.pid
重新启动服务器,访问web服务发现无法浏览啦!登陆服务器之后进到nginx使用./nginx -s reload重新读取配置文件,发现报nginx: [error] open() "/usr ...
- nginx: [error] invalid PID number "" in "/usr/local/nginx/logs/nginx.pid"
iwangzheng.com tty:[0] jobs:[0] cwd:[/opt/nginx/conf] 12:45 [root@a02.cmsapi]$ /usr/local/nginx/sbin ...
- Nginx 报错: nginx: [error] open() "/usr/local/nginx/logs/nginx.pid" failed (2: No such file or directory) 的解决方法
今天测试域名访问不了,登陆 Linux(Ubuntu)重启Nginx: nginx -s reload 结果报错: nginx: [error] open() : No such file or di ...
- 解决nginx: [error] open() "/usr/local/nginx/logs/nginx.pid" failed错误
重新启动服务器,访问web服务发现无法浏览,登陆服务器之 后进到nginx使用./nginx -s reload重新读取配置文件,发现报nginx: [error] open() "/usr ...
- Nginx配置文件nginx.conf详细说明
Nginx配置文件nginx.conf详细说明 #worker_processes 8; #worker_cpu_affinity 00000001 00000010 00000100 0000100 ...
随机推荐
- 重学c#系列——异常(六)
前言 用户觉得异常是不好的,认为出现异常是写的人的问题. 这是不全面,错误的出现并不总是编写程序的人的原因,有时会因为应用程序的最终用户引发的动作或运行代码的环境而发生错误,比如你用android4去 ...
- 为什么 2020 还要学 Node.js
更佳阅读体验 https://www.yuque.com/sunluyong/node 前言 前些日子刷知乎看到个 2019 年初的问题 2019年nodejs凉了吗?凉到什么程度了?才看到问题的时候 ...
- 【mysql数据库基础】
基础:·数据库的本质是一个文件·行---记录·列---字段·RDBMS是一个程序·SQL是结构化的查询语言·MYSQL是一个数据库软件,可以通过SQL操作MYSQL数据库·SQL语句不区分大小写·学了 ...
- 利用Python操作MySQL数据库
前言 在工作中,我们需要经常对数据库进行操作,比如 Oracle.MySQL.SQL Sever 等,今天我们就学习如何利用Python来操作 MySQL 数据库. 本人环境:Python 3.7.0 ...
- 学学Viewbinding
Viewbinding 1.环境需求 环境上,需要Android Studio 3.6 Canary 11+ 同样的Gradle也需要升级(这年头都4.0了,应该没有还在用低版本的了吧...) 2.配 ...
- Java实现短信验证码
前言 本人使用的是阿里短信服务,一开始尝试了许多不同的第三方短信服务平台,比如秒滴科技.梦网云通讯.当初开始为什么会选择这两个,首先因为,他们注册就送10元钱(#^.^#),但是后来却发现他们都需要认 ...
- Unity 笔记
摄像机 Main Camera 跟随主角移动,不看 UI 剧情摄像机 当进入剧情时,可以关闭 main camera,启用剧情摄像机,不看 UI UI 摄像机 看 UI Unity编辑器常用的sett ...
- nginx进程模型解析
nginx进程模型解析 概念 master会发送请求给worker,用于处理用户的请求,模型图如下 nginx进程分类 master进程(只有1个) 接受信号传递给worker wo ...
- C#LeetCode刷题之#326-3的幂(Power of Three)
问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3867 访问. 给定一个整数,写一个函数来判断它是否是 3 的幂次 ...
- storcli 命令(更新Ing)
help [root@centos7]# storcli -h Storage Command Line Tool Ver 007.0606.0000.0000 Mar , (c)Copyright ...