413 Commits

Author SHA1 Message Date
Huan Xie
21149582ff XenAPI Remove useless files when use os-xenapi lib
XenServer has released os-xenapi lib on pypi, I have made a patch
https://review.openstack.org/#/c/406059/ use os-xenapi in nova
project. In this patch, we just delete those useless files and
folders.

Change-Id: I7cd83a492bae38fd9249f25b95663fa4385b262c
Partially-Implements: blueprint add-os-xenapi-library
2017-01-10 18:06:17 -08:00
Takashi NATSUME
4eb89c206e Add a hacking rule for string interpolation at logging
String interpolation should be delayed to be handled
by the logging code, rather than being done
at the point of the logging call.
So add the following hacking rule for it.

- [N354] String interpolation should be delayed at logging calls.

See the oslo i18n guideline.

* http://docs.openstack.org/developer/oslo.i18n/guidelines.html

Change-Id: Ief6d3ee3539c0857098fffdb7acfeec3e0fed6eb
Closes-Bug: #1596829
2016-10-11 08:39:48 +00:00
Stephen Finucane
6bb1fd776f plugins/xenserver: Add '.py' extension
All Python files, except executables, should have a '.py' extension.
This wasn't being done for files in the 'plugins/xenserver' folder,
likely because it seems unnatural to call a "plugin" with a file
extension.

Begin working towards a resolution for this by renaming all files to
include a '.py' extension. To avoid forcing operators to upgrade the
Nova service and per-host plugins at the same time, continue to
reference the old, non-'.py' filenames, using symlinks to ensure the
references continue to work. Once Ocata has been released, these
symlinks can be removed, the API version updated and the reference
updated to include the '.py' extension.

Change-Id: Icf4cf2424c15276a6c01778fb92f76bbdc9b2068
Closes-bug: #1302831
2016-09-21 10:56:39 +01:00
Jenkins
014b503a57 Merge "XenAPI: resolve the fetch_bandwidth failure" 2016-09-20 19:43:15 +00:00
Jenkins
bc1193f60f Merge "XenAPI: add unit test for plugin bandwidth" 2016-09-20 19:25:07 +00:00
Jianghua Wang
676babbd9a XenAPI: resolve the fetch_bandwidth failure
When introducing interim bridge for XenAPI, it introduced a interface
which is connected to the interim bridge and it has the name as
vifxxxxxxxx-xx. In the xenapi plugin of bandwidth, it uses
the pattern of "^vif*" to filter out VM's interfaces. Due to the
existing of vifxxxxxxxx-xx, it will get exception when parsing the
interface's name basing on "vif<dom#>.<dev>".
So let's give more restrict pattern to filter VM's vifs e.g. change from
"^vif*" to "^vif<dom#>.<dev#>". May consider to use another interface
name for the interface on interim bridge; but need cover both name
patterns when delete interfaces to avoid upgrade issues which may make
things complicated.

Change-Id: I36b96bbe2bb764f3d60cbeb43aa3dbd9a0a43f61
Closes-Bug: #1597551
2016-09-09 17:49:57 +08:00
Jianghua Wang
ab5e67f8ea XenAPI: add unit test for plugin bandwidth
Add unit test for plugin bandwidth. And there is a bug in
the plugin which does not close the opened file. This change
will try to fix it. It also splits _read_proc_net() into two
functions, so that it's easier to make the UT.

Change-Id: Ie871b1d16cf180e9709e46bb0d67573053d14376
2016-07-07 11:19:29 +08:00
Bob Ball
3e85b80649 XenAPI: Perform disk operations in dom0
Move some disk operations from DomU to Dom0 to allow Nova
to run independently from the hypervisor.

Some disk types can be created in Dom0 (e.g. swap, ext3) but
others cannot.  Add support here for creating those that can
in Dom0.  This will be documented in the independent_compute
config flag in the last patch in this series.

Implements: blueprint xenapi-independent-nova
Change-Id: I634e783a5e19f9710544920e12300b299fc06b36
2016-06-27 13:41:15 +01:00
Jenkins
9373f7f2d5 Merge "XenAPI: Support neutron security group" 2016-06-27 11:45:26 +00:00
Jenkins
6a119fc720 Merge "XenAPI: OVS agent updates the wrong port with Neutron" 2016-06-23 12:05:35 +00:00
Huan Xie
bebc0a4b2e XenAPI: Support neutron security group
This implementation is to give support on neutron security group with
XenServer as compute driver. When using neutron+openvswitch, the ovs
agent on compute node cannot run correctly due to lack of qbr linux
bridge on compute node. This change will add qbr linux bridge when
xenserver as hypervisor
Xenserver driver now doesn't have linux bridge, the connection is:
compute node: vm-vif -> br-int -> br-eth
network node: br-eth -> br-int -> br-ex
With this implemented, linux bridge(qbr) will be added in compute
node. Thus the security group rules can be applied on qbr bridge.
The connection will look like:
compute node: vm-vif -> qbr(linux bridge) -> br-int -> br-eth
network node: br-eth -> br-int -> br-ex

Closes-Bug: #1526138

Implements: blueprint support-neutron-security-group

DocImpact: /etc/modprobe.d/blacklist-bridge file in dom0 should be
    deleted since it prevent loading linux bridge module in dom0

Depends-On: I377f8ad51e1d2725c3e0153e64322055fcce7b54

Change-Id: Id9b39aa86558a9f7099caedabd2d517bf8ad3d68
2016-06-21 22:42:12 -07:00
jianghuaw
97745f2bee XenAPI: OVS agent updates the wrong port with Neutron
With xen hypervisor, it will create two sets of port/interface
for each VM vif: One is named as tapx.y which is qemu-emulated
NIC and is used when no PV drivers installed with the VM; The
other one is named as vifx.0 which is the xen network frontend
NIC and is used when VM has PV drivers installed. But neutron
only handle one port. If the finally used port is not the one
handled by neutron, the guest VM will have no network access.
The solution is to change nova xenapi to add a bridge, which
we call the 'interim bridge', between the VM and the OVS
integration bridge. In this way it will only expose to neutron
with the integration bridge's port which connected to the
interim bridge. So it will fix the issue mentioned above.

Closes-Bug: #1268955

Change-Id: I0cfc0284e1fcd1a6169d31a7ad410716037e5cc2
2016-06-21 12:45:34 +08:00
Rajesh Tailor
9ebf9a5aa5 Trivial-Fix: Fix typos
Change-Id: I09a87b7a13cf551f18ef1fb27aa9f5406baebab4
2016-06-13 06:41:08 +00:00
Mike Fedosin
78fbb4776e Make Xenplugin to work with glance v2 api
This code makes xenplugin version agnostic
and allows to work with both apis, depending
on what version is considered as 'current'

Plugin version is bumped to 1.4.

partially implements bp use-glance-v2-api
Co-Authored-By: Sudipta Biswas <sbiswas7@in.ibm.com>

Change-Id: I84f6971afaeaeed69a2d3e93a34af8df70d1fb00
2016-06-08 15:37:01 +05:30
Sudipta Biswas
0a533df573 get rid of the old _vhd methods
This patchset gets rid of all the old download_vhd/upload_vhd code.
The old _vhd calls won't work anymore since we won't send them the
right parameters.

Change-Id: I8c0b47a7e8a94ee4b20c888bd86c1a77920103b8
2016-06-08 12:26:30 +05:30
Stephen Finucane
ac9b37e619 plugins/xenserver: Resolve PEP8 issues
Some files have regressed since '798058' ensured PEP8 compliance.
Correct these regressions in preparation for enabled PEP8 checks.

Change-Id: I2d0bae469673e4b5e2238978a7ba63f6bfe0358a
Partial-Bug: #1302831
2016-08-15 18:11:49 +01:00
Jenkins
c9dff59c18 Merge "Typo fix: remove multiple whitespace" 2016-08-03 11:06:57 +00:00
yuyafei
c97f3eec01 Remove white space between print and ()
TrivialFix

Change-Id: Ice05cc9848bc0b647ee20cfad20c23b47f8fedbd
2016-08-02 07:31:35 +00:00
Alex Szarka
5af5d051a9 Typo fix: remove multiple whitespace
Remove multiple whitespace character from
doc/networking.rst file.

TrivialFix

Change-Id: I3e6a1543a3a0d8b001a158fda0e715f6098dab02
2016-07-12 15:24:00 +00:00
Jenkins
748833d3cf Merge "plugins/xenserver: Resolve PEP8 issues" 2016-03-10 14:27:09 +00:00
Tim Pownall
32d5764271 xenapi: fix when tar exits early during download
When downloading a streamed chunk from swift through glance gives tar
invalid input, tar will exit, but leave the plugin still trying to write
data to the dead process.

To stop this we can spot when the tar process exits early, and be sure
to stop trying to write more data to the dead process.

Change-Id: Ic2bc89fa6d08db505b044a9498c1bfa5b884a056
Closes-Bug: 1552293
2016-03-09 09:32:05 -06:00
Stephen Finucane
79805827bb plugins/xenserver: Resolve PEP8 issues
Before enabling PEP8 checks for these files, the actual PEP8 issues
need to be resolved. There are a number of "types" of issues that need
to be fixed:

* E112 expected an indented block
* E241 multiple spaces after ','
* E265 block comment should start with '# '
* E302 expected 2 blank lines, found 1
* H102 Apache 2.0 license header not found
* H237 module module is removed in Python 3
* H303 No wildcard (*) import.
* H404 multi line docstring should start without a leading new line
* H231 Python 3.x incompatible 'except x,y:' construct
* F403 from module import *' used; unable to detect undefined names
* F841 local variable 'name' is assigned to but never used
* N344 Use six.iteritems() instead of dict.iteritems().

The fixes for the above are all pretty self-explanatory, but there is
one exception. The 'N344' issues are not ignorable due to how the
"hacking" check is implemented. Rather than ignoring them, skip the
issue altogether by replacing 'iteritems' with 'items'. The difference
in memory usage that this incurs should not be noticable.

Change-Id: Ie26e3daca3b408c9ea43613bcb9996618b9abc69
Partial-Bug: #1302831
2016-03-09 11:23:33 +00:00
Alvaro Lopez Garcia
0eebaa01f8 xrange() is renamed to range() in Python 3
Change-Id: I423dd4ce36759e3dc482e66fb743358f467069ef
Partial-Bug: #1456955
2016-02-03 10:18:14 +01:00
Bo Wang
608b7d9047 Fix indexing of dict.keys() in python3
It will throw TypeError when you try to operate on
dict.keys() like a list in python3.
ref:https://docs.python.org/3/library/stdtypes.html#dictionary-view-objects

Partially implements blueprint: nova-python3-mitaka

Change-Id: I44fc5ceb4f533f0e3628bddc1b394cf5e6573a82
2016-01-15 00:48:35 +08:00
Sean Dague
89de4ed5e9 Add upload/download vhd2 interfaces
This adds interfaces to the glance plugin for uploading / downloading
vhd files by glance url instead of with a host / port / use_ssl
tuple. This makes it possible to have glance hosted on a non root url
and still work with xenserver.

This bumps the plugin version to 1.3 as these are new functions exposed.

Convert xenapi driver to using up/down vhd2

All unit test converted to use this new functionality.

Change-Id: I73f60de0b1644827238961e1659b0119b80bf82f
2015-12-18 12:37:35 +00:00
Sean Dague
6ebd61b28b retool xen glance plugin to work with urls
This makes internal changes to the xen glance plugins so that they are
internally passing information about the glance servers by urls. It
does not change the surface of the plugin (that will come later), so
at a top level we are still thinking of glance as a host, port, and
use_ssl. However that's immediately converted to an endpoint url which
is then used for all the rest of the effort.

Change-Id: Ie1dce099846c725ff1ad7bb32f74aa6ae701ee9a
2015-12-11 08:28:58 -05:00
Jenkins
1a86864e8b Merge "Fix a few typos" 2015-09-15 11:24:36 +00:00
Takashi NATSUME
e5f457d66f Fix a few typos
adress => address
curent => current
concurent => concurrent
a instance => an instance
optinally => optionally

Change-Id: I08e38d8418c2133475e4631bfaef17e34dd1c5bc
Closes-Bug: #1481123
2015-09-08 10:36:14 +09:00
John Hua
b97e409dfd xenapi: Support extra tgz images that with only a single VHD
Currently tgz images are supported only when the names of VHD files
within follow the format of "0.vhd, 1.vhd, ... (n-1).vhd" called VDI
chain.

To maximize the range of support, the arbitrary named VHD file could be
renamed to 0.vhd when the tgz image only has a single VHD file.

Change-Id: I01cadf26262b20f1ad5a19e4441b42a0155f5a52
2015-09-07 12:39:01 +00:00
Davanum Srinivas
ed0196ebb6 Get py34 subunit.run test discovery to work
Currently the tox py34 target uses testtools.run to run
a subset of our test harness. We need to be able to use
pretty_tox.sh just like py27 as we make progress with py34
support.

The first step is to make sure we can discover all the
tests using:
python -m subunit.run discover -t . ./nova/tests/ --list

So, we need to fix a bunch of things for the discovery
to work including updating to a new version of websockify.

In the xen code, we should keep the original import and
add except for py34 as xen uses an older python that does
not work with six.moves.

Depends-On: Ib4ef2e79b28b7180e564b3d6dc2188456c66c08a
Change-Id: I88b6746da6136a7386a173f6cacd42f0b470deee
2015-07-28 10:40:56 +00:00
John Garbutt
979d1116fe xenapi: don't send terminating chunk on errors
If we send the terminator on an error, it looks like we have actually
completed the upload, when that was not actually the case, we have
failed, and ideally we want glance to notice and mark the snapshot as
failed.

This partly reverts the following commit:
e039b036b5e9dbaff8b37f7ab22c209b71bdc182

It is not a full revert of the above commit, and some of the refactoring
and error handling changes are still useful.

Closes-Bug: #1398826
Change-Id: Ib608a32556135a5b7e666d02c4ee77722ea6e07c
2015-01-14 13:58:18 +00:00
Nikhil Komawar
9211822923 XenAPI: Check image status before uploading data
Currently, the Xen API plugin sends the data payload to Glance
without checking the image status. In consequence, if the image is
not in queued status Glance will not let the image upload succeed.
This is by design, please refer [0].

The issue here being; buffering of the data will happen on the Glance
server. Consequently, the bound to be failed upload operation will not
get a 409 until after a large chunk of data has already been streamed
to the Glance server. This may result into client side wastage of
bandwidth and wait time.

This patch proposes a HEAD call be made from the glance plugin to
Glance API; thus in turn checking the valid image state for the
data transfer.

[0] http://docs.openstack.org/developer/glance/statuses.html

Change-Id: I24c1222a3b1ac809353724500117e58d50615ac8
2015-01-05 16:23:27 -05:00
Nikhil Komawar
43e89abeb2 XenAPI: Refactor message strings to remove locals
This commit is a small refactor to the XenAPI glance plugin removing
the use of locals() to improve the readability.

Change-Id: I5de095ac1f7f38fd37cc9d6010a876995f0f8841
2015-01-05 16:20:22 -05:00
Johannes Erdfelt
3664d8e466 xenapi plugins must target only Python 2.4 features
Add a comment documenting the restriction that our xenapi plugins must
target Python 2.4 features because of restrictions with the XenServer
dom0 userspace.

Change-Id: Ide130923b16c0555c3190cbd63ce97e18d18aae0
2014-11-10 07:29:03 -08:00
Christopher Lefelhocz
e03525bf1a Fix xen plugin to retry on upload failure
The xen plugin does not catch all cases where upload can throw
an exception due to connection failures and timeouts.  This
change extends the try/execpt window to catch these cases.

Also added original connect which in part keeps us from lazy-loading
the connection and logging of exception information so we can
figure out later what happened.

Change-Id: If643a7da9f602ab7bb5d255031a841c674fa6c6f
Fixes-bug: 1378903
2014-11-06 12:58:21 -06:00
Jesse J. Cook
cc2a34ce05 update retryable errors & instance fault on retry
HTTP errors can be split into a few categories: client ephemeral, server
ephemeral, server permanent, and globally permanent. You could argue
there is even more permutations. However, for simplicity, these errors
can be viewed as ephemeral and permanent.

The Glance XenAPI plugin has been updated to raise a RetryableError for
ephemeral and unexpected (i.e. errors that are categorized as neither
permanent or ephemeral) errors.

Additionally, an instance fault will be logged every time an error
occurs. This will serve as transaction history where every attempt is a
transaction on the state. If an ephemeral error occurs, there is a
retry, then a permanent error, the history of each error will be in the
instance_faults.

Deployers should configure the num_retries relative to the number of
api_servers. Right now, servers are put in random order and then cycled.
Trying the same server multiple times could cause unnecessary load and
delays. However, trying multiple servers, is ideal when a single server
is behaving badly or cannot reach another server it needs to communicate
with to fulfill a request.

Closes-Bug: 1380776

Change-Id: I267a5b524c3ff8a28edf1a2285b77bb09049773c
2014-10-27 12:25:40 -05:00
John Garbutt
d65ca49990 xenapi: deal with reboots while talking to agent
The latest version of the agent has started changing the hostname
through the official windows APIs, when resetnetwork is called. This
means a reboot might happen after resetnetwork.

A reboot happens when polling for the version. Until now we wait for the
call timeout, before fetching the new dom id. This change ensures that
if we spot a reboot, the plugin exits early rather than keeping polling
the wrong dom id.

Turns out its best to wait for the dom_id to change, before trying
to poll the agent again. Once the dom_id in xenapi has been updated,
the xenstore keys are always in place.

Trying too early leads to lots of reboot detections because we are
retrying with the old dom_id. XenServer continues to return the old
dom_id for a little while after the reboot.

Closes-Bug: #1370999

Change-Id: Id0bf5b64f2b271d162db5bbce50167ab1f665c87
2014-09-26 14:57:05 +01:00
Jenkins
daed1ebdd5 Merge "XenAPI: run vhd-util repair if VHD check fails" 2014-09-21 01:01:14 +00:00
John Garbutt
bfdae32efb XenAPI: run vhd-util repair if VHD check fails
We can hit issues with corrupted VHDs if we copy a VHD while XenServer
is performing other operations. This happens because there are times
when we copy the VHD chains while XenServer is still performing a
coalesce of the VHD chain.

In most cases, vhd-util should be able to safely repair any metadata
corruption. It can copy the copy of the VHD footer at the front of the
VHD file and add it at the bottom on the VHD file. There is no VM data
loss, due to the way the coalesce happens, but the chain will be bigger
than it would be both before and after the coalesce.

This does not, however, ensure that snapshots are valid before uploading
them to glance. But should you launch a corrupted snapshot, this change
would fix up the snapshot, and allow it to boot correctly.

Closes-Bug: #1362595

Change-Id: I88b737d7e97964a9db5ccf2c39dea7fd0701ead4
2014-09-17 13:46:39 +01:00
Jesse J. Cook
e039b036b5 xenapi: send chunk terminator on subprocess exc
During chunk upload if a subprocess exception is thrown, a malformed
chunk upload occurs.

This patch adds logging for subprocess exceptions and sends the
terminator even in the event of a subprocess exception. The incomplete
file upload will then be cleaned up by the client.

Change-Id: I559f201430bcd4c36d669c7772a10bfe3cd54d41
Closes-Bug: 1365637
2014-09-04 14:48:51 -05:00
Brian Elliott
77aea0e6a3 xenapi: Do not retry snapshot upload on 500
If Glance returns a 500 response on an initial attempt to upload
a snapshot image, it will set the image status to killed.  Any retry
attempts will fail with a 409 response.

Hence, Nova should not attempt to retry the upload in this case, which
will eliminate many pointless retries.

Closes-Bug: 1349933

Change-Id: I1a8f2416923a368b02cf8963c747ebbb24d749a1
2014-06-10 17:10:03 +00:00
Joe Gordon
855fe98ef4 Fix and Gate on E265
pep8 E265 makes sure block comment start with '# '. Fix and gate on this
new rule as it helps improve comment readability.

In the few cases where the comment was just commented out code, remove
the comment.

Change-Id: Iea1c445df8ddc2b6c17a4ab697ad756eef2f91fa
2014-07-24 08:11:00 -04:00
Davanum Srinivas
f3dc6eefe7 Fix and gate on H305 and H307
Both H305 and H307 are part of the OpenStack style guide.

Ensure that there are 3 groups of imports, stdlib,
third-party and project specific. Within each category
ensure that imports are in alphabetical order.

Change-Id: Id4994551c135c3c1a4982153f0c6cacba6176b95
2014-07-15 01:13:26 +00:00
Christopher Lefelhocz
5255364933 XenAPI: adjust bittorrent settings
This commit addresses some optimizations when using libtorrent to
download.  The settings are documented here:
http://www.rasterbar.com/products/libtorrent/reference-Settings.html

I'm proposing to add these with dom0 environment overrides in case
any other adjustments are needed.  The changes effectively double the
download rate from the default settings.  It also allows unbalanced
download/upload which is preferred in openstack environments.

No unit tests were added as plugins are not currently unit tested.

Closes-bug: #1303993

Change-Id: I503a6a521c196e4ad58e0a16aba2988f66a9cdca
2014-05-07 18:46:45 +00:00
Alex Gaynor
b055e16846 Fixed many typos.
These were found using: https://github.com/intgr/topy

Change-Id: Ia4e14508c285d95ab4eaeabbde032ecc5e7c9e4b
2014-04-25 21:47:41 -07:00
Bob Ball
b634bf3a0b XenAPI: Use local rsync rather than remote if possible
Using ssh depends on the host being set up to be able to SSH into
itself which is not a common scenario.  While this is unavoidable for
the current implementation of resize across multiple hosts, if there
is a single host (i.e. a test scenario) or the resize is restricted
to the same host then we can succeed without SSH access

Dependency on Ia310e31d31aaf5c979e41c64af8223202a18e03a is because the
tests will always fail without Ia310 therefore this fix cannot be tested
without taking Ia310 as well.

Closes-bug: 1308064

Change-Id: I15802a1d97d380b1c5b74fc9f92ece2494fe789a
2014-04-22 18:06:59 +01:00
John Garbutt
6b578665d4 xenapi: Cleanup tar process on glance error
Currently, when the network connection to glance is interrupted, there
is different behaviour on upload and download.

This change ensures the behaviour between the two code paths is more
consistent.

Uploads generally need to be given more time before they timeout, so
to keep a single timeout between upload and download, the timeout is
increased to 90 seconds.

At the same time, it ensures the tar process gets killed when any
issues occur with the communication between the hypervisor and
glance.

Change-Id: Id5396e5d3c1052dc2979476a886412da65e08670
Closes-Bug: #1284596
2014-04-08 15:48:00 +01:00
Jenkins
416edbe2c3 Merge "Rename Openstack to OpenStack" 2014-03-18 01:17:47 +00:00
Johannes Erdfelt
27c8086028 xenapi plugins: Make sure subprocesses finish executing
Fixes bug 1286187

Neither execute_get_output() nor execute() would wait for the process to
fully finish executing. This could potentially create a race condition
where commands execute in a different order than intended.

Also, for execute() it could cause a process to never finish executing if
it generates enough output to block writing to the pipe.

Change-Id: I3404f4b3ca1cddeec2f3e7b393817a6ccc42bec7
2014-02-28 16:25:21 +00:00
Alexander Bochkarev
dd4032e9fb Enable flake8 H404 checking
This check indicates on comments in which multi line docstring should
start without a leading new line. This change fixed all violators of
said check.

Change-Id: Ic7357b8c7420767dba611f6fcee07b7700f3aea8
2014-02-27 11:15:55 +04:00