nginx搭建反向代理配置并测试

前言:

    如今信息时代,对于web服务器的要求很高,既要性能,又要稳定性,又经济最好免费,还要满足公司的各大奇葩业务需求,越来越挑剔,就像你去买手机,中意的是外观好看,功能强大,拍照清晰,存储大,不死机不闪退,充电快,质量好能当‘砖头’使,操作简单顺手,价格便宜,最主要看电影玩游戏爽,总之使用起来要爽,哈哈。。。   互联网上主流的web服务器有 nginx,  Apache, Squid, IIS, kangle, WebSphere,  WebLogic, Tomcat, Jboss, TrafficServer等等, 我玩过的就nginx,Apache, TrafficServer三款,其它不熟, Apache由于不可扩展,不可定制,固满足不了公司一些需求,TrafficServer 开源产品 c++编写,功能强大,可搭建集群,国人用得不多,知道的人也不多,大公司在用(阿里),小公司用不起,bug太多,难维护,  Nginx现在用的人越来越多,优点如下:

           1.模块化的功能集,第三方模块丰富,占用资源小,稳定性强,

           2.可扩展性强,官方文档资料全,安装配置简单,官方代码贡献者活跃,不断有更新,

           3.Nginx从头开始都是纯C实现,采用多进程和异步机制(异步非阻塞),内存消耗极小,官方统计,单台能达到50000并发请求量。

           4.支持负载均衡,跨平台,能满足公司很多需求。


笔者的系统centos6.5

首先装好linux系统 ,此处略。


nginx:      192.168.4.72           #nginx安装的位置及apache位置

apache:  192.168.4.69           #要代理的两台服务器

apache:  192.168.4.68

一、安装gcc

   yum install gcc-c++ -y


二、安装nginx所需要的依赖库

   yum -y install zlib-devel openssl-devel pcre-devel


三、如有安装老版本,则卸载。

   查看:find -name nginx

   卸载:yum remove nginx


四、下载nginx源码并解压.(源码去官网下载, 以下是官方链接)

    wget -c http://nginx.org/download/nginx-1.6.2.tar.gz

    tar -zxvf nginx-1.6.2.tar.gz

    mv nginx-1.6.2 nginx

    cd nginx

    ./configure --user=nginx --group=nginx --prefix=/usr/local/nginx

    --with-http_addition_module

    --with-http_flv_module --with-http_gzip_static_module

    --with-http_realip_module --with-http_ssl_module

    --with-http_stub_status_module --with-http_sub_module

    --with-http_dav_module

注:这里--with开头的选项为nginx自带的模块,需要什么就添加,默认是不安装,


    make

    make install


五、建立nginx用户及用户组

      groupadd -r nginx

    useradd  -s /sbin/nologin -g nginx -r nginx
  
cd 到nginx目录,看能否启动
sbin/nginx           #如果没有报错,说明ok

再ps一下,ps ax | grep nginx,看到如下,说明ok
               2537 ?        Ss     0:00 nginx: master process sbin/nginx
               2538 ?        S      0:00 nginx: worker process

           nginx在启动后,会有一个master进程和多个worker进程。master进程主要用来管理worker进程,包含:接收来自外界的信号,向各worker进程发送信号,监控worker进程的运行状态,当worker进程退出后(异常情况下),会自动重新启动新的worker进程。

 查看安装的nginx版本:
            sbin/nginx -v
 查看安装的编译选项:
           sbin/nginx -V


六、下面开始配置nginx,及反向代理,编辑配置文件nginx.conf

    vim /usr/local/nginx/conf/nginx.conf


   user nginx nginx;                                   #这里是nginx运行的用户

   worker_processes 2;                            #设置nginx服务的worker子进程,比如设为2:

   error_log logs/error.log;                        #去掉前面的#,记录nginx错误日志,方便检查bug:

   pid logs/nginx.pid;                                 #nginx的pid位置


events {
             worker_connections  1024;       #每个进程允许的最多连接数,
 }

http {

      include   mime.types;

     default_type  application/octet-stream;

   #把下面的#去掉,这是日志配置:

   log_format  main  '$remote_addr - $remote_user [$time_local] "$request"     '

                       '$status $body_bytes_sent "$http_referer" '

                       '"$http_user_agent" "$http_x_forwarded_for"';

   access_log logs/access.log main;                      #日志存放位置


#这里很关键,很多小伙伴问我 “负载均衡乍配置,为啥我配置的不能访问呢“,这里的upstream就是配置负载均衡的,当然得两台以上才叫负载,我这里的ip69和68都是

#用的apache,   也许你们的是tomcat, 没关系,按这样配置一样可以,

 upstream proxy_test {

   server 192.168.4.69:80 weight=1;     #如果你要测试,把这里换成你自己要代理后端的ip

   server 192.168.4.68:80 weight=1;

   #ip_hash;                                              #当负载两台以上用ip来hash解决session的问题,一台就别hash了。

 }

这是server段的配置

server {

    listen       80;

    server_name  www.test.com;    #要访问的域名,我这里用的测试域名,如果有多个,用逗号分开


    charset utf8;


    location / {

        proxy_pass       http://proxy_test;               #这里proxy_test是上面的负载的名称,映射到代理服务器,可以是ip加端口,   或url 

        proxy_set_header Host      $host;

        proxy_set_header X-Real-IP $remote_addr;

        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

      }

   }

}

