nginx负载均衡不生效的坑,ng解决跨域问题

nginx负载均衡不生效的坑,ng解决跨域问题

  • 先看下我的负载均衡配置

先看下我的负载均衡配置

upstream upstream.name{
        server 192.169.0.1:8001;
        server 192.169.0.2:8002;
    }
    server { 
		listen		8888; 
		server_name	test; 
		location / { 
			#允许跨域请求的域,*代表所有
			add_header 'Access-Control-Allow-0rigin' *;
			#允许带上cookie请求
			add_header 'Access-Control-Allow-Credentials' 'true';
			#允许请求的方法,比如GET/POST/PUT/DELETE
			add_header 'Access-Control-Allow-Methods' *;
			#允许请求的header
			add_header 'Access-Control-Allow-Headers' *;
			proxy_pass http://upstream.name;
			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,访问我的ng的8888端口号都是拒绝访问,百度了也没有找到好的方法;
  • 我的ng上是有其他负载的,其他负载是能够访问到的,说明ng是没有问题的;然后我就把原来好的负载端口号改了,下面再访问新修改的端口号就进不去了,到这里,总算想到了原因,那就是服务器的防火墙端口暴露问题;

然后执行下面的操作就OK了:

firewall-cmd --zone=public --add-port=8888/tcp --permanent  暴露8888端口
systemctl restart firewalld.service     防火墙重启

执行完上面的操作就可以正常负载到后台服务了。
这是我之前踩到的坑,希望对大家有所帮助。

下面奉上ng启动的时候遇到的坑

  1. ps -ef|grep nginx ;
    你会发现你的服务器上面启动了n个ng服务,你还不一定知道哪个是你要重启的;

  2. 进入到/usr/local/nginx/sbin/ 目录下面;
    你会发现一个交nginx的文件;使用以下命令操作:

./nginx -t  检查配置文件
./nginx -s stop  停止当前nginx服务
ps -ef|grep nginx  查看当前运行的nginx服务,此时应该停掉了当前的ng
./nginx    直接启动当前ng服务就OK了

到此所有的问题都以完美解决;

下面奉上ng解决跨域问题

#设置需要跨域的指定文件
location ^~/res/ {
    add_header Access-Control-Allow-Origin *;
    add_header Access-Control-Allow-Methods 'GET,POST';
    add_header Access-Control-Allow-Headers 'DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization';
    alias /data/web/res/;
}
#设置允许全局跨域
server {   ....
    add_header Access-Control-Allow-Origin *;
    add_header Access-Control-Allow-Methods 'GET,POST';
    add_header Access-Control-Allow-Headers 'DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization';  
}

大家如果有好的方法,欢迎留言讨论。

你可能感兴趣的:(java,nginx,java)