http1.0
一次请求一个 tcp 连接。
支持持久化连接,但是需要显示启用。
http1.1
默认使用持久化连接。
建立一个 tcp 连接后可以发送多个请求。但是有如下限制,客户端可以不必等待响应连续发送请求,但是服务端必须按客户端发送请求的顺序依次返回对应响应,这样客户端才能对应请求与响应。所以这样还是会出现队头阻塞(Head of line blocking)。
一次请求一个 tcp 连接。
支持持久化连接,但是需要显示启用。
默认使用持久化连接。
建立一个 tcp 连接后可以发送多个请求。但是有如下限制,客户端可以不必等待响应连续发送请求,但是服务端必须按客户端发送请求的顺序依次返回对应响应,这样客户端才能对应请求与响应。所以这样还是会出现队头阻塞(Head of line blocking)。
go 语言通过 goroutine 提供了并发编程支持,goroutine 是 go 运行库的功能,而不是操作系统线程实现的,goroutine 可以被理解成一个用户态的线程。
动词 | 示例 | 含义 |
---|---|---|
%v | 默认格式输出,当输出结构体时,扩展标志(%+v)会添加字段名 | |
%#v | 值的 Go 语法表示 | |
%T | 值的类型的Go语法表示 | |
%% | 百分号 |
动词 | 示例 | 含义 |
---|---|---|
%t | true | 单词 true 或 false |
动词 | 示例 | 含义 |
---|---|---|
%b | 表示二进制 | |
%c | 该值对应的unicode码值 | |
%d | 表示为十进制 | |
%o | 表示为八进制 | |
%q | 该值对应的单引号括起来的go语法字符字面值,必要时会采用安全的转义表示 | |
%x | 表示为十六进制,使用a-f | |
%X | 表示为十六进制,使用A-F | |
%U | 表示为Unicode格式:U+1234,等价于"U+%04X" |
动词 | 示例 | 含义 |
---|---|---|
%b | 无小数部分、二进制指数的科学计数法,如-123456p-78 | |
%e | 科学计数法,如-1234.456e+78 | |
%E | 科学计数法,如-1234.456E+78 | |
%f | 有小数部分但无指数部分,如123.456 | |
%F | 等价于%f | |
%g | 根据实际情况采用%e或%f格式(以获得更简洁、准确的输出) | |
%G | 根据实际情况采用%E或%F格式(以获得更简洁、准确的输出) |
对于浮点数,宽度设置输出总长度;精度设置小数部分长度(如果有的话),除了%g/%G,此时精度设置总的数字个数。例如,对数字123.45,格式%6.2f 输出123.45;格式%.4g输出123.5。
Delve 是一个 Golang 的调试工具,比 GDB 要好用很多,能支持协程的调试。使用的时候可以直接运行程序调试,也可以 attach 到一个正在运行中的程序。
Delve 的安装很简单,它本身也是 go 写的。
Go 语言推荐测试文件和源代码文件放在一起。测试文件以 “_test.go” 结尾(这样在 go build 的时候才不会被包含)。
example/
|-- biz.go
|-- biz_test.go
普通测试用例的方法以 Test 开头,参数为 t *testing.T
Command Line Tools 是苹果的一个小型独立包,适用于 macOS,为终端扩展了额外的功能。包括但不限于:svn、git、make、GCC、clang、perl、size、strip、strings、libtool、cpp、what、codesign以及其他很多能够在Linux中找到的命令。
(以前截的图,找不到来源了)
mongodb://username:password@db_host/db_name
use db_name
没有就会创建,有就会切换到该数据库
show dbs
db.dropDatabase()
删除当前所在数据库
首先需要检查系统版本是否支持 Docker,现在新版本大部分已经支持了 Docker。
yum install docker -y
systemctl start docker
# 官方安装命令
curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun
docker search centos
默认从国外拉取,速度比较慢,可以使用大陆的镜像加速,参考 https://docker-cn.com/registry-mirror(现在很多镜像已经不可用了)。
这里使用 acme.sh 来配置证书
curl https://get.acme.sh | sh
# 中国 https://github.com/acmesh-official/acme.sh/wiki/Install-in-China
安装在 ~/.acme.sh/
目录下
acme.sh --set-default-ca --server letsencrypt
生成证书需要验证域名的所有权,一般有 http 和 dns 两种验证方式,http 验证就是在网站根目录下放置文件,dns 则是添加 dns 记录来验证。
目前泛域名证书仅支持 dns 方式验证。
比如我使用的是 dnspod 来解析域名的,则去 dndpod 申请一套 api token,其他解析运营商也都类似。这样会得到一个 id 和 key。
然后设置为系统环境变量
sudo mkdir -p /etc/systemd/system/docker.service.d
# 写入 /etc/systemd/system/docker.service.d/proxy.conf
[Service]
Environment="HTTP_PROXY=http://bb.bb.com"
Environment="HTTPS_PROXY=http://bb.bb.com"
Environment="NO_PROXY=aa.bb.com"
然后
sudo systemctl daemon-reload
sudo systemctl restart docker
更新:大部分已经不可用
对于使用 systemd 的系统,请在 /etc/docker/daemon.json 中写入如下内容(如果文件不存在请新建该文件)