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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 代理服务器基本知识[通俗易懂]

    代理服务器基本知识[通俗易懂]代理服务器系列(一):基础知识2005年9月10日世界网络教研组编一、什么是代理服务器?代理服务器英文全称是ProxyServer,其功能就是代理网络用户去取得网络信息。形象的说:它是网络信息的中转站。在一般情况下,我们使用网络浏览器直接去连接其他Internet站点取得网络信息时,需送出Request信号来得到回答,然后对方再把信息以bit方

    2022年4月30日
    55
  • 关于我在黑马程序员培训毕业后的亲身体验

    关于我在黑马程序员培训毕业后的亲身体验首先申明:我本人已经于2016年5月份在广州传智播客java培训完毕业,和黑马程序员官网没有任何的利益往来,也没有人出钱给我帮他们做软文推广,这是我在黑马程序员的亲身体验,不存在虚构。

    2022年7月7日
    34
  • Java获取二维数组行列长度「建议收藏」

    Java获取二维数组行列长度「建议收藏」二维数组intarray[][]=newint[3][3];行长度:array.length列长度:array[i].lengthclassTest{for(inti=0;i

    2022年5月12日
    46
  • 解压缩模块 zipfile

    解压缩模块 zipfilezipfile一、创建一个ZipFile对象,表示一个zip文件classzipfile.ZipFile(file[,mode[,compression[,allowZip64]]])参数file表示文件的路径或类文件对象(file-likeobject)参数mode指示打开zip文件的模式,默认值为’r’,表示读已经存在的zip文件,也可以为’w’或’a’,’w’表示…

    2022年9月17日
    0
  • 学术应用使用node-http-proxy集成谷歌学术「建议收藏」

    学术应用使用node-http-proxy集成谷歌学术「建议收藏」搞科研的同学肯定离不开谷歌学术,谷歌学术搜索是文献搜索下载一大利器。之前实验室开发了一款学术应用,遗留了历史问题,就是没有解决文献搜索的功能,而这个任务最后落在我的身上。我采用的方案就是集成谷歌学术,但是国内的网络环境,你懂的,自然状态下根本就访问不了谷歌学术的,你得翻墙才能访问。你不能期望使用你开发的学术应用都能翻墙访问谷歌学术(虽然搞科研的人电脑翻墙软件肯定都准备好了!),所以呢我还要给谷歌学术

    2022年8月31日
    3
  • 信用卡行为评分风险等级_信用卡综合评分标准

    信用卡行为评分风险等级_信用卡综合评分标准WOE&IVwoe全称叫WeightofEvidence,常用在风险评估、授信评分卡等领域。IV全称是Informationvalue,可通过woe加权求和得到,衡量自变量对应变量的预测能力。虽然网上到处都是神经网络、xgboost的文章,但当下的建模过程中(至少在金融风控领域)并没有完全摆脱logistic模型,原因大致有以下几点:logistic模型客群变化的敏感度不如其他高…

    2025年6月13日
    0

发表回复

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

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