保存退出!

nginx平滑重启:nginx -s reload   #加载刚刚加入的配置。


七、测试:

     后端服务器开启,在192.168.4.69和68的网页文件位置添加测试文件test.html, 内容69上: this is test 69,     68上:this is test 68,这样方便查看访问到哪台了。

      在本地配置好host,在\Windows\System32\drivers\etc\hosts              用记事本打开,在最后一行加入:192.168.4.72 www.test.com

     然后使用cmd,ping www.test.com   是否能ping通这个192.168.4.72地址,如果ok,则继续

打开浏览器用www.test.com去访问后端服务器的文件,

如: www.test.com/test.html,

    浏览器打开显示有this...说明配置ok了。

然后F5刷新一下,如果是68和69不停的切换,说明负载ok了。


如果还有什么不懂的,加我们的技术群解答(284215611)

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要在Docker中使用Nginx反向代理,可以按照以下步骤进行配置: 1.首先,创建一个名为 `proxy` 的网络: ``` docker network create proxy ``` 2.创建一个Nginx容器,并将其连接到 `proxy` 网络: ``` docker run --name nginx-proxy --network proxy -p 80:80 -d nginx ``` 3.创建一个要反向代理的应用程序容器,并将其连接到 `proxy` 网络。确保应用程序容器具有一个标识符,以便Nginx可以识别它: ``` docker run --name app --network proxy -d your_app_image ``` 4.在Nginx容器中,创建一个名为 `proxy.conf` 的文件,其中包括反向代理配置。以下是一个示例配置文件: ``` server { listen 80; server_name your_domain.com; location / { proxy_pass http://app:3000; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } } ``` 该配置文件将请求 `your_domain.com` 的所有请求转发到连接到 `proxy` 网络的名为 `app` 的应用程序容器的端口3000。 5.将 `proxy.conf` 文件复制到Nginx容器中: ``` docker cp proxy.conf nginx-proxy:/etc/nginx/conf.d/ ``` 6.重新加载Nginx配置: ``` docker exec nginx-proxy nginx -s reload ``` 现在,当您访问 `your_domain.com` 时,Nginx将自动将请求转发到连接到 `proxy` 网络的名为 `app` 的应用程序容器的端口3000。 ### 回答2: 使用Docker配置Nginx反向代理非常简单。反向代理是指将客户端的请求转发到后端服务器上,实现负载均衡和高可用性。 首先,确保已经安装了Docker和Docker Compose。在项目目录下创建一个名为`docker-compose.yml`的文件,内容如下: ``` version: '3' services: nginx: image: nginx ports: - "80:80" volumes: - ./nginx.conf:/etc/nginx/conf.d/default.conf restart: always ``` 在同一目录下创建一个名为`nginx.conf`的文件,这是Nginx配置文件,示例内容如下: ``` server { listen 80; server_name example.com; location / { proxy_pass http://backend-server; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } } ``` 在上面的示例中,`example.com`是你的域名,你可以根据自己的需求进行修改。`http://backend-server`是你要代理的后端服务器的地址,可以是IP地址或者域名。 保存并关闭文件后,在项目目录下打开终端,运行以下命令启动Nginx容器: ``` docker-compose up -d ``` 这将拉取Nginx镜像并在后台运行容器。你可以通过访问`http://localhost`来验证反向代理是否正常工作。 在实际应用中,你可能需要配置更复杂的Nginx反向代理规则,例如添加SSL证书、使用多个后端服务器等。你可以根据实际需求修改`nginx.conf`文件并重新启动Nginx容器来实现这些功能。 总的来说,使用Docker配置Nginx反向代理非常方便。只需编写一个简单的Docker Compose文件和Nginx配置文件,就可以快速搭建一个强大的反向代理服务器。 ### 回答3: Docker是一款开源的容器化平台,Nginx是一款高性能的HTTP服务器和反向代理服务器。在使用Docker部署应用时,可以使用Nginx作为反向代理来实现负载均衡、缓存和SSL终止等功能。 配置Docker中的Nginx反向代理有以下几个步骤: 1. 创建Nginx配置文件:在Docker中创建一个用于存放Nginx配置文件的目录,如`/etc/nginx`。 2. 编写Nginx配置文件:在上述目录中创建一个名为`nginx.conf`的文件,并编辑该文件,设置反向代理的规则。例如,可使用`proxy_pass`指令指定服务器的地址和端口号。 3. 创建Docker镜像:使用Dockerfile来创建一个Nginx镜像。其中,可以通过`COPY`指令将上述Nginx配置文件拷贝到镜像内的`/etc/nginx`目录中。 4. 构建和运行容器:使用Docker命令构建Nginx镜像,并运行容器。运行容器时,可以使用`-p`选项来映射容器内Nginx实例的端口到宿主机上。 通过上述步骤,即可完成Docker中Nginx配置反向代理。此时,当有请求到达Nginx时,Nginx会根据配置反向代理规则将请求转发到指定的服务器。这样可以实现负载均衡和高可用,提高应用的性能和可靠性。 总之,使用Docker和Nginx进行配置反向代理可以快速、灵活地部署应用,并有效地提升应用的性能和可扩展性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值