nginx 代理https ,wss及 http ws 同时兼容 (socket.io),留档

定义 $connection_upgrade 变量

# 使用 $http_upgrade 变量来定义 $connection_upgrade 变量
# 如果 $http_upgrade 不为 '' 则$connection_upgrade 为 upgrade
# 如果 $http_upgrade 为 '' 则$connection_upgrade 为 close
map $http_upgrade $connection_upgrade {
    default upgrade;
    '' close;
}

来个负载均衡

# API
upstream apibackend{
    server ip1:port1; # ip和端口组合;
    server ip2:port2;
    keepalive 1000; # 可以认为是空闲连接池大小;
}
# websocket
upstream wsbackend{
    #ws用不了localhost 写具体ip
    server ip1:port1; # ip和端口组合;
    server ip2:port2;
    keepalive 1000; # 可以认为是空闲连接池大小;
}

keepalive 1000 表示的是每个nginx进程中上游服务器保持的空闲连接,当空闲连接过多时,会关闭最少使用的空闲连接.当然,这不是限制连接总数的,可以想象成空闲连接池的大小.设置的值应该是上游服务器能够承受的

反向代理代码

# https ,wss 配置
server {
	listen 443 ssl;
	server_name s.wzero.net;
	
	ssl on;
	ssl_certificate /home/ubuntu/cert/wzero.net/fullchain.cer; # 证书文件 
	ssl_certificate_key /home/ubuntu/cert/wzero.net/wzero.net.key; # 私钥文件

	ssl_session_timeout 5m; # 会话缓存过期时间
	ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # 开启 SSL 支持
	ssl_prefer_server_ciphers on; # 设置协商加密算法时,优先使用服务端的加密套件
        # api 接口代理
	location / {
        	proxy_pass http://apibackend;   #来自jsp请求交给tomcat处理
		proxy_redirect off;
	        proxy_set_header Host $host;    #后端的Web服务器可以通过X-Forwarded-For>获取用户真实IP
	        proxy_set_header X-Real-IP $remote_addr;
	        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
	        client_max_body_size 10m;   #允许客户端请求的最大单文件字节数
	        client_body_buffer_size 128k; #缓冲区代理缓冲用户端请求的最大字节数
	        proxy_connect_timeout 90;   #nginx跟后端服务器连接超时时间(代理连接超时)
	        proxy_read_timeout 90;      #连接成功后,后端服务器响应时间(代理接收超时)
	        proxy_buffer_size 4k;       #设置代理服务器(nginx)保存用户头信息的缓冲区大小
	        proxy_buffers 6 32k;        #proxy_buffers缓冲区,网页平均在32k以下的话>,这样设置
	        proxy_busy_buffers_size 64k; #高负荷下缓冲大小(proxy_buffers*2)
	        proxy_temp_file_write_size 64k; #设定缓存文件夹大小,大于这个值,将从upstream服务器传
	}
        # 基于 socket.io服务器端的websocket代理
        location /socket.io {
                proxy_pass http://wsbackend;
                proxy_http_version 1.1;
                proxy_buffering off;
                proxy_set_header Upgrade $http_upgrade;
                proxy_set_header Connection $connection_upgrade;
         }
}
#http ws的配置
server {
        listen 80;
        server_name s.wzero.net;

        location / {
            proxy_pass http://apibackend;
        }

        location /socket.io {
            proxy_pass http://wsbackend;
            proxy_http_version 1.1;
            proxy_buffering off;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection $connection_upgrade;
        }
 }

Spring cloud Alibaba Nacos Config 不会自动刷新问题

前提:

1、Spring Cloud 2020.1.x

2、Spring Cloud Alibaba 2021.0.x

问题:

1、Nacos 发布配置,应用没有做出反应

2、应用日志也没有提示收到配置更新的日志

细节:

1、spring.config.cloud.nacos.config.shared-dataids 配置项已过时

2、spring.config.cloud.nacos.config.shared-configs 这是新的代替配置项

3、而后config每项不是单纯的字符串表达式,而是一个对象,里面有三个属性

1)spring.cloud.nacos.config.shared-configs[x].dataid 对应nacos里的 dataid

2) spring.cloud.nacos.config.shared-configs[x].group 对应 dataid的group

