Commit c37b3b0f authored by Pierre-Elliott Bécue's avatar Pierre-Elliott Bécue

[iscsi] Kludges sales pour virer les liens morts supplémentaires.

 Si seulement udev se débarassait des modules physiques qui n'existent plus...
parent 217d16d1
......@@ -157,7 +157,7 @@ class Nols(object):
# On récupère le mapping pour chercher un lun de libre
map = self.volume_map()
lun = 0
lun = 1
while lun in map: lun = lun + 1
# Création du volume
......
......@@ -29,7 +29,10 @@ def store_iscsi_volumes():
if line.startswith('ip-'):
device = os.readlink(PATH+line) # de la forme ../../sdb42
device = device.rsplit('/', 1)[1]
symlink = 'iscsi_' + ugin.getname(device)
if line.rsplit('-', 1)[1][0:4] == "part":
symlink = 'iscsi_' + ugin.getname("".join([i for i in device if i.isalpha()])) + "_part" + line.rsplit('-', 1)[1][4:]
else:
symlink = 'iscsi_' + ugin.getname(device)
line = line.rsplit('-', 1)[1]
_ = links.setdefault(line, [symlink, device])
return links
......@@ -41,7 +44,7 @@ def make_link(couple):
sym, dev = couple
diskstatus = subprocess.Popen(['file', '-sb', '/dev/' + dev], stdout=subprocess.PIPE)
diskstatus = diskstatus.stdout.readlines()[0]
if not os.path.islink(sym) and 'empty' in diskstatus:
if not (os.path.islink(sym)) and not 'empty' in diskstatus and not 'ERROR' in diskstatus:
sys.stdout.write("Création du lien /dev/" + sym + " -> /dev/" + dev + " … ")
try:
os.symlink(dev, sym)
......@@ -51,7 +54,7 @@ def make_link(couple):
sys.stdout.write(coul("ECHEC", 'rouge'))
res = False
sys.stdout.write('\n')
elif os.path.islink(sym) and 'empty' in diskstatus:
elif os.path.islink(sym) and ('empty' in diskstatus or 'ERROR' in diskstatus):
sys.stdout.write("Destruction du lien /dev/" + sym + " … ")
try:
os.remove(sym)
......@@ -76,7 +79,28 @@ def make_link(couple):
res = None
return res
def clean_iscsi_links():
"""Nettoie les liens présents dans /dev/iscsi_*"""
links = {}
# os.listdir retourne une liste désordonnée, l'idée est de privilégier
# l'ordre lexicographique pour que l'état du retour soit identifié.
state = subprocess.Popen(['ls', '/dev'], stdout=subprocess.PIPE)
state = state.stdout.readlines()
for line in state:
line = line.replace('\n', '')
if line.startswith('iscsi_'):
device = os.readlink('/dev/'+line) # de la forme ../../sdb42
symlink = line
make_link((symlink, device))
return links
if __name__ == '__main__':
if "-h" in sys.argv or "--help" in sys.argv:
print "Usage: udev_update_symlinks.py <options>"
print " -h, --help : print this message and exit"
print " --clean : clean empty links no longer referenced"
if "--clean" in sys.argv:
clean_iscsi_links()
nothing = True
links = store_iscsi_volumes()
for path in links.keys():
......
......@@ -37,4 +37,4 @@ exec_cmd "Rescan des volumes iscsi" \
iscsiadm -m session --rescan
exec_cmd "Mises à jours des liens symboliques dans /dev" \
python /usr/scripts/gestion/iscsi/udev_update_symlinks.py
python /usr/scripts/gestion/iscsi/udev_update_symlinks.py --clean
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment