OVS 端口掩码计算

OpenVSwitch 1.6 开源版本放出来了,这个版本在进行 OF 流设置的时候,有一个很有趣的功能,就是可以指定端口掩码。

早在 OpenVSwitch 1.4 版本的时候就注意到这个功能,可惜 ovs-ofctl 使用手册中说这个功能只有 1.6 及以上版本才能使用。好不容易 1.6 版本放出来了,但 OpenVSwitch 却没有提供计算端口掩码的工具。没办法,“自己动手,丰衣足食”吧。写了个 Java 的小工具,可以计算端口掩码。

用法很简单,直接调用静态方法 OvsUtil.getPortMask(minPortNum, maxPortNum) 就 OK 了。

import java.util.ArrayList;  
import java.util.List;  
  
/** 
 * OVS工具类
 *  
 * @date 2012-3-24
 * @version 0.1
 */  
public class OvsUtil {  
    /** 
     * 端口位掩码数组 
     *  
     * 对于portBitMasks[i],按位与portBitMasks[i][0]可获取低i位的值,<br> 
     * 按位与portBitMasks[i][1]可获取高(16-i)位的值 
     */  
    private static final int[][] portBitMasks = new int[][] { { 0, 0xffff },  
            { 0x1, 0xfffe }, { 0x3, 0xfffc }, { 0x7, 0xfff8 }, { 0xf, 0xfff0 },  
            { 0x1f, 0xffe0 }, { 0x3f, 0xffc0 }, { 0x7f, 0xff80 },  
            { 0xff, 0xff00 }, { 0x1ff, 0xfe00 }, { 0x3ff, 0xfc00 },  
            { 0x7ff, 0xf800 }, { 0xfff, 0xf000 }, { 0x1fff, 0xe000 },  
            { 0x3fff, 0xc000 }, { 0x7fff, 0x8000 }, { 0xffff, 0 } };  
  
    /** 
     * 根据端口范围获取端口范围的掩码表示序列 
     *  
     * 由于端口号在1-65535之间,所以用int型表示足够了 
     *  
     * @param min 
     *            最小端口号 
     * @param max 
     *            最大端口号 
     *  
     * @return 表示最小端口号到最大端口号范围的掩码序列 
     */  
    public static String[] getPortMask(int min, int max) {  
        if (min < 1 || max > 0xffff || min > max) {  
            System.out.println("错误的端口号或端口号范围!");  
            return new String[0];  
        }  
  
        List<String> masks = new ArrayList<String>();  
  
        for (int n = min; n <= max;) {  
            int i = 1;  
            for (; i <= 16; ++i) {  
                int x = n + portBitMasks[i][0];  
                if (x > max || (x & portBitMasks[i][1]) != (n & portBitMasks[i][1])) {  
                    break;  
                }  
            }  
  
            // 因为i已经+1了,所以这里的--i就是掩码的长度  
            masks.add(toPortMask(n, --i));  
            // 下一个掩码前缀开始的地方  
            n += (portBitMasks[i][0] + 1);  
        }  
  
        return masks.toArray(new String[0]);  
    }  
  
    /** 
     * 根据开始端口号和掩码长度生成端口掩码 
     *  
     * @param port 
     *            端口号 
     * @param maskLen 
     *            掩码长度 
     *  
     * @return port/mask格式的端口掩码,如果掩码长度为0,则只返回端口号 
     */  
    private static String toPortMask(int port, int maskLen) {  
        if (0 == maskLen) {  
            return "0x" + Integer.toHexString(port);  
        }  
  
        return "0x" + Integer.toHexString(port & portBitMasks[maskLen][1]) + "/0x"  
                + Integer.toHexString(portBitMasks[maskLen][1]);  
    }  
}  
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 名词延伸 通俗的说,域名就相当于一个家庭的门牌号码,别人通过这个号码可以很容易的找到你。如果把IP地址比作一间房子...
    杨大虾阅读 20,658评论 2 56
  • 装载自http://sdnhub.cn/index.php/openv-switch-full-guide/ 1 ...
    ximitc阅读 6,141评论 0 11
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,015评论 25 709
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,107评论 19 139
  • 电影讲述一个平凡女孩Andy进入世界顶尖杂志社,快速成长,面对诱惑,内心经过挣扎,最终回归初心的故事。 在那里,有...
    NydiaPeng阅读 1,243评论 0 3