use of netapp.manage.NaElement in project cloudstack by apache.
the class NetappManagerImpl method returnAvailableVolumeSize.
/**
* This method returns the available size on the volume in terms of bytes
* @param volName -- name of volume
* @param userName -- username
* @param password -- password
* @param serverIp -- ip address of filer
* @throws UnknownHostException
* @return-- available size on the volume in terms of bytes; return -1 if volume is offline
* @throws ServerException
*/
@Override
public long returnAvailableVolumeSize(String volName, String userName, String password, String serverIp) throws ServerException {
long availableSize = 0;
NaElement xi = new NaElement("volume-list-info");
xi.addNewChild("volume", volName);
NaServer s = null;
String volumeState = null;
try {
s = getServer(serverIp, userName, password);
NaElement xo = s.invokeElem(xi);
List volList = xo.getChildByName("volumes").getChildren();
Iterator volIter = volList.iterator();
while (volIter.hasNext()) {
NaElement volInfo = (NaElement) volIter.next();
availableSize = volInfo.getChildLongValue("size-available", -1);
volumeState = volInfo.getChildContent("state");
}
if (volumeState != null) {
//return -1 if volume is offline
return volumeState.equalsIgnoreCase("online") ? availableSize : -1;
} else {
// as good as volume offline
return -1;
}
} catch (NaException nae) {
s_logger.warn("Failed to get volume size ", nae);
throw new ServerException("Failed to get volume size", nae);
} catch (IOException ioe) {
s_logger.warn("Failed to get volume size ", ioe);
throw new ServerException("Failed to get volume size", ioe);
} finally {
if (s != null)
s.close();
}
}
use of netapp.manage.NaElement in project cloudstack by apache.
the class NetappManagerImpl method returnSnapshotSchedule.
/**
* Utility method to return snapshot schedule for a volume
* @param vol -- volume for the snapshot schedule creation
* @return -- the snapshot schedule
* @throws ServerException
*/
private String returnSnapshotSchedule(NetappVolumeVO vol) throws ServerException {
NaElement xi = new NaElement("snapshot-get-schedule");
xi.addNewChild("volume", vol.getVolumeName());
NaServer s = null;
try {
s = getServer(vol.getIpAddress(), vol.getUsername(), vol.getPassword());
NaElement xo = s.invokeElem(xi);
String weeks = xo.getChildContent("weeks");
String days = xo.getChildContent("days");
String hours = xo.getChildContent("hours");
String minutes = xo.getChildContent("minutes");
String whichHours = xo.getChildContent("which-hours");
String whichMinutes = xo.getChildContent("which-minutes");
StringBuilder sB = new StringBuilder();
sB.append(weeks).append(" ").append(days).append(" ").append(hours).append("@").append(whichHours).append(" ").append(minutes).append("@").append(whichMinutes);
return sB.toString();
} catch (NaException nae) {
s_logger.warn("Failed to get volume size ", nae);
throw new ServerException("Failed to get volume size", nae);
} catch (IOException ioe) {
s_logger.warn("Failed to get volume size ", ioe);
throw new ServerException("Failed to get volume size", ioe);
} finally {
if (s != null)
s.close();
}
}
use of netapp.manage.NaElement in project cloudstack by apache.
the class NetappManagerImpl method destroyLunOnFiler.
/**
* This method destroys a lun on the netapp filer
* @param lunName -- name of the lun to be destroyed
*/
@Override
@DB
public void destroyLunOnFiler(String lunName) throws InvalidParameterValueException, ServerException {
final TransactionLegacy txn = TransactionLegacy.currentTxn();
txn.start();
LunVO lun = _lunDao.findByName(lunName);
if (lun == null)
throw new InvalidParameterValueException("Cannot find lun");
NetappVolumeVO vol = _volumeDao.acquireInLockTable(lun.getVolumeId());
if (vol == null) {
s_logger.warn("Failed to lock volume id= " + lun.getVolumeId());
return;
}
NaServer s = null;
try {
s = getServer(vol.getIpAddress(), vol.getUsername(), vol.getPassword());
if (s_logger.isDebugEnabled())
s_logger.debug("Request --> destroyLun " + ":serverIp:" + vol.getIpAddress());
try {
//Unmap lun
NaElement xi2 = new NaElement("lun-unmap");
xi2.addNewChild("initiator-group", lunName);
xi2.addNewChild("path", lun.getPath() + lun.getLunName());
s.invokeElem(xi2);
} catch (NaAPIFailedException naf) {
if (naf.getErrno() == 9016)
s_logger.warn("no map exists excpn 9016 caught in deletelun, continuing with delete");
}
//destroy lun
NaElement xi = new NaElement("lun-destroy");
xi.addNewChild("force", "true");
xi.addNewChild("path", lun.getPath() + lun.getLunName());
s.invokeElem(xi);
//destroy igroup
NaElement xi1 = new NaElement("igroup-destroy");
//xi1.addNewChild("force","true");
xi1.addNewChild("initiator-group-name", lunName);
s.invokeElem(xi1);
_lunDao.remove(lun.getId());
txn.commit();
} catch (UnknownHostException uhe) {
txn.rollback();
s_logger.warn("Failed to delete lun", uhe);
throw new ServerException("Failed to delete lun", uhe);
} catch (IOException ioe) {
txn.rollback();
s_logger.warn("Failed to delete lun", ioe);
throw new ServerException("Failed to delete lun", ioe);
} catch (NaAPIFailedException naf) {
if (naf.getErrno() == 9017) {
//no such group exists excpn
s_logger.warn("no such group exists excpn 9017 caught in deletelun, continuing with delete");
_lunDao.remove(lun.getId());
txn.commit();
} else if (naf.getErrno() == 9029) {
//LUN maps for this initiator group exist
s_logger.warn("LUN maps for this initiator group exist errno 9029 caught in deletelun, continuing with delete");
_lunDao.remove(lun.getId());
txn.commit();
} else {
txn.rollback();
s_logger.warn("Failed to delete lun", naf);
throw new ServerException("Failed to delete lun", naf);
}
} catch (NaException nae) {
txn.rollback();
s_logger.warn("Failed to delete lun", nae);
throw new ServerException("Failed to delete lun", nae);
} finally {
if (vol != null) {
_volumeDao.releaseFromLockTable(vol.getId());
}
if (s != null)
s.close();
}
}
use of netapp.manage.NaElement in project cloudstack by apache.
the class NetappManagerImpl method createVolumeOnFiler.
/**
* This method creates a volume on netapp filer
* @param ipAddress -- ip address of the filer
* @param aggName -- name of aggregate
* @param poolName -- name of pool
* @param volName -- name of volume
* @param volSize -- size of volume to be created
* @param snapshotPolicy -- associated snapshot policy for volume
* @param snapshotReservation -- associated reservation for snapshots
* @param username -- username
* @param password -- password
* @throws UnknownHostException
* @throws InvalidParameterValueException
*/
@Override
@DB
public void createVolumeOnFiler(String ipAddress, String aggName, String poolName, String volName, String volSize, String snapshotPolicy, Integer snapshotReservation, String username, String password) throws UnknownHostException, ServerException, InvalidParameterValueException {
if (s_logger.isDebugEnabled())
s_logger.debug("Request --> createVolume " + "serverIp:" + ipAddress);
boolean snapPolicy = false;
boolean snapshotRes = false;
boolean volumeCreated = false;
NaServer s = getServer(ipAddress, username, password);
NaElement xi = new NaElement("volume-create");
xi.addNewChild("volume", volName);
xi.addNewChild("containing-aggr-name", aggName);
xi.addNewChild("size", volSize);
NaElement xi1 = new NaElement("snapshot-set-reserve");
if (snapshotReservation != null) {
snapshotRes = true;
xi1.addNewChild("percentage", snapshotReservation.toString());
xi1.addNewChild("volume", volName);
}
NaElement xi2 = new NaElement("snapshot-set-schedule");
if (snapshotPolicy != null) {
snapPolicy = true;
String weeks = null;
String days = null;
String hours = null;
String whichHours = null;
String minutes = null;
String whichMinutes = null;
StringTokenizer s1 = new StringTokenizer(snapshotPolicy, " ");
if (s1.hasMoreTokens()) {
weeks = s1.nextToken();
}
if (weeks != null && s1.hasMoreTokens()) {
days = s1.nextToken();
}
if (days != null && s1.hasMoreTokens()) {
String[] hoursArr = s1.nextToken().split("@");
hours = hoursArr[0];
whichHours = hoursArr[1];
}
if (hours != null && s1.hasMoreTokens()) {
String[] minsArr = s1.nextToken().split("@");
minutes = minsArr[0];
whichMinutes = minsArr[1];
}
if (weeks != null)
xi2.addNewChild("weeks", weeks);
if (days != null)
xi2.addNewChild("days", days);
if (hours != null)
xi2.addNewChild("hours", hours);
if (minutes != null)
xi2.addNewChild("minutes", minutes);
xi2.addNewChild("volume", volName);
if (whichHours != null)
xi2.addNewChild("which-hours", whichHours);
if (whichMinutes != null)
xi2.addNewChild("which-minutes", whichMinutes);
}
Long volumeId = null;
final TransactionLegacy txn = TransactionLegacy.currentTxn();
txn.start();
NetappVolumeVO volume = null;
volume = _volumeDao.findVolume(ipAddress, aggName, volName);
if (volume != null) {
throw new InvalidParameterValueException("The volume for the given ipAddress/aggregateName/volumeName tuple already exists");
}
PoolVO pool = _poolDao.findPool(poolName);
if (pool == null) {
throw new InvalidParameterValueException("Cannot find pool " + poolName);
}
pool = _poolDao.acquireInLockTable(pool.getId());
if (pool == null) {
s_logger.warn("Failed to acquire lock on pool " + poolName);
throw new ConcurrentModificationException("Failed to acquire lock on pool " + poolName);
}
volume = new NetappVolumeVO(ipAddress, aggName, pool.getId(), volName, volSize, "", 0, username, password, 0, pool.getName());
volume = _volumeDao.persist(volume);
volumeId = volume.getId();
try {
s.invokeElem(xi);
volumeCreated = true;
if (snapshotRes) {
s.invokeElem(xi1);
volume.setSnapshotReservation(snapshotReservation);
_volumeDao.update(volumeId, volume);
}
if (snapPolicy) {
s.invokeElem(xi2);
volume.setSnapshotPolicy(snapshotPolicy);
_volumeDao.update(volumeId, volume);
}
txn.commit();
} catch (NaException nae) {
//zapi call failed, log and throw e
s_logger.warn("Failed to create volume on the netapp filer:", nae);
txn.rollback();
if (volumeCreated) {
try {
//deletes created volume on filer
deleteRogueVolume(volName, s);
} catch (NaException e) {
s_logger.warn("Failed to cleanup created volume whilst rolling back on the netapp filer:", e);
throw new ServerException("Unable to create volume via cloudtools." + "Failed to cleanup created volume on netapp filer whilst rolling back on the cloud db:", e);
} catch (IOException e) {
s_logger.warn("Failed to cleanup created volume whilst rolling back on the netapp filer:", e);
throw new ServerException("Unable to create volume via cloudtools." + "Failed to cleanup created volume on netapp filer whilst rolling back on the cloud db:", e);
}
}
throw new ServerException("Unable to create volume", nae);
} catch (IOException ioe) {
s_logger.warn("Failed to create volume on the netapp filer:", ioe);
txn.rollback();
if (volumeCreated) {
try {
//deletes created volume on filer
deleteRogueVolume(volName, s);
} catch (NaException e) {
s_logger.warn("Failed to cleanup created volume whilst rolling back on the netapp filer:", e);
throw new ServerException("Unable to create volume via cloudtools." + "Failed to cleanup created volume on netapp filer whilst rolling back on the cloud db:", e);
} catch (IOException e) {
s_logger.warn("Failed to cleanup created volume whilst rolling back on the netapp filer:", e);
throw new ServerException("Unable to create volume via cloudtools." + "Failed to cleanup created volume on netapp filer whilst rolling back on the cloud db:", e);
}
}
throw new ServerException("Unable to create volume", ioe);
} finally {
if (s != null)
s.close();
if (pool != null)
_poolDao.releaseFromLockTable(pool.getId());
}
}
Aggregations