3) spring.cloud.nacos.config.shared-configs[x].refresh 是否开启刷新

尝试/解决:

1、spring.config.cloud.nacos.refresh-enabled = true ,但是这个默认值是 true的,感觉也没啥鸟用

2、看到官方文档配置项目:

3、而后就有了

4、而后神奇的只要修改了配置,应用日志就提示收到配置了,嗯…

分析:

1、不做统一配置的目的可能就是因为整体刷新带来的问题

2、因此自然而然默认就应该是不自动刷新的

3、把控制权交给编程人员,某些角度上说

因为网站备案问题关闭了一年的站,今天用Oracle Cloud,站在羊毛上从新站起来了

之前因为备案过期,懒得再备案。开了进10年的(虽然没几篇文)个人站关了一年。服务器还是在,阿里云的,但是备案太麻烦了!!!

(后来发现个问题,Oracle Cloud 的所有IP 都被封!!!,用Cloudflare 代理,总算可以访问。总的来说还是很有价值的羊毛)

前天看到很多youtuber 羊毛党 用 Oracle Cloud 单间 梯子。而且比google cloud的爽,因为没有一年期限。

有始终免费的都是可以用的,当然要始终免费,那么肯定是标记了“符合始终免费 ” 的资源,否则过了30天试用期就被收回了。

主要是用的是 VM 实例,始终免费的肯定是配置最低的,1 CPU 1G 内存。但是可以建2台。

原来我也是打算搭梯子,可是…可是… 我估计晚了一步。反正搭建服务是能搭建成功。成功后,我用客户端一连接,立马整个VM 就断开了,怎么都连接不上,SSH都连接不上,只能销毁(终止)。尝试了各种版本。最后还是放弃了。

重点来了。做不了梯子!也不能浪费啊,两台 1CPU 1G内存 的虚拟机。搭个我个人博客都可以吧。因此网站备案也省略了。

我觉得大家也可以用起来的。加入羊毛党!!!

后期可以用其他的一些内容,比如有对象存储,提供了20G 呢。目前也是我需要的,但是没有国内的腾讯云和阿里云 的方便,国内的都提供各种语言的SDK。oracle 好像只提供OCI的一个程序,需要自己通过这个程序实现操作,不太方便。

还有负载均衡,提供了两台主机,其实可以做成负载均衡的。负载均衡也有始终免费的份额!

情商——当有人骂你煞笔的时候

什么是情商呢?情商的心理学术语是情绪智力。而我们大多数人理解的情商和媒体肆意宣扬的情商都是片面的。现在很多的网络课程都教你怎么样提高情商,实际上课程内容和情商并无关系。所谓情商高不是会说话,讨好别人。也不是别人说了你不爱听的话,你怎么去回怼别人。那都不是高情商的表现。情商不能和聪明、反应快、办事圆滑、见机行事划等号。这是我们大家认知上的常见的一个误区。


情绪智力是指监控自己和他人的情感及情绪,并识别、利用这些信息指导自己的行为的能力。‍‍这些能力包括为五个方面:识别自己的情绪、掌控自己的情绪、自我激励、识别他人的情绪和处理好人际关系的能力。我们要抓住这两个字“情绪”。当别人嘲讽你的时候,你可以感受到自己的情绪是愤怒的,这个时候你要知道控制自己的情绪,因为情绪失控的时候是很容易做出冲动的事情,或者说出让自己后悔的话。我们经常看到的社会新闻就是两个人因为小事争吵,情绪失控,动起手来,一人失手将另外一个人杀死。最终因刑事犯罪进入监狱的大门,去采访的时候都说自己真的很后悔,当时只是一时冲动,就落下不可挽回的后果。这样的新闻比比皆是。

所以,当别人嘲讽你的时候,不要去和他对骂,以暴制暴,这样只会让你们双方的情绪都更加不好,就算你吵赢了他又怎么样,你还是很愤怒。你的目的是让自己开心和快乐,过好自己的生活。所以不要去做让你恼火的事情。表面上不要去计较,撕破脸总是不好的。但是自己心里要清楚谁是朋友,谁是敌人。微笑面对敌人才是高手,培养敌人的缺点,总有一天他自己的火会烧到自己。

控制好自己的情绪才是情商高的真正表现。