qshell是利用七牛文档上公开的API实现的一个方便开发者测试和使用七牛API服务的命令行工具。该工具设计和开发的主要目的就是帮助开发者快速解决问题。目前该工具融合了七牛存储,CDN,以及其他的一些七牛服务中经常使用到的方法对应的便捷命令,比如b64decode,就是用来解码七牛的URL安全的Base64编码用的,所以这是一个面向开发者的工具,任何新的被认为适合加到该工具中的命令需求,都可以在ISSUE列表里面提出来,我们会尽快评估实现,以帮助大家更好地使用七牛服务。
该工具使用Go语言编写而成,当然为了方便不熟悉Go或者急于使用工具来解决问题的开发者,我们提供了预先编译好的各主流操作系统平台的二进制文件供大家下载使用,由于平台的多样性,我们把这些二进制打包放到一个文件里面,请大家根据下面的说明各自选择合适的版本来使用。在文档中的例子里面,为了方便,我们统一使用qshell
这个命令来做介绍。
更新日志 查看
版本 | 支持平台 | 链接 |
---|---|---|
qshell v2.1.8 | Mac OSX, Linux, Windows | 下载 |
该工具由于是命令行工具,所以只需要从上面的下载之后即可使用。其中文件名和对应系统关系如下:
文件名 | 描述 |
---|---|
qshell-linux-x86 | Linux 32位系统 |
qshell-linux-x64 | Linux 64位系统 |
qshell-linux-arm | Linux ARM CPU |
qshell-windows-x86.exe | Windows 32位系统 |
qshell-windows-x64.exe | Windows 64位系统 |
qshell-darwin-x64 | Mac 64位系统,主流的系统 |
Linux和Mac平台
(1)权限
如果在Linux或者Mac系统上遇到Permission Denied
的错误,请使用命令chmod +x qshell
来为文件添加可执行权限。这里的qshell
是上面文件重命名之后的简写。
(2)任何位置运行
对于Linux或者Mac,如果希望能够在任何位置都可以执行,那么可以把qshell
所在的目录加入到环境变量$PATH
中去。假设qshell
命令被解压到路径/home/jemy/tools
目录下面,那么我们可以把如下的命令写入到你所使用的bash所对应的配置文件中,如果是/bin/bash
,那么就是~/.bashrc
文件,如果是/bin/zsh
,那么就是~/.zshrc
文件中。写入的内容为:
export PATH=$PATH:/home/jemy/tools
保存完毕之后,可以通过两种方式立即生效,其一为输入source ~/.zshrc
或者source ~/.bashrc
来使配置立即生效,或者完全关闭命令行,然后重新打开一个即可,接下来就可以在任何位置使用qshell
命令了。
Windows平台
(1)闪退问题 本工具是一个命令行工具,在Windows下面请先打开命令行终端,然后输入工具名称执行,不要双击打开,否则会出现闪退现象。
(2)任何位置运行
如果你希望可以在任意目录下使用qshell
,请将qshell
工具可执行文件所在目录添加到系统的环境变量中。由于Windows系统是图形界面,所以方便一点。假设qshell.exe
命令被解压到路径E:\jemy\tools
目录下面,那么我们把这个目录放到系统的环境变量PATH
里面。
该工具有两类命令,一类需要鉴权,另一类不需要。
需要鉴权的命令都需要依赖七牛账号下的 AccessKey
和 SecretKey
。所以这类命令运行之前,需要使用 account
命令来设置下 AccessKey
,SecretKey
。
单用户模式:
$ qshell account ak sk
多用户模式:
$ qshell -m account ak sk
和其他的工具一样,本工具也会在使用的过程中,向本地磁盘写入一些文件,比如上面的account
设置的 AccessKey
和 SecretKey
都是加密后保存在本地磁盘上的。另外还有qupload
和qdownload
功能也会向本地磁盘写入一些文件。
默认情况下,工具的使用模式是单用户模式,用户的所有信息写入到磁盘$HOME_DIR/.qshell
下面。即如果你用account
设置了新的密钥,那么这个新的密钥将覆盖旧的密钥。这个$HOME_DIR
在Linux或者Mac下就是~
所表示的目录。如果是Windows下则是C:\Users\jemy
这样的路径。
但是有些情况下,我们可能拥有多个账号,比如同时拥有测试环境的账号和线上环境的账号,这种情况下,怎么让qshell
同时支持多组AccessKey
和SecretKey
的设置呢?
为了解决这个问题,我们引入了选项-m
。当在使用qshell
的时候,指定该选项的话,就会切换到多用户模式下,在这种模式下,工具会把所有的临时文件都写到工具执行的目录。
基于上面的功能,我们可以创建一些专用的目录,用来切换到qshell
的多用户模式运行。假设本地有如目录/Users/jemy/Temp/qshell/workdir
,这个目录下分别有env_dev
和env_prod
两种环境的账号。
我们分别在目录env_dev
和env_prod
目录下,运行qshell -m account ak sk
来设置不同账号的密钥对,结果如下:
$ tree -a
├── env_dev
│ └── .qshell
│ └── account.json
└── env_prod
└── .qshell
└── account.json
这样其他的依赖AccessKey
和SecretKey
的命令都可以使用-m
选项在这个目录下执行命令,例如stat
获取文件信息:
$ cd /Users/jemy/Temp/qshell/workdir/env_dev
$ qshell -m stat bucket key
该工具还有一些有用的选项参数如下:
参数 | 描述 |
---|---|
-d | 设置是否输出DEBUG日志,如果指定这个选项,则输出DEBUG级别的日志 |
-m | 切换到多用户模式,这样所有的临时文件写入都在命令运行的目录下 |
-h | 打印命令列表帮助信息,遇到参数忘记的情况下,可以使用该命令 |
-v | 打印工具版本,反馈问题的时候,请提前告知工具对应版本号 |
命令 | 类别 | 描述 | 详细 |
---|---|---|---|
account | 账号 | 设置或显示当前用户的AccessKey 和SecretKey |
文档 |
dircache | 存储 | 输出本地指定路径下所有的文件列表 | 文档 |
listbucket | 存储 | 列举七牛空间里面的所有文件 | 文档 |
prefop | 存储 | 查询七牛数据处理的结果 | 文档 |
fput | 存储 | 以文件表单的方式上传一个文件 | 文档 |
rput | 存储 | 以分片上传的方式上传一个文件 | 文档 |
qupload | 存储 | 同步数据到七牛空间, 带同步进度信息,和数据上传完整性检查(配置式) | 文档 |
qupload2 | 存储 | 同步数据到七牛空间, 带同步进度信息,和数据上传完整性检查(命令式) | 文档 |
qdownload | 存储 | 从七牛空间同步数据到本地,支持只同步某些前缀的文件,支持增量同步 | 文档 |
stat | 存储 | 查询七牛空间中一个文件的基本信息 | 文档 |
delete | 存储 | 删除七牛空间中的一个文件 | 文档 |
move | 存储 | 移动或重命名七牛空间中的一个文件 | 文档 |
copy | 存储 | 复制七牛空间中的一个文件 | 文档 |
chgm | 存储 | 修改七牛空间中的一个文件的MimeType | 文档 |
chtype | 存储 | 修改七牛空间中的一个文件的存储类型,支持普通存储(0)和低频存储(1) | 文档 |
expire | 存储 | 修改七牛空间中的一个文件的生存时间 | 文档 |
fetch | 存储 | 从Internet上抓取一个资源并存储到七牛空间中 | 文档 |
sync | 存储 | 从Internet上抓取一个资源并存储到七牛空间中,适合大文件的场合 | 文档 |
prefetch | 存储 | 更新七牛空间中从源站镜像过来的文件 | 文档 |
batchdelete | 存储 | 批量删除七牛空间中的文件,可以直接根据listbucket 的结果来删除 |
文档 |
batchchgm | 存储 | 批量修改七牛空间中文件的MimeType | 文档 |
batchchtype | 存储 | 批量修改七牛空间中的文件的存储类型,支持普通存储(0)和低频存储(1) | 文档 |
batchexpire | 存储 | 批量修改七牛空间中的文件的生存时间 | 文档 |
batchcopy | 存储 | 批量复制七牛空间中的文件到另一个空间 | 文档 |
batchmove | 存储 | 批量移动七牛空间中的文件到另一个空间 | 文档 |
batchrename | 存储 | 批量重命名七牛空间中的文件 | 文档 |
batchsign | 存储 | 批量根据资源的公开外链生成资源的私有外链 | 文档 |
batchstat | 存储 | 批量查询七牛空间中文件的基本信息 | 文档 |
privateurl | 存储 | 生成私有空间资源的访问外链 | 文档 |
saveas | 存储 | 实时处理的saveas链接快捷生成工具 | 文档 |
reqid | 存储 | 七牛自定义头部X-Reqid解码工具 | 文档 |
buckets | 存储 | 获取当前账号下所有的空间名称 | 文档 |
domains | 存储 | 获取指定空间的所有关联域名 | 文档 |
qetag | 存储 | 根据七牛的qetag算法来计算文件的hash | 文档 |
m3u8delete | 存储 | 根据流媒体播放列表文件删除七牛空间中的流媒体切片 | 文档 |
m3u8replace | 存储 | 修改流媒体播放列表文件中的切片引用域名 | 文档 |
cdnrefresh | CDN | 批量刷新cdn的访问外链或目录 | 文档 |
cdnprefetch | CDN | 批量预取cdn的访问外链 | 文档 |
b64encode | 工具 | base64编码工具,可选是否使用UrlSafe方式,默认UrlSafe | 文档 |
b64decode | 工具 | base64解码工具,可选是否使用UrlSafe方式,默认UrlSafe | 文档 |
urlencode | 工具 | url编码工具 | 文档 |
urldecode | 工具 | url解码工具 | 文档 |
ts2d | 工具 | 将timestamp(单位秒)转为UTC+8:00中国日期,主要用来检查上传策略的deadline参数 | 文档 |
tms2d | 工具 | 将timestamp(单位毫秒)转为UTC+8:00中国日期 | 文档 |
tns2d | 工具 | 将timestamp(单位100纳秒)转为UTC+8:00中国日期 | 文档 |
d2ts | 工具 | 将日期转为timestamp(单位秒) | 文档 |
ip | 工具 | 根据淘宝的公开API查询ip地址的地理位置 | 文档 |
unzip | 工具 | 解压zip文件,支持UTF-8编码和GBK编码 | 文档 |
alilistbucket | 第三方 | 列举阿里OSS空间里面的所有文件 | 文档 |
如果对项目编译感兴趣,请按照如下方式进行:
$ go get github.com/astaxie/beego/logs
$ go get github.com/fsnotify/fsnotify
$ go get github.com/syndtr/goleveldb/leveldb
$ go get github.com/yanunon/oss-go-api/oss
$ go get golang.org/x/text/encoding/simplifiedchinese
$ go get golang.org/x/sys/unix
$ ./build.sh
如果上面的 golang.org/x
下面的包因为被墙而无法下载,那么可以使用 git clone
分别将依赖的库下载到本地的GOPATH
中:
git clone https://github.com/golang/sys.git $GOPATH/src/golang.org/x/sys
git clone https://github.com/golang/text.git $GOPATH/src/golang.org/x/text
对于跨平台的编译脚本 cross-build-main.sh
编译出来的二进制文件存在的已知问题如下:
如果您有任何问题,请写在ISSUE列表里面,我们会尽快回复您。
如果您希望和在工作中使用qshell
的其他人进行交流,可以加入QQ群:343822521 。