在nginx下配置Websocket的proxy_pass还是很方便的。几乎和默认的proxy_pass一致,只要加两行代码:
XML/HTML代码
    - proxy_set_header Upgrade $http_upgrade;  
 
    - proxy_set_header Connection $connection_upgrade;  
 
 
如果对http_upgrade和$connection_upgrade的变量有自定义,可以这样写:
XML/HTML代码
    - map $http_upgrade $connection_upgrade {  
 
    -     default upgrade;  
 
    -     '' close;  
 
    - }  
 
 
如果不熟悉map的用法,这里有一篇中文的说明:https://blog.51cto.com/tchuairen/2175525,
至此,一个websocket 就配置好了,但偶尔你可能还是会发现ws会断开,所以最好设置一下超时时间。比如5分钟?
XML/HTML代码
    - proxy_read_timeout 300s;  
 
    - proxy_send_timeout 300s;  
 
 
毕竟网络不好的时候。。30s或者60s是真有可能会数据发出去收不到的。干脆延长一点吧。
参考:
1、https://www.xncoding.com/2018/03/12/fullstack/nginx-websocket.html
2、https://blog.51cto.com/tchuairen/2175525
 
 
 
 
前几天发的:用pm2管理frpc ,里面直接讲的是用pm2 start  -x 来启动的。如果用yaml来启动的话,会有部分不同
原来我的配置文件是这样的:
XML/HTML代码
    - apps:  
 
    -   - name: frp #配置  
 
    -     cwd: /Users/gouki/frp  
 
    -     script: ./frpc  
 
    -     exec_mode: fork  
 
    -     # interpreter: php  
 
    -     instances: 1  
 
    -     args:  
 
    -       - -c /Users/gouki/frp/frpc.ini  
 
 
 
看起来好象一点问题没有。毕竟 frpc的启动本来也就是frpc -c xxxx.ini,但如果真是这样,你会发现一直报错:
XML/HTML代码
    - 3|frp   | open  /Users/gouki/frp/frpc.ini: no such file or directory  
 
 
 
嗯,这种中间有空格的参数在这里好象是不能用的。改成 -c=/Users/gouki/frp/frpc.ini ,一切恢复
OK,于是最终的代码是这样的:
XML/HTML代码
    - apps:  
 
    -   - name: frp #配置  
 
    -     cwd: /Users/gouki/frp  
 
    -     script: ./frpc  
 
    -     exec_mode: fork  
 
    -     # interpreter: php  
 
    -     instances: 1  
 
    -     args:  
 
    -       - -c=/Users/gouki/frp/frpc.ini  
 
 
 
就是这样简单。但真的浪费了我不少时间。
 
jq是linux命令行下读取和解析JSON的好工具。只是好象不能jq xxx.json这样的用法,但没事,可以通过管道符,cat xxx.json|jq 就OK了
在这里:https://www.tuicool.com/articles/vieMN3Q有详细的教程,写的非常完整,但如果简单的使用,并不需要完整的看完,只要记得几个用法就行
来个简单的数据:{"code":1,"msg":"ok","data":{"fields":["a","b","c"],"items":[{1,2,3},{11,22,33}],"other":[{"x":1,"y":1},{"x":2,"y":2}]}}
1、获取items节点: cat xxx.json|jq ".data.items"
2、获取items下第二条数据的第二个,即22.   cat xxx.json|jq ".data.items[1][1]"
3、获取other下的所有x节点: cat xxx.json|jq ".data.other[].x"
是不是很方便?如果要自定义格式输出,还可以这样
1、将所有x节点用{"items":[]}格式输出: cat xxx.json| jq "{items: [ .data.other[].x ]}" ,
如果要看更多的用法,还是上面的网址里更详细一点。我这只是简单的用一下。。或者说是临时在服务器上测试数据,让自己看起来会比较方便一点。还有一个原因是我在服务器上用这个的最大理由。有时候JSON拿到的时候中文都是转义过的。用jq,可以直接看中文。这点比较爽
 
 如题。如果文件是"-test.log",是的你没看错。文件名前面有一个减号。如果你直接使用:rm -test.log,会报如下错误:
XML/HTML代码
    - rm: invalid option -- 't'  
 
    - Try 'rm ./-test.log' to remove the file ‘-test.log’.  
 
    - Try 'rm --help' for more information.  
 
 
毕竟。- 是有特殊意义的。那怎么删除呢?也简单:
XML/HTML代码
    - rm -- -test.log  
 
 
文件就这样被删除了。事实上,象这种"-"(减号、负号)开头的文件。因为它自带的特殊意义(linux下命令行的参数前缀),所以你用touch\vim等命令,其实都无法创建这样的文件。不信你试试"touch -test.log"。当然,你也是可以用touch -- -test.log来创建(其他类似)
 
 
 
 比较简单的设置,就是利用 sshconfig 。
    - 3、如果服务器需要通过跳板机登录(跳板机需要走本地网络代理)  
 
    -   
 
    - 首先配置跳板机ssh  
 
    -   
 
    - Host jumper  
 
    -   HostName yyy.yyy.yyy.yyy # 跳板机IP,跳板机~/.ssh/authorized_keys需要配置ssh公钥  
 
    -   User root  
 
    -   ForwardAgent yes  
 
    -   IdentityFile /Users/aslinwang/.ssh/id_ecdsa  
 
    -   ProxyCommand corkscrew 127.0.0.1 12679 %h %p  
 
    - 然后通过跳板机访问服务器  
 
    -   
 
    - Host aslin  
 
    -   HostName xxx.xxx.xxx.xxx # 远程服务器IP,~/.ssh/authorized_keys需要配置ssh公钥  
 
    -   User root  
 
    -   ForwardAgent yes  
 
    -   IdentityFile /Users/aslinwang/.ssh/id_ecdsa  
 
    -   ProxyCommand ssh jumper -W %h:%p 2> /dev/null  
 
 
如果你不用 公钥,那可以尝试用sshpass (即,输密码式的登录):
XML/HTML代码
    - Host aslin  
 
    -   HostName xxx.xxx.xxx.xxx # 远程服务器IP,~/.ssh/authorized_keys需要配置ssh公钥  
 
    -   User root  
 
    -   ForwardAgent yes  
 
    -   IdentityFile /Users/aslinwang/.ssh/id_ecdsa  
 
    -   ProxyCommand sshpass -p [跳板机密码] ssh -p [跳板机端口] root@[跳板机IP] -W %h:%p 2> /dev/null  
 
 
 
 ------EOF----
文中的aslinwang是上述网址文章中的用户,如果是你自己的,就是/Users/用户名/,相信能找到这里的人应该都明白