Hierfür sind keine Root-Rechte erforderlich (viele dieser Befehle verwenden jedoch Bashismen und sind von diesen abhängig, sodass sie nicht in allen POSIX-kompatiblen Shells funktionieren):
Es gibt eine schnelle Möglichkeit, nach einem der folgenden Punkte zu fragen :sdX
grep -H . /sys/block/sda/{capability,uevent,removable,device/{model,type,vendor,uevent}}
/sys/block/sda/capability:52
/sys/block/sda/uevent:MAJOR=8
/sys/block/sda/uevent:MINOR=0
/sys/block/sda/uevent:DEVNAME=sda
/sys/block/sda/uevent:DEVTYPE=disk
/sys/block/sda/removable:0
/sys/block/sda/device/model:WDC WD360GD-00FN
/sys/block/sda/device/type:0
/sys/block/sda/device/vendor:ATA
/sys/block/sda/device/uevent:DEVTYPE=scsi_device
/sys/block/sda/device/uevent:DRIVER=sd
/sys/block/sda/device/uevent:MODALIAS=scsi:t-0x00
Die wirklich interessante Datei ist capability
. Auf meinem Debian habe ich eine genhd.h
Datei, also:
eval $(sed -ne '
s/#define.*GENHD_FL_\([A-Z0-9_]*\)[ \t]*\([0-9]*\) \?.*$/GENHD_FLAGS[\2]="\1"/p
' /usr/src/linux-headers-2.6.32-5-common-openvz/include/linux/genhd.h)
diskCapa=$(</sys/block/sda/capability)
for i in ${!GENHD_FLAGS[@]};do
(( diskCapa & i )) && echo ${GENHD_FLAGS[i]}
done
MEDIA_CHANGE_NOTIFY
UP
SUPPRESS_PARTITION_INFO
diskCapa=$(</sys/block/sdd/capability)
for i in ${!GENHD_FLAGS[@]};do
(( diskCapa & i )) && echo ${GENHD_FLAGS[i]}
done
REMOVABLE
MEDIA_CHANGE_NOTIFY
UP
SUPPRESS_PARTITION_INFO
Nur um zu wissen, ob das Flag removable
gesetzt ist:
grep REMOVABL /usr/src/linux-headers-3.2.0-4-common/include/linux/genhd.h
#define GENHD_FL_REMOVABLE 1
so
for disk in sd{a,b,c,d,e,f,g,h} ; do
(( $(< /sys/block/$disk/capability ) & 1 )) && echo $disk is removable
done
Testet, ob für den capability
Wert (in meinem sda
obigen Beispiel 52 ) das 1
Bit gesetzt ist (dh ob es sich um eine ungerade Zahl handelt).
Aber Linux rendert alle Flags in /sys
, also /sys/block/sdX/removable
ist es viel einfacher , danach zu fragen ! ;-)
So ein USB - Schlüssel sein könnte removable
, aber da es viele ist abnehmbarer Geräte, würde ich sicherstellen mag , dass die Größe des Mediums größer als 0 ist (wie ein unbelastetes CD-ROM-Laufwerk, für Probe)
und dass das Gerät ist nicht in Verwendung: Beim Anschauen sdX/trace/enable
ist das nicht gebunden:
Hinweis: All dies ist auf bash v4.2 + gut getestet.
Unter Bash können Sie diese sehr schnelle und effiziente Methode verwenden:
for disk in /sys/block/* ; do
[ -f "$disk/removable" ] && [ $(<"$disk/removable") -gt 0 ] &&
[ -f "$disk/size" ] && [ $(<"$disk/size") -gt 0 ] &&
[ -f "$disk/trace/enable" ] && [ -z "$(<"$disk/trace/enable")" ] &&
echo "${disk##*/} $(($(<"$disk/size")/1953125))G $(<"$disk/device/model")"
done
Auf meinem System gibt es 4 USB-Sticks, von denen einer ( sde
) bereits gemountet ist, sodass der vorherige Befehl Folgendes ausgibt:
sdd 8G Trans-It Drive
sdf 7G Storage Media
sdg 4G silicon-power
Mein Drehbuch:
Es gibt eine kleine Bash- Funktion, die ich geschrieben habe, um das aktualisierte Debian Live zu installieren.
#!/bin/bash
txtsize() {
local _c=$1 _i=0 _a=(b K M G T P)
while [ ${#_c} -gt 3 ] ; do
((_i++))
_c=$((_c>>10))
done
_c=000$(( ( $1*1000 ) >> ( 10*_i ) ))
((_i+=${3:-0}))
printf -v ${2:-REPLY} "%.2f%s" ${_c:0:${#_c}-3}.${_c:${#_c}-3} ${_a[_i]}
}
# Der erste Teil gibt nur die für Menschen lesbare Größe wieder. Die Funktion beginnt dort.
chooseFreeUsbKey() {
local _lUdisk _lUsize _lUdialog=dialog # whiptail # gdialog
local -A _lUdevices
unset ${1:-REPLY}
for _lUdisk in /sys/block/*; do
[ -f $_lUdisk/removable ] && [ $(<$_lUdisk/removable) -gt 0 ] &&
[ -f $_lUdisk/size ] && [ $(<$_lUdisk/size) -gt 0 ] &&
txtsize $(<$_lUdisk/size)*512 _lUsize &&
[ -f $_lUdisk/trace/enable ] && [ -z "$(<$_lUdisk/trace/enable)" ] &&
_lUdevices[${_lUdisk##*/}]="$_lUsize $(<$_lUdisk/device/model)"
done
case ${#_lUdevices[@]} in
0 ) ;; # echo Sorry no key found. ;;
1 ) IFS=§ read -a ${1:-REPLY} \
<<< "${!_lUdevices[@]}§${_lUdevices[@]%% *}§${_lUdevices[@]#* }";;
* ) declare -a menu
for _lUdisk in ${!_lUdevices[@]}; do
menu+=($_lUdisk "${_lUdevices[$_lUdisk]}")
done
_lUdisk=$($_lUdialog --menu "Choose a USB stick" \
$((LINES-3)) $((COLUMNS-3)) $((LINES-8)) \
"${menu[@]}" 2>&1 >/dev/tty)
IFS=§ read -a ${1:-REPLY} \
<<< "$_lUdisk§${_lUdevices[$_lUdisk]%% *}§${_lUdevices[$_lUdisk]#* }"
esac
}
Dies weist die Antwort als Array der Variablen zu, die als erstes Argument angegeben wurde, oder der Variablen $REPLY
:
chooseFreeUsbKey stick
echo "$stick"
sdf
echo "${stick[1]}"
7.26G
echo "${stick[2]}"
Storage Media
(Das letzte Feld kann Leerzeichen enthalten.)