Site updated: 2022-11-02 08:02:13

This commit is contained in:
qinglong
2022-11-02 08:02:14 +08:00
parent baa42440cc
commit f23c58c78e
103 changed files with 288 additions and 158 deletions

View File

@@ -1,11 +1,24 @@
{
"version": "https://jsonfeed.org/version/1",
"title": "Hito的公告栏",
"title": "涛声依旧",
"subtitle": "天下事有难易乎?为之,则难者亦易矣",
"icon": "https://blog.jingxiyuan.cn/images/favicon.ico",
"description": "hito的博客",
"home_page_url": "https://blog.jingxiyuan.cn",
"items": [
{
"id": "https://blog.jingxiyuan.cn/2022/11/02/2-dev-null%E5%92%8C-dev-null-2-1%E5%92%8C2-1-dev-null%E7%9A%84%E5%8C%BA%E5%88%AB/",
"url": "https://blog.jingxiyuan.cn/2022/11/02/2-dev-null%E5%92%8C-dev-null-2-1%E5%92%8C2-1-dev-null%E7%9A%84%E5%8C%BA%E5%88%AB/",
"title": "2>/dev/null和>/dev/null 2>&1和2>&1>/dev/null的区别",
"date_published": "2022-11-02T08:29:00.000Z",
"content_html": "<h4 id=\"区别\"><a class=\"anchor\" href=\"#区别\">#</a> 区别:</h4>\n<pre><code class=\"language-bash\">2&gt;/dev/null\n</code></pre>\n<p>意思就是把错误输出到 “黑洞”</p>\n<pre><code class=\"language-bash\">&gt;/dev/null 2&gt;&amp;1\n</code></pre>\n<p>默认情况是 1也就是等同于 1&gt;/dev/null 2&gt;&amp;1。意思就是把标准输出重定向到 “黑洞”,还把错误输出 2 重定向到标准输出 1也就是标准输出和错误输出都进了 “黑洞”</p>\n<pre><code class=\"language-bash\">2&gt;&amp;1 &gt;/dev/null\n</code></pre>\n<p>意思就是把错误输出 2 重定向到标准出书 1也就是屏幕标准输出进了 “黑洞”,也就是标准输出进了黑洞,错误输出打印到屏幕</p>\n<h4 id=\"解释\"><a class=\"anchor\" href=\"#解释\">#</a> 解释:</h4>\n<ol>\n<li>\n<p>文件描述符<br />\n Linux 系统预留三个文件描述符0、1 和 2他们的意义如下所示<br />\n0—— 标准输入stdin<br />\n略...<br />\n1—— 标准输出stdout<br />\n在当前目录下有且只有一个文件名称为 a.txt 的文件这时我们运行这个命令【ls a.txt】, 就会获得一个标准输出 stdout 的输出结果a.txt<br />\n<img data-src=\"https://file.jingxiyuan.cn/images/2022/11/01/newscreen629761046.jpg\" alt=\"\" /><br />\n2—— 标准错误stderr<br />\n在当前目录下有且只有一个文件名称为 a.txt 的文件我们运行命令【ls b.txt】我们就会获得一个标准错误 stderr 的输出结果 “ls无法访问 b.txt没有这样的文件或目录”。<br />\n<img data-src=\"https://file.jingxiyuan.cn/images/2022/11/01/newscreen629793578.jpg\" alt=\"\" /></p>\n</li>\n<li>\n<p>重定向<br />\n重定向的符号有两个&gt; 或 &gt;&gt;,两者的区别是:前者会先清空文件,然后再写入内容,后者会将重定向的内容追加到现有文件的尾部。举例如下:</p>\n</li>\n</ol>\n<ul>\n<li>\n<p>重定向标准输出 stdout<br />\n<img data-src=\"https://file.jingxiyuan.cn/images/2022/11/01/newscreen630033531.jpg\" alt=\"\" /><br />\n 如上图所示,对比没有添加重定向的操作,这条命令在使用之后并没有将 a.txt 打印到屏幕。在紧接的 cat 操作后,可以发现本来应该被输出的内容被记录到 stdout.txt 中。</p>\n</li>\n<li>\n<p>重定向标准错误 stderr<br />\n<img data-src=\"https://file.jingxiyuan.cn/images/2022/11/01/newscreen630256640.jpg\" alt=\"\" /><br />\n 如上图所示,文件描述符 2标准错误的重定向也是同样的原理被记录在了文件 stderr.txt 这个文件里面了。</p>\n</li>\n<li>\n<p>可以将 stderr 单独定向到一个文件stdout 重定向到另一个文件</p>\n</li>\n</ul>\n<pre><code class=\"language-bash\">ls b.txt 2&gt; stderr.txt 1&gt;stdout.txt\n</code></pre>\n<ul>\n<li>也可以将 stderr 和 stdout 重定向到同一个文件</li>\n</ul>\n<pre><code class=\"language-bash\">ls b.txt &gt; output.txt 2&gt;&amp;1\n</code></pre>\n<ul>\n<li>或采用下面的方法,可以少写几个字,能达到同样的效果</li>\n</ul>\n<pre><code class=\"language-bash\">ls b.txt &amp;&gt; output.txt\nls b.txt &gt;&amp; output.txt #两个表达式效果一样的\n</code></pre>\n<ol start=\"3\">\n<li>Linux 特殊文件<br />\n /dev/null 是一个特殊的设备文件这个文件接收到任何数据都会被丢弃。因此null 这个设备通常也被称为位桶bit bucket或黑洞。<br />\n所以2&gt;/dev/null 的意思就是将标准错误 stderr 删掉。</li>\n</ol>\n",
"tags": [
"Linux",
"Shell",
"Shell",
"2>&1"
]
},
{
"id": "https://blog.jingxiyuan.cn/2022/11/01/360%E7%8B%AC%E7%AB%8B%E7%89%88%E5%B0%8F%E5%B7%A5%E5%85%B7/",
"url": "https://blog.jingxiyuan.cn/2022/11/01/360%E7%8B%AC%E7%AB%8B%E7%89%88%E5%B0%8F%E5%B7%A5%E5%85%B7/",
@@ -274,20 +287,6 @@
"protobuf",
"js"
]
},
{
"id": "https://blog.jingxiyuan.cn/2022/09/21/%E8%AE%B0%E4%B8%80%E6%AC%A1netty-socket-io%E6%9C%8D%E5%8A%A1%E7%AB%AF%E8%BF%9E%E6%8E%A5%E4%B8%8D%E4%B8%8A%E7%9A%84%E9%97%AE%E9%A2%98/",
"url": "https://blog.jingxiyuan.cn/2022/09/21/%E8%AE%B0%E4%B8%80%E6%AC%A1netty-socket-io%E6%9C%8D%E5%8A%A1%E7%AB%AF%E8%BF%9E%E6%8E%A5%E4%B8%8D%E4%B8%8A%E7%9A%84%E9%97%AE%E9%A2%98/",
"title": "记一次netty-socketio服务端连接不上的问题",
"date_published": "2022-09-21T01:46:00.000Z",
"content_html": "<p><em>今天前端开发跟我反馈用 vue 的 socketio 连接不上后台服务,连接无反应无任何报错。所以不清楚是前端代码问题还是后台服务的问题。由于框架为另一同事搭建,我只负责处理后端业务逻辑部分,所以第一时间我也不清楚具体的原因。于是我找了个第三方的 socket 工具尝试连接,果然有问题。但是只是提示连接不上,无明显错误原因。到后台查看发现有提示 Unknown transport for request 错误,最后通过调试发现 netty-socketio 的库中 AuthorizeHandler 类有段处理 transport 的代码只能接受大写的 WEBSOCKET 或者 POLLING于是我在工具中按要求填上结果还是不行。然后我在网上搜索也未发现有相关问题只发现有网友提示需要用 socketio 的库,不要自己写 socket 连接。于是我找了 socket.io.js 来连接,结果还是一样。经过大量调试改代码,最后突发奇想,有没有可能跟 netty-socketio 的版本有关系,于是我把版本从 1.7.20 升级到 1.7.21,结果就奇迹般的好了。</em></p>\n<h6 id=\"总结就好像大力出奇迹实在找不到原因的时候不妨升级一下版本说不定问题就解决了呢o_o\"><a class=\"anchor\" href=\"#总结就好像大力出奇迹实在找不到原因的时候不妨升级一下版本说不定问题就解决了呢o_o\">#</a> 总结就好像大力出奇迹实在找不到原因的时候不妨升级一下版本说不定问题就解决了呢O (∩_∩) O</h6>\n",
"tags": [
"生活",
"心得体会",
"踩坑",
"netty",
"socketIO"
]
}
]
}