[转帖]ipset命令介绍与基本使用
一. 介绍
ipset命令是用于管理内核中IP sets模块的,如iptables之于netfilter。ipset字面意思是一些IP地址组成一个集合(set)。但是ipset用于用于存储IP地址,整个子网,端口号(TCP/UDP),MAC地址,网络接口名或者上述这些的组合。ipset主要是由iptables来使用,用于提高iptables的灵活性,简化iptables的规则。可能你在使用iptables时会感觉到以下不便:
1. 使用iptables命令为一批IP地址或端口应用相同的iptables规则时,不得不为每个IP或端口都新建一条iptables规则。这有时会让iptables某个表特别庞大,但是规则看起来又非常冗余。
2. 当需要给某个iptables规则应用到一个新的IP地址或端口时,我们不得不新建一条iptables规则;当需要给某个iptables规则删除其中某个IP地址或端口时,则需要直接删除那条iptables规则。这会让iptables操作特别繁琐。
ipset可以解决以上问题:
1. 当需要把一批IP地址或端口都应用某个iptables规则时,只需要把一批IP地址和端口放入一个ipset中,把iptables规则应用到这个ipset就可以了。
2. 当需要更新iptables规则的IP地址或端口时,只要更新对应ipset中的IP地址或端口就可以了,不需要修改iptables表。
二. ipset命令基本介绍与使用
格式:
#ipset命令格式 ipset [ OPTIONS ] COMMAND [ COMMAND−OPTIONS ] COMMANDS := { create | add | del | test | destroy | list | save | restore | flush | rename | swap | help | version | − } OPTIONS := { −exist | −output { plain | save | xml } | −quiet | −resolve | −sorted | −name | −terse | −file filename } ipset create SETNAME TYPENAME [ CREATE−OPTIONS ] ipset add SETNAME ADD−ENTRY [ ADD−OPTIONS ] ipset del SETNAME DEL−ENTRY [ DEL−OPTIONS ] ipset test SETNAME TEST−ENTRY [ TEST−OPTIONS ] ipset destroy [ SETNAME ] ipset list [ SETNAME ] ipset save [ SETNAME ] ipset restore ipset flush [ SETNAME ] ipset rename SETNAME−FROM SETNAME−TO ipset swap SETNAME−FROM SETNAME−TO ipset help [ TYPENAME ] ipset version ipset −
COMMAND选项介绍:
n, create SETNAME TYPENAME [ CREATE−OPTIONS ]
通过指定SETNAME和TYPENAME创建一个新IP集合。如果指定-exist选项,ipset在创建一个已经存在的IP集合时,ipset将不会报错。
add SETNAME ADD-ENTRY [ADD-OPTIONS]
添加一个条目到SETNAME指定的IP集合中。如果指定-exist选项,IP集合存在此条目时,ipset将不会报错。
del SETNAME DEL-ENTRY [ DEL-OPTIONS ]
从SETNAME指定的IP集合中删除一个条目。如果指定-exist选项,IP集合不存在此条目时,ipset将不会报错。
test SETNAME TEST-ENTRY [ TEST-OPTIONS ]
测试一个条目是否在指定的IP集合中。如果在,ipset命令返回0,如果不在,则返回非0
x,destory [ SETNAME ]
销毁指定的IP集合,如果不指定,则销毁所有的IP集合。如果某一IP集合正在被引用,则ipset不对该IP集合做任何操作。
list [ STENAME ] [ OPTIONS ]
列出指定IP集合的头部数据和添加的条目,如果没有指定,则是所有的IP集。--sorted选项会把IP集合排序后输出。--output指定IP集合输出的格式:
# 创建名称为test的IP集 ~ # ipset create test hash:ip # 添加114.114.114.114到test IP集中 ~ # ipset add test 114.114.114.114 # 以普通文本格式输出test IP集内容 ~ # ipset list test -output plain Name: test Type: hash:ip Revision: 4 Header: family inet hashsize 1024 maxelem 65536 Size in memory: 8264 References: 0 Members: 114.114.114.114 # 以保存格式输出test IP集内容 ~ # ipset list test -output save create test hash:ip family inet hashsize 1024 maxelem 65536 add test 114.114.114.114 # 以XML格式输出test IP集内容 ~ # ipset list test -output xml <ipsets> <ipset name="test"> <type>hash:ip</type> <revision>4</revision> <header><family>inet</family><hashsize>1024</hashsize><maxelem>65536</maxelem> <memsize>8264</memsize> <references>0</references> </header> <members> <member><elem>114.114.114.114</elem></member> </members> </ipset> </ipsets>
save [ SETNAME ]
保存指定的IP集,如果没有指定,则是所有的IP集。如果不指定-file则是输出到标准输出,指定则是输出到指定文件。
~ # ipset save test -file /tmp/234
flush [ SETNAME ]
清空指定IP集,如果没有指定,则是所有的IP集。
e,rename SETNAME-FROM SETNAME-TO
重命名一个IP集
~ # ipset rename test test1
w,swap SETNAME-FROM SETNAME-TO
交换两个IP集的名称。但是两个IP集的必须存在而且SETTYPE兼容才可以。
其他选项:
timeout
设置IP集合添加的新条目的默认超时时间,新加的条目的时间超过超时时间后,将从IP集中删除。
-
# test IP集新添加的条目的默认超时时间300s
-
ipset create test hash:ip timeout 300
-
-
# 192.168.0.1在60s后从test IP集中移除
-
ipset add test 192.168.0.1 timeout 60
SET TYPE:
bitmap:ip
CREATE−OPTIONS := range fromip−toip|ip/cidr [ netmask cidr ] [ timeout value ] [ counters ] [ comment ] [ skbinfo ]
ADD−ENTRY := { ip | fromip−toip | ip/cidr }
ADD−OPTIONS := [ timeout value ] [ packets value ] [ bytes value ] [ comment string ] [ skbmark value ] [ skbprio value ] [ skbqueue value ]
DEL−ENTRY := { ip | fromip−toip | ip/cidr }
TEST−ENTRY := ip
举例:
range fromip−toip | ip/cidr:
# example 1 ~ # ipset create test3 bitmap:ip range 192.168.0.1-192.168.0.255 ~ # ipset add test3 192.168.1/24 ~ # ipset list test3 Name: test3 Type: bitmap:ip Revision: 3 Header: range 192.168.0.1-192.168.0.255 Size in memory: 92 References: 0 Members: 192.168.0.1 . . . 192.168.0.255 # example 2 ~ # ipset create test4 bitmap:ip range 192.168.0.1-192.168.0.100 ~ # ~ # ipset add test4 192.168.0/24 ipset v7.15: Element is out of the range of the set ~ # ~ # ipset add test4 192.168.0.100 ~ # ipset list test4 Name: test4 Type: bitmap:ip Revision: 3 Header: range 192.168.0.1-192.168.0.100 Size in memory: 76 References: 0 Members: 192.168.0.100 # example 3 ~ # ipset create test5 bitmap:ip range 192.168.1.0/16 ~ # ipset add test5 192.168.1/16 ~ # ipset list test5 Name: test5 Type: bitmap:ip Revision: 3 Header: range 192.168.0.0-192.168.255.255 Size in memory: 8252 References: 0 Members: 192.168.0.1 . . . 192.168.0.255 . . . 192.168.255.255 # example 4 ~ # ipset create test6 bitmap:ip range 192.168.1.0/16 ~ # ipset add test6 192.168.5/24 ~ # ipset list test6 Name: test6 Type: bitmap:ip Revision: 3 Header: range 192.168.0.0-192.168.255.255 Size in memory: 8252 References: 0 Members: 192.168.0.1 . . . 192.168.0.255
bitmap:ip,mac
CREATE−OPTIONS := range fromip−toip|ip/cidr [ timeout value ] [ counters ] [ comment ] [ skbinfo ]
ADD−ENTRY := ip[,macaddr]
ADD−OPTIONS := [ timeout value ] [ packets value ] [ bytes value ] [ comment string ] [ skbmark value ] [ skbprio value ] [ skbqueue value ]
DEL−ENTRY := ip[,macaddr]
TEST−ENTRY := ip[,macaddr]
举例:
range fromip−toip|ip/cidr:
-
~ # ipset create test bitmap:ip,mac range 192.168.0.0/16
-
~ # ipset add test 192.168.1.1,12:34:56:78:9A:BC
-
~ # ipset add test 192.168.1.2
-
~ # ipset list test
-
Name: test8
-
Type: bitmap:ip,mac
-
Revision: 3
-
Header: range 192.168.0.0-192.168.255.255
-
Size in memory: 532532
-
References: 0
-
Members:
-
192.168.1.1,12:34:56:78:9A:BC
-
192.168.1.2
bitmap:port
CREATE−OPTIONS := range fromport−toport [ timeout value ] [ counters ] [ comment ] [ skbinfo ]
ADD−ENTRY := { [proto:]port | [proto:]fromport−toport }
ADD−OPTIONS := [ timeout value ] [ packets value ] [ bytes value ] [ comment string ] [ skbmark value ] [ skbprio value ] [ skbqueue value ]
DEL−ENTRY := { [proto:]port | [proto:]fromport−toport }
TEST−ENTRY := [proto:]port
举例:
range [proto:]fromport−toport:
~ # ipset create test bitmap:port range 1024-4096 ~ # ipset add test 30000 ipset v7.15: Element is out of the range of the set ~ # ~ # ipset add test 2048 ~ # ~ # ipset list test Name: test Type: bitmap:port Revision: 3 Header: range 1024-4096 Size in memory: 436 References: 0 Members: 2048
hash:ip
CREATE−OPTIONS := [ family { inet | inet6 }]|[ hashsize value ] [ maxelem value ] [ netmask cidr ] [ timeout value ] [ counters ] [ comment ] [ skbinfo ]
ADD−ENTRY := ipaddr
ADD−OPTIONS := [ timeout value ] [ packets value ] [ bytes value ] [ comment string ] [ skbmark value ] [ skbprio value ] [ skbqueue value ]
DEL−ENTRY := ipaddr
TEST−ENTRY := ipaddr
举例:
-
~ # ipset create test hash:ip
-
~ # ipset add test 192.168.100.1
hash:mac
CREATE−OPTIONS := [ hashsize value ] [ maxelem value ] [ timeout value ] [ counters ] [ comment ] [ skbinfo ]
ADD−ENTRY := macaddr
ADD−OPTIONS := [ timeout value ] [ packets value ] [ bytes value ] [ comment string ] [ skbmark value ] [ skbprio value ] [ skbqueue value ]
DEL−ENTRY := macaddr
TEST−ENTRY := macaddr
举例:
-
~ # ipset create test hash:mac
-
~ # ipset add test 01:02:03:04:05:06
-
~ # ipset test test 01:02:03:04:05:06
hash:ip,mac
CREATE−OPTIONS := [ family { inet | inet6 }]|[ hashsize value ] [ maxelem value ] [ timeout value ] [ counters ] [ comment ] [ skbinfo ]
ADD−ENTRY := ipaddr,macaddr
ADD−OPTIONS := [ timeout value ] [ packets value ] [ bytes value ] [ comment string ] [ skbmark value ] [ skbprio value ] [ skbqueue value ]
DEL−ENTRY := ipaddr,macaddr
TEST−ENTRY := ipaddr,macaddr
举例:
-
~ # ipset create test hash:ip,mac
-
~ # ipset add test 1.1.1.1,01:02:03:04:05:06
-
~ # ipset test test 1.1.1.1,01:02:03:04:05:06
hash:net
CREATE−OPTIONS := [ family { inet | inet6 }]|[ hashsize value ] [ maxelem value ] [ timeout value ] [ counters ] [ comment ] [ skbinfo ]
ADD−ENTRY := netaddr
ADD−OPTIONS := [ timeout value ] [ nomatch ] [ packets value ] [ bytes value ] [ comment string ] [ skbmark value ] [ skbprio value ] [ skbqueue value ]
举例:
-
~ # ipset create test hash:net
-
~ # ipset add test 192.168.0.0/24
-
~ # ipset add test 10.1.0.0/16
-
~ # ipset add test 192.168.0/24
-
~ # ipset add test 192.168.0/30 nomatch
hash:net,net
CREATE−OPTIONS := [ family { inet | inet6 }]|[ hashsize value ] [ maxelem value ] [ timeout value ] [ counters ] [ comment ] [ skbinfo ]
ADD−ENTRY := netaddr,netaddr
ADD−OPTIONS := [ timeout value ] [ nomatch ] [ packets value ] [ bytes value ] [ comment string ] [ skbmark value ] [ skbprio value ] [ skbqueue value ]
CREATE−OPTIONS := [ family { inet | inet6 }]|[ hashsize value ] [ maxelem value ] [ timeout value ] [ counters ] [ comment ] [ skbinfo ]
ADD−ENTRY := netaddr,netaddr
ADD−OPTIONS := [ timeout value ] [ nomatch ] [ packets value ] [ bytes value ] [ comment string ] [ skbmark value ] [ skbprio value ] [ skbqueue value ]
举例:
-
~ # ipset create test hash:net,net
-
~ # ipset add test 192.168.0.0/24,10.0.1.0/24
-
~ # ipset add test 10.1.0.0/16,10.255.0.0/24
-
~ # ipset add test 192.168.0/24,192.168.54.0-192.168.54.255
-
~ # ipset add test 192.168.0/30,192.168.64/30 nomatch
hash:ip,port
CREATE−OPTIONS := [ family { inet | inet6 }]|[ hashsize value ] [ maxelem value ] [ timeout value ] [ counters ] [ comment ] [ skbinfo ]
ADD−ENTRY := ipaddr,[proto:]port
ADD−OPTIONS := [ timeout value ] [ packets value ] [ bytes value ] [ comment string ] [ skbmark value ] [ skbprio value ] [ skbqueue value ]
DEL−ENTRY := ipaddr,[proto:]port
TEST−ENTRY := ipaddr,[proto:]port
举例:
-
~ # ipset create test hash:ip,port
-
~ # ipset add test 192.168.1.0/24,80−82
-
~ # ipset add test 192.168.1.1,udp:53
-
~ # ipset add test 192.168.1.1,vrrp:0
-
~ # ipset test test 192.168.1.1,80
-
Warning: 192.168.1.1,80 is in set test.
[转帖]ipset命令介绍与基本使用的更多相关文章
- [转帖]十二 个经典 Linux 进程管理命令介绍
https://www.cnblogs.com/swordxia/p/4550825.html 接了 http referer 头 没法显示图片 可以去原始blog 里面去查看. 随笔- 109 ...
- 12个Linux进程管理命令介绍(转)
12个Linux进程管理命令介绍 [日期:2015-06-02] 来源:Linux中国 作者:Linux [字体:大 中 小] 执行中的程序在称作进程.当程序以可执行文件存放在存储中,并且运行的 ...
- 2.SDK目录结构和adb工具及命令介绍
安卓开发学习笔记 1.安卓开发之环境搭建 2.SDK目录结构和adb工具及命令介绍 1.SDK目录介绍: ******************************** add-ons:Androi ...
- git各种命令介绍以及碰到的各种坑
一.各种命令介绍: git pull:从其他的版本库(既可以是远程的也可以是本地的)将代码更新到本地,例如:'git pull origin master'就是将origin这个版本库的代码更新到本地 ...
- tar.xz如何解压:linux和windows下tar.xz解压命令介绍
在linux下怎么解压和压缩tar.xz文件? (本文由www.169it.com搜集整理) 在linux下解压tar.xz文件步骤 1 2 # xz -d ***.tar.xz //先解压xz # ...
- 查看MySQL数据库表的命令介绍
如果需要查看MySQL数据库中都有哪些MySQL数据库表,应该如何实现呢?下面就为您介绍查看MySQL数据库表的命令,供您参考. 进入MySQL Command line client下查看当前使用的 ...
- Docker学习总结之Run命令介绍
Docker学习总结之Run命令介绍 本文由Vikings(http://www.cnblogs.com/vikings-blog/) 原创,转载请标明.谢谢! 在使用Docker时,执行最多的命令某 ...
- maven常用命令介绍
mvn 3.0.4 创建maven项目命令 mvn archetype:generate -DgroupId=damocles-autocredit -DartifactId=damocles ...
- Pacman命令介绍
用pacman很久了,一直没有深入去研究到底它包含多少神秘的力量,每次都是pacman -Syu就简单的把所有升级更新问题搞定实在是让笔者懒惰了很多.不过也正是因为pacman的简单让笔者爱不释手,同 ...
- Android Debug Bridge命令介绍[转]
Android Debug Bridge命令介绍 Android Debug Bridge的一些基本命令.这个工具直译过来就是Android调试桥的意思.它提供了强大的特性,例如复制文件到设备或从设备 ...
随机推荐
- Langchain-Chatchat项目:1.1-ChatGLM2项目整体介绍
ChatGLM2-6B是开源中英双语对话模型ChatGLM-6B的第2代版本,引入新的特性包括更长的上下文(基于FlashAttention技术,将基座模型的上下文长度由ChatGLM-6B的2K ...
- 聆听无声的话语:手把手教你用ModelArts实现手语识别
摘要:ModelArts,化作我们与听力障碍之间的一座沟通桥梁. 据统计,我国有超过2000万人有听力语言障碍,每年有约3万名婴儿生来就失去了聆听的机会.或许是因为缺少与没有听力障碍的人交流的途径,环 ...
- 华为AppCube通过中国信通院“低代码开发平台通用能力要求”评估!
摘要:华为AppCube应用魔方顺利通过信通院评估,被认证为具备 "低代码开发平台通用能力"的企业服务平台. 本文分享自华为云社区<华为AppCube通过中国信通院" ...
- storybook组件属性详解:组件props到strorybook Args
首先我们查看官方文档:https://storybook.js.org/docs/vue/writing-docs/doc-block-argstable#customizing 官方的例子么有看到v ...
- 没有苹果开发者账号能否创建ios证书-最新
摘要: 本文介绍了在没有Mac电脑的情况下,使用appuploader工具生成iOS证书和描述文件的方法.随着大前端和H5框架的热门话题,越来越多的人希望将H5应用打包成iOS应用.苹果官方提供的 ...
- 在线一键生成安卓证书keystore 文件
在线一键生成安卓证书 keystore 文件 一般的打包工具都会有默认的安卓证书提供,但如果你需要上架需要用自己申请安卓证书 keystore 文件打包 apk 现有方便方便的工具,直接在网页就可以申 ...
- Solon cloud 使用融断器 sentinel 或 guava 或 semaphore
Solon Cloud 是一套防腐层的架构方案.提供统一的接口定义和配置设计,从而实现不同框架统一体验的效果. 目前,已适配的融断器有三个插件且体验方式完全相同,分别是: sentinel-solon ...
- Grafana--变量(label_values)
grafana官方文档:https://grafana.com/docs/grafana/latest/ 版本:6.5.2 模板与变量(摘抄自官方文档): 变量是值的占位符.您可以在度量查询和面板标题 ...
- 【CJsonObject】C++ JSON 解析器使用教程
能选封装的尽量不使用底层的 一.CJsonObject 简介 CJsonObject 是 Bwar 基于 cJSON 全新开发一个 C++ 版的 JSON 库. CJsonObject 的最大优势是轻 ...
- A*(A star)搜索总结
定义 先复制一则定义 A*算法在人工智能中是一种典型的启发式搜索算法 启发中的估价是用估价函数表示的: h(n)=f(n)+g(n) 其中f(n)是节点n的估价函数 g(n)表示实际状态空间中从初始节 ...
