Nginx支持websocket配置

前言

wss协议实际就是websocket+ssl,就是在websocket协议上加入ssl层,类似https(http+ssl)。

Nginx websocket代理主要配置:

proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";

ws配置示例

server {
    listen 80;
    server_name yourdomain.com;

    location /websocket {
        proxy_pass http://localhost:8000;

        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
    }
}

sqlserver大表数据导入导出【bcp命令】

前言

一般情况下,我们在迁移表结构和数据时,是使用数据库工具提供的结构同步或数据同步功能,来迁移数据库或保证不同服务器数据库结构和数据的一致。但特殊情况下,比如网络不通的情况下,我们要迁移大表的数据,则只能先把大表数据导出成脚本或文件,然后再在目标服务器执行导入。本文我们主要使用bcp命令(Bulk Copy Program)来说明,如何通过bcp命令来完成大表数据的导入和导出操作。

bcp命令说明

bcp导出命令

bcp "SELECT * FROM YourTable" queryout C:\YourFile.dat -c -T -S YourServerName -d databaseName

将YourTable表中选取所有列,并将结果保存到YourFile.dat文件中。
-c参数指定输出格式为字符型;
-T参数指示使用Windows身份验证登录服务器;
-S参数后面应该提供服务器名称或IP地址;
-d参数指定数据库名称;

bcp导入命令

bcp YourTable IN C:\YourFile.dat -c -T -S YourServerName -d databaseName

将YourFile.dat文件中的内容导入到名为YourTable的表中。

以太坊简介

简介

以太坊(英文Ethereum)是一个开源的有智能合约功能的公共区块链平台,通过其专用加密货币以太币(Ether,简称“ETH”)提供去中心化的以太虚拟机(Ethereum Virtual Machine)来处理点对点合约。

社区地址:https://ethereum.org/zh/

什么是区块链?

对区块链最好的描述是将其描述为一个公共数据库,它由网络中的许多计算机更新和共享。

"区块"指的是数据和状态是按顺序批量或"区块"存储的。 如果你向别人发送 ETH,需要将交易数据添加到一个区块中才算成功。

"链"指的是每个区块加密引用其父块。 换句话说,区块被链接在一起。 在不改变所有后续区块的情况下,区块内数据是无法改变,但改变后续区块需要整个网络的共识。

什么是 WEB3?

Web3 简介

中心化网络已经帮助数十亿人融入了互联网,并在其上创建了稳定、可靠的基础设施。 与此同时,少数中心化巨头几乎垄断了互联网,甚至可以为所欲为。

Web3 是摆脱这一困境的方案。 不同于科技巨头垄断的传统互联网,Web3 采用去中心化,由所有用户构建、运营和拥有。 Web3 将权力赋予个人而非公司。 在我们讨论 Web3 之前,先来看看我们是如何走到这一步的。

早期的网络

大多数人认为互联网是现代生活的一个持续支柱—自发明出来后就一直存在。 然而,我们今天大多数人所熟知的互联网与最初的想象有很大不同。 为了便于理解,可以将过去短暂的互联网历史分为两个时期—Web 1.0 和 Web 2.0。

Chrome自动播放报错:play() failed because the user didn't interact with the document first解决方法

报错信息

在浏览器中实现语音播报,视频自动播放等场景下,我们可能会遇到以下报错:
Uncaught (in promise) DOMException: play() failed because the user didn't interact with the document first.

报错原因

这个错误信息表示你尝试在没有用户交互的情况下播放音频,而浏览器的自动播放策略阻止了这一行为。
从Chrome 66开始,浏览器实施了更严格的自动播放策略,要求音频或视频在播放前必须有用户的明确交互(例如点击或触摸事件)。

解决方法

在toB用户确定的场景下,我们可以设置Chrome启动参数,来指定自动播放策略:
--no-user-gesture-required 自动播放策略,不需要任何用户手势

具体步骤:
桌面Chrome快捷方式图标--右键属性--快捷方式栏--目标内容末尾添加参数:
--autoplay-policy=no-user-gesture-required

目标内容完整示例:
"C:\Program Files\Google\Chrome\Application\chrome.exe" --autoplay-policy=no-user-gesture-required

设置完后,重启Chrome浏览器,测试具体场景即可;