代码拉取完成,页面将自动刷新
#!/usr/bin/env python
#
# Create veth pairs and start up switch daemons
#
import os
import time
from subprocess import Popen,PIPE,call,check_call
from optparse import OptionParser
parser = OptionParser(version="%prog 0.1")
parser.set_defaults(port_count=4)
parser.set_defaults(of_dir="../openflow")
parser.set_defaults(port=6653)
parser.add_option("-n", "--port_count", type="int",
help="Number of veth pairs to create")
parser.add_option("-o", "--of_dir", help="OpenFlow root directory for host")
parser.add_option("-p", "--port", type="int",
help="Port for OFP to listen on")
parser.add_option("-N", "--no_wait", action="store_true",
help="Do not wait 2 seconds to start daemons")
(options, args) = parser.parse_args()
call(["/sbin/modprobe", "veth"])
for idx in range(0, options.port_count):
print "Creating veth pair " + str(idx)
veth = "veth%d" % (idx*2)
veth_peer = "veth%d" % (idx*2+1)
call(["/sbin/ip", "link", "add", "name", veth, "type", "veth",
"peer", "name", veth_peer])
for idx in range(0, 2 * options.port_count):
cmd = ["/sbin/ifconfig",
"veth" + str(idx),
"192.168.1" + str(idx) + ".1",
"netmask",
"255.255.255.0"]
print "Cmd: " + str(cmd)
call(cmd)
veths = "veth0"
for idx in range(1, options.port_count):
veths += ",veth" + str(2 * idx)
ofd = options.of_dir + "/udatapath/ofdatapath"
ofp = options.of_dir + "/secchan/ofprotocol"
try:
check_call(["ls", ofd])
except:
print "Could not find datapath daemon: " + ofd
sys.exit(1)
try:
check_call(["ls", ofp])
except:
print "Could not find protocol daemon: " + ofp
sys.exit(1)
if not options.no_wait:
print "Starting ofprotocol in 2 seconds; ^C to quit"
time.sleep(2)
else:
print "Starting ofprotocol; ^C to quit"
ofd_op = Popen([ofd, "-i", veths, "punix:/tmp/ofd"])
print "Started ofdatapath on IFs " + veths + " with pid " + str(ofd_op.pid)
call([ofp, "unix:/tmp/ofd", "tcp:127.0.0.1:" + str(options.port),
"--fail=closed", "--max-backoff=1"])
ofd_op.kill()
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。