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启动的时候遇到的坑
-
ps -ef|grep nginx ;
你会发现你的服务器上面启动了n个ng服务,你还不一定知道哪个是你要重启的; -
进入到/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';
}
大家如果有好的方法,欢迎留言讨论。