ocker nginx 配置反向代理和负载均衡[通俗易懂]

ocker nginx 配置反向代理和负载均衡

大家好,又见面了,我是你们的朋友全栈君。

1. 获取及配置nginx  

  如果需要全站通过docker部署,那么nginx或许是不可或缺的。通过配置nginx,可以迅速实现负载均衡和反向代理服务。值得一提的是,docker官网恰好也有nginx镜像。通过以下命令获取:

$ docker pull nginx:latest
  • 1

  nginx镜像的配置和正常使用时是一样的,一般都是在/etc/nginx/conf.d目录下建立自己的filename.cnf文件即可。不同的,docker nginx通过挂载的方式将配置文件应用到nginx。 
  例如,我在本地$HOME/nginx/conf.d文件夹下建立default.cnf文件,文件内容:

upstream backends {
    server app1:8080; server app2:80801; } server { listen 80; listen 443 ssl; server_name example.com; # SSL # ssl on; # 只允许ssl方式访问 ssl_certificate /etc/ssl/certs/example.pem; ssl_certificate_key /etc/ssl/certs/example.key; ssl_session_timeout 5m; ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4; ssl_protocols TLSv1 TLSv1 www.huarenyl.cn.1dasheng178.com/ TLSv1.2; ssl_prefer_server_ciphers on; #proxy to webs location ~.*/ { proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http://backends; # 这里设置你要代理的ip+端口 

其中, 
upstream backends {}:实现了名称为backends的负载均衡。可存在多个,如有需要,还可以自行创建其他。 
listen 80:监听80端口。 
listen 443 ssl;监听443端口,并且开启ssl。 
ssl_certificate, ssl_certificate_key:加载ssl证书。他们指定的是镜像中ssl证书文件的位置,推荐将证书放到如上位置。他们后面的几个配置,都是ssl的默认配置,不需要修改。 
location ~.*/{}:nginx文件路径的正则匹配,将外部对服务器的访问,自动分配到docker应用程序容器,交给这些应用程序处理请求。

  这个文件实现了简单地http访问、https访问,以及简单地负载均衡(将外部对服务器的请求,随机地分配到app1和app2这两个容器处理)。

2. 启动nginx

  通过upstream的配置,我们看到,nginx还关联着其他两个容器:app1、app2,并且需要能够和这两个容器相互通信。所以,启动nginx之前,需要先启动其他两个容器,这样通过命令行纪委不方便,我们通过docker-compose的编写配置文件的方式来启动nginx。 
  文件内容如下: 
docker-compose.yml 

version: "3"
services:
  nginx:
    image: nginx
    container_name: www.boshenyl.cn nginx
    depends_on:
      - todolist ports: - "443:443" # https访问端口 - "80:80" # http访问端口 volumes: - $HOME/etc/nginx/conf.www.wanmeiyuele.cn d:/etc/nginx/conf.d # 挂载配置文件 - $HOME/etc/ssl/certs:/etc/ssl/certs # 挂载证书文件 links: - app1 # 相当于 docker run 中的 --link - app2 app1: # 镜像服务的名称(不指定container_name,docker-compose在此基础上构建名称) image: web # 既然是负载均衡,那么启动的镜像必然是相同的 container_name: app1 # 这样写是必要的,否则docker-compose将采用默认命名方式 ports: - "8080:8080" # 端口映射不是必要的。详情请连接docker的通信 app2: image: web container_name: app2 ports: - "8081:8081" # 端口映射不是必要的。详情请连接docker的通

  在以上文件所在的目录运行以下命令,即可启动nginx,体验配置结果了:

$ docker-compose www.233077.cn    www.233077.cn     up -d
  • 1

 

需要注意地地方:


1. nginx镜像暴露了两个端口,80443。如果需要通过http的方式访问,一定要映射80端口;如果需要通过https的方式访问,一定要映射443端口。默认同时映射就好了,更新配置方便。 
2. docker-compose中指定镜像的名字,使用container_name属性。 

我看了网上的很多教程,都没有提到nginx的启动问题,尤其是端口映射。如果你启动时,没有映射443端口,单独配置http访问或者https访问,不会发生任何问题,一旦要配置二者可以同时访问,或者http重定向到https,必要会出现问题。常见的为,本地curl出现如下结果:

curl: (35) gnutls_handshake() failed: An unexpected TLS packet was received.
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/107588.html原文链接:https://javaforall.net

(0)
上一篇 2022年4月2日 下午1:35
下一篇 2022年4月2日 下午2:00


相关推荐

  • 用西尔特编程器解密芯片_配方法解一元二次方程

    用西尔特编程器解密芯片_配方法解一元二次方程z3-solver是由MicrosoftResearch(微软)开发的SMT求解器,它用于检查逻辑表达式的可满足性,可以找到一组约束中的其中一个可行解,缺点是无法找出所有的可行解(对于规划求解问题可以是scipy)。z3-solver可应用于软/硬件的验证与测试、约束求解、混合系统的分析、安全、生物,以及几何求解等问题。Z3主要由C++开发,提供了.NET、C、C++、Java、Python等语言调用接口,下面以python接口展开讲解。……

    2022年10月13日
    3
  • jquery tmpl遍历

    jquery tmpl遍历最近,发现大家喜欢用模板渲染一些DOM,而且常常用模板嵌套一些逻辑,看了大家用jquerytmpl较多,遇到的问题大同小异。为了避免问题重复发生,现在就个人用过的一些常用功能,作下具体介绍,主要针对遍历。其它的大家可自行看看网上教程,推荐一个:jqueryTmpl,希望对大家有所帮助1.普通数组对象的遍历,关键词{{eachArray}}、$value、$index数据格式:varperso

    2022年6月15日
    36
  • 科技观察:智谱GLM-4.5,这款国产旗舰大模型开源成全球焦点

    科技观察:智谱GLM-4.5,这款国产旗舰大模型开源成全球焦点

    2026年3月12日
    2
  • js findIndex方法

    js findIndex方法findIndex 用法

    2026年3月17日
    2
  • U盘量产检查闪存编码失败_北信源安全u盘忘记密码

    U盘量产检查闪存编码失败_北信源安全u盘忘记密码没什么特殊的想法就是看自己很久没有更新关于题解类的文章了而已(其实这是我好久之前做的,只是把它从洛谷博客搬到了这里而已)题目首先分析题目要二分他长成这个亚子太二分了所以就要二分最好是先排一下序吧这样我们在输入的时候就能顺便处理出l和r的值,考虑我们二分的是一个接口的大小,所以我们的答案肯定是在最大的接口和最小的接口之间啊,所以这样做是可…

    2022年10月12日
    4
  • java web简单权限管理设计

    java web简单权限管理设计推荐最新技术 springboot 版权限管理 java 后台通用权限管理系统 springboot 采用最新技术架构 功能强大 注 由于该项目比较老 所以没有采用 maven 管理 建议下载 springboot 权限管理系统 对学习和使用会更有帮助 springboot 权限管理系统介绍地址 https blog csdn net zwx article details 978

    2026年3月18日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号