Nali:一个离线查询IP地理信息和CDN提供商的终端利器

系统 Linux
今天给大家介绍两款基于 GO 语言和 Nodejs 开发的,且具有更多高级功能的新一代 Nali。

 

什么是 Nali

dig、nslookup、traceroute 等都是非常实用的网络调试工具,Nali 是一个可以自动解析这些工具 stdout 中的 IP 并附上所属 ISP 和地理信息,对这些已是瑞士军刀般的工具可谓如虎添翼。

Nali 取自中文「哪里」。Nali 一开始是数年前由 surfchen 用 C 和 Perl 写成的小工具(C 用于解析纯真 IP 数据库,Perl 用于解析 stdout),如今已经失传。

今天给大家介绍两款基于 GO 语言和 Nodejs 开发的,且具有更多高级功能的新一代  Nali。

Nali CLI

Nali CLI 采用 Nodejs 开发,在安装之前,你的环境必须已经具备 Nodejs 环境。

项目地址:

  •  GitHub: https://github.com/sukkaw/nali-cli
  •  官网:https://nali.skk.moe/

安装

对于环境中有 Node.js 的,可以直接通过 NPM 和 Yarn 安装: 

  1. # NPM  
  2. $ npm i nali-cli -g  
  3. # Yarn  
  4. $ yarn global add nali-cli 

Nali CLI 也有预编译好的供 macOS x64 和 Linux x64 的二进制文件,可以在 GitHub Repo 中的 👉bin 目录中下载。

首次运行 Nali CLI 时会自动下载所需的 qqwry.dat 到 $HOME/.config/nali-cli/ 目录下。

常用命令行语法 

  1. $ nali --help  
  2. Usage: nali <command> [options]  
  3. Options:  
  4.   -v, --version  版本信息  
  5.   -h, --help     output usage information  
  6. Commands:  
  7.   parse          解析 stdin 或参数中的 IP 信息 (默认)  
  8.   update         更新 IP 库  
  9.   help [cmd]     display help for [cmd]  
  10. $ nali update --help    
  11. Usage: update [options]  
  12. 更新 IP 库 (qqwry.dat)  
  13. Options:  
  14.   -r, --remote  获取最新 IP 库版本信息  
  15.   -f, --force   强制更新 IP 库  
  16.   -y, --yes     直接更新 IP 库  
  17.   -h, --help    output usage information 

使用

Nali CLI 支持从传入的参数中解析 IP: 

  1. $ nali 11.4.5.14  
  2. 11.4.5.14 [美国 俄亥俄州哥伦布市 DoD 网络信息中心]  
  3. $ nali Cloudflare 1.0.0.1 1.1.1.1  
  4. Cloudflare 1.1.1.1 [美国 APNIC&CloudFlare 公共 DNS 服务器] 1.0.0.1 [美国 APNIC&CloudFlare 公共 DNS 服务器]  
  5. $ nali 114.514.191.9 114.5.1.4  
  6. 114.514.191.8 114.5.1.4 [印度尼西亚] 

除此以外,Nali CLI 内置了以下几个常用工具:

  •  nali-dig
  •  nali-nslookup
  •  nali-ping
  •  nali-tracepath
  •  nali-traceroute

注意,上述工具只是 Wrapper,使用时仍然需要安装原始程序。比如要使用 nali-dig 和 nali-nslookup 需要先安装 Bind (dnsutils)。 

  1. $ nali-nslookup nali.skk.moe 1.1.1.1  
  2. Server:         1.1.1.1 [美国 APNIC&CloudFlare 公共 DNS 服务器]  
  3. Address:        1.1.1.1 [美国 APNIC&CloudFlare 公共 DNS 服务器]#53  
  4. Non-authoritative answer:  
  5. Name:   nali.skk.moe  
  6. Address: 104.18.100.28 [美国 CloudFlare 公司 CDN 节点]  
  7. Name:   nali.skk.moe  
  8. Address: 104.18.101.28 [美国 CloudFlare 公司 CDN 节点]  
  9. Name:   nali.skk.moe  
  10. Address: 2606:4700::6812:641c  
  11. Name:   nali.skk.moe  
  12. Address: 2606:4700::6812:651c 

Nali CLI 还支持从外部的 stdin 中解析和查询 IP 信息,因此像 mtr 这类未被 Nali CLI 包装的工具也可以使用: 

  1. # 这里以 dig 为例  
  2. $ dig nali.skk.moe @1.1.1.1 +short | nali  
  3. 104.18.100.28 [美国 CloudFlare 公司 CDN 节点]  
  4. 104.18.101.28 [美国 CloudFlare 公司 CDN 节点] 

对于 mtr 等,还可以自行创建 nali-mtr 文件并添加到 PATH 中: 

  1. #!/bin/sh  
  2. mtr $@ 2>&1 | nali 

也可以直接在 .bashrc 或 .zshrc 中注册 nali-mtr: 

  1. nali-mtr() {  
  2.   mtr $@ 2>&1 | nali  

Nali CLI 也可以更新 qqwry.dat:

  1. $ nali upadte 

Nali (Go 版本)

Nali (Go 版本)是在 Sukka 的 Nodejs 版本上进行改良的,它在原有功能的基础上增加了对 IPv6 的支持,并且增加了 Geoip2 数据库。

项目地址:

支持的功能

  •  纯真 IPv4 离线数据库
  •  ZX IPv6 离线数据库
  •  Geoip2 城市数据库 (可选)
  •  IPIP 数据库 (可选)
  •  CDN 服务提供商查询
  •  支持管道处理
  •  支持交互式查询
  •  同时支持 IPv4 和 IPv6
  •  查询完全离线
  •  全平台支持

安装

  1.  从源码安装

Nali 需要预先安装 Go. 安装后可以从源码安装软件: 

  1. $ go get -u -v github.com/zu1k/nali 

      2.  下载预编译的可执行程序(推荐)

直接从项目的 👉Release 页面下载预编译好的可执行程序,你只需要选择适合你系统和硬件架构的版本下载,解压后直接运行即可。

常用命令语法 

  1. $ nali --help  
  2. Usage:  
  3.   nali [flags]  
  4.   nali [command]  
  5. Available Commands:  
  6.   cdn         Query cdn service provider  
  7.   help        Help about any command 
  8.   parse       Query IP information  
  9.   update      update chunzhen ip database  
  10. Flags:  
  11.   -h, --help     help for nali 
  12.   -t, --toggle   Help message for toggle  
  13. Use "nali [command] --help" for more information about a command.

使用

第一次使用时会需要点时间,因为要下载纯真和 CDN 相关数据库。 

  1. $ nali                                                      
  2. 2020/08/20 17:37:14 文件不存在,尝试从网络获取最新纯真 IP 库  
  3. 2020/08/20 17:37:32 已将最新的 纯真IP库 保存到本地: /Users/Mike/.nali/qqwry.dat  
  4. 2020/08/20 17:37:32 文件不存在,尝试从网络获取最新ZX IPv6数据库  
  5. 2020/08/20 17:37:33 已将最新的 ZX IPv6数据库 保存到本地: /Users/Mike/.nali/ipv6wry.db  
  6. 2020/08/20 17:37:33 文件不存在,尝试从网络获取最新CDN数据库  
  7. 2020/08/20 17:37:34 已将最新的 CDN数据库 保存到本地: /Users/Mike/.nali/cdn.json 
  1.  查询一个 IP 的地理信息 
  1. $ nali 1.2.3.4  
  2. 1.2.3.4 [澳大利亚 APNIC Debogon-prefix网络]  
  3. # 或者使用管道  
  4. $ echo IP 6.6.6.6 | nali  
  5. IP 6.6.6.6 [美国 亚利桑那州华楚卡堡市美国国防部网络中心] 

      2.  同时查询多个IP的地理信息 

  1. $ nali 1.2.3.4 4.3.2.1 123.23.3.0  
  2. 1.2.3.4 [澳大利亚 APNIC Debogon-prefix网络]  
  3. 4.3.2.1 [美国 新泽西州纽瓦克市Level3Communications]  
  4. 123.23.3.0 [越南 越南邮电集团公司] 

      3.  交互式查询

使用 exit 或 quit 退出查询。 

  1. $ nali  
  2. 123.23.23.23  
  3. 123.23.23.23 [越南 越南邮电集团公司]  
  4. 1.0.0.1 
  5. 1.0.0.1 [美国 APNIC&CloudFlare公共DNS服务器]  
  6. 8.8.8.8  
  7. 8.8.8.8 [美国 加利福尼亚州圣克拉拉县山景市谷歌公司DNS服务器]  
  8. quit 

      4.  与 dig 命令配合使用

需要你系统中已经安装好 dig 程序。 

  1. $ dig nali.lgf.im +short | nali  
  2. 104.28.2.115 [美国 CloudFlare公司CDN节点]  
  3. 104.28.3.115 [美国 CloudFlare公司CDN节点]  
  4. 172.67.135.48 [美国 CloudFlare节点] 

      5.  与 nslookup 命令配合使用 

  1. 需要你系统中已经安装好 nslookup 程序。  
  2. $ nslookup nali.lgf.im 8.8.8.8 | nali  
  3. Server:         8.8.8.8 [美国 加利福尼亚州圣克拉拉县山景市谷歌公司DNS服务器]  
  4. Address:        8.8.8.8 [美国 加利福尼亚州圣克拉拉县山景市谷歌公司DNS服务器]#53 
  5. Non-authoritative answer:  
  6. Name:   nali.lgf.im  
  7. Address: 104.28.3.115 [美国 CloudFlare公司CDN节点]  
  8. Name:   nali.lgf.im  
  9. Address: 104.28.2.115 [美国 CloudFlare公司CDN节点]  
  10. Name:   nali.lgf.im  
  11. Address: 172.67.135.48 [美国 CloudFlare节点] 

      6.  与任意程序配合使用

因为 nali 支持管道处理,所以可以和任意程序配合使用。 

  1. $ bash abc.sh | nali 

Nali 将在 IP 后面插入 IP 地理信息,CDN 域名后面插入 CDN 服务提供商信息。

      7.  支持 IPv6 

  1. 和 IPv4 用法完全相同。  
  2. $ nslookup google.com | nali  
  3. Server:         127.0.0.53 [局域网 IP]  
  4. Address:        127.0.0.53 [局域网 IP]#53  
  5. Non-authoritative answer:  
  6. Name:   google.com  
  7. Address: 216.58.211.110 [美国 Google全球边缘网络]  
  8. Name:   google.com  
  9. Address: 2a00:1450:400e:809::200e [荷兰Amsterdam Google Inc. 服务器网段] 

      8.  查询 CDN 服务提供商

因为 CDN 服务通常使用 CNAME 的域名解析方式,所以推荐与 nslookup 或者 dig 配合使用,在已经知道 CNAME 后可单独使用。

  •  只查询 CDN 服务提供商 
  1. $ nslookup www.gov.cn | nali cdn  
  2. Server:         127.0.0.53  
  3. Address:        127.0.0.53#53  
  4. Non-authoritative answer:  
  5. www.gov.cn      canonical name = www.gov.cn.bsgslb.cn [白山云 CDN].  
  6. www.gov.cn.bsgslb.cn [白山云 CDN]       canonical name = zgovweb.v.bsgslb.cn [白山云 CDN].  
  7. Name:   zgovweb.v.bsgslb.cn [白山云 CDN]  
  8. Address: 185.232.56.148  
  9. Name:   zgovweb.v.bsgslb.cn [白山云 CDN]  
  10. Address: 185.232.56.147  
  11. Name:   zgovweb.v.bsgslb.cn [白山云 CDN]  
  12. Address: 2001:428:6402:21b::6  
  13. Name:   zgovweb.v.bsgslb.cn [白山云 CDN]  
  14. Address: 2001:428:6402:21b::5 
  •  查询所有信息 
  1. $ nslookup www.gov.cn | nali  
  2. Server:         127.0.0.53 [局域网 IP]  
  3. Address:        127.0.0.53 [局域网 IP]#53  
  4. Non-authoritative answer:  
  5. www.gov.cn      canonical name = www.gov.cn.bsgslb.cn [白山云 CDN].  
  6. www.gov.cn.bsgslb.cn [白山云 CDN]       canonical name = zgovweb.v.bsgslb.cn [白山云 CDN].  
  7. Name:   zgovweb.v.bsgslb.cn [白山云 CDN]  
  8. Address: 103.104.170.25 [新加坡 ]  
  9. Name:   zgovweb.v.bsgslb.cn [白山云 CDN]  
  10. Address: 2001:428:6402:21b::5 [美国Louisiana州Monroe Qwest Communications Company, LLC (CenturyLink)]  
  11. Name:   zgovweb.v.bsgslb.cn [白山云 CDN]  
  12. Address: 2001:428:6402:21b::6 [美国Louisiana州Monroe Qwest Communications Company, LLC (CenturyLink)] 
  •  单独使用

需要提前查询到 CNAME 域名 

  1. $ nali cdn cdn.somecdncname.com 

一些使用技巧

  1.  更新纯真数据库 
  1. $ nali update  
  2. 2020/07/17 12:53:46 正在下载最新纯真 IP 库... 
  3. 2020/07/17 12:54:05 已将最新的纯真 IP 库保存到本地 /root/.nali/qqwry.dat 

      2.  使用自定义 IP 库

使用自定义 IP 库前,你需要设置环境变量:NALI_DB。目前支持的变量内容: 

  1. Geoip2 ['geoip', 'geoip2', 'geo']  
  2. Chunzhen ['chunzhen', 'qqip', 'qqwry'] 

使用三方 IP 库,需要手动提前下载相应的 IP 数据库。 

  1. # Windows 平台  
  2. ## 使用geoip数据库  
  3. set NALI_DB=geoip  
  4. ## 使用ipip数据库  
  5. set NALI_DB=ipip  
  6. # Linux平台  
  7. ## 使用geoip数据库  
  8. export NALI_DB=geoip  
  9. ## 使用ipip数据库  
  10. export NALI_DB=ipip  

 

责任编辑:庞桂玉 来源: 奇妙的Linux世界
相关推荐

2022-07-15 14:26:36

开源工具IP

2020-09-21 10:01:38

NaliIPISP

2011-10-31 10:34:12

2017-08-31 09:32:11

私有云服务支持

2012-05-14 09:46:42

腾讯

2021-01-22 05:40:54

保密安全信息

2022-06-23 06:55:05

数值索引数据检索数值查询

2018-07-28 05:21:43

PaaSIaaS云计算

2022-03-16 09:40:00

数据中心边缘计算托管

2018-10-18 08:54:46

云备份存储数据

2023-11-07 16:28:56

云提供商云计算

2012-09-17 22:22:50

第一线IPVPN

2019-07-29 11:09:05

云计算云备份

2018-04-04 13:15:17

云计算数据中心企业

2011-10-08 10:23:13

云计算云服务

2014-07-14 14:03:59

跟踪定位ios信息泄露

2015-02-02 10:43:28

2014-11-14 10:03:18

灾难恢复灾难恢复即服务DRaaS

2013-11-06 09:39:36

DRaaS灾难恢复灾难恢复即服务
点赞
收藏

51CTO技术栈公众号