Як автоматично встановити з командного рядка?


25

Як я можу запустити автозаряд з командного рядка? Під "automount" я не маю на увазі повністю автоматичне встановлення, але отримання списку доступних пристроїв, а потім вибору одного і його закінчення як /media/{user}/{diskid}. Цю функціональність, наприклад, надає Nautilus або Thunar, але я не можу знайти інструмент командного рядка для запуску такого типу напівавтоматичного кріплення.

pmountє найближчим, що я знайшов, але, здається, працює зовсім інша механіка внизу і змушує пристрої відображатись як /media/sdfщось подібне.

Відповіді:


29

Ви можете використовувати:

udisksctl кріплення -b ім'я_пристрою

деdevice_name назва пристрою зберігання даних і має виглядати щось подібне /dev/sdb1.

Використовуючи lsblkабо sudo fdisk -lкомандуючи, ви можете знайти всі пристрої зберігання даних, приєднані до вашої системи.


2
Спробував, що, однак, призводить до цього /media/{disk}, відрізняється від того, що дадуть Тунар або Наутілус. Однак udisksctlкоманда, яка надається, udisks2здається, робить те, що я хочу.
Grumbel

1
udisksctl statusдасть належний перелік пристроїв та працює як користувач. fdisk -lне тільки вимагає root, але також вийде з ладу з GPT-накопичувачами. cat /proc/partitionsбув би кращим низьким рівнем способу отримати уявлення про наявні розділи.
Grumbel

udiskctlнадзвичайно корисний і для монтажу файлів дискових зображень на циклічні пристрої без привілеїв root!

Здається, udiskбули доступні до 14.04.
Пабло А

13

gio mount

gvfs тепер вказаний як застарілий (2018), і вам рекомендується використовувати "gio", який є Gnome In Out та частиною Glib. Дивіться Вікіпедію .

Наприклад, для автоматичного монтажу другого дискового розділу; створити bash-скрипт із дозволеним файлом для запуску при наступній команді:

gio mount -d /dev/sda2

Якщо ви є власником розділу (див. chown), Вам не знадобиться судо.

Щоб встановити ISO-файл, розміщений, наприклад, на ~/ISOs:

gio mount "archive://file%3A%2F%2F%2Fhome%2Fpablo%2FISOs%2Fubuntu-18.04-desktop-amd64.iso"

Ви можете URL-адреса кодувати шлях за допомогою Python 3 та realpath(щоб об'єднатися в archive://:

python -c "import urllib.parse, sys; print(urllib.parse.quote(sys.argv[1] if len(sys.argv) > 1 else sys.stdin.read()[0:-1], \"\"))" "file://$(realpath ubuntu-18.04-desktop-amd64.iso)"

Це буде монтуватися далі /run/user/$(id -u)/gvfs/.

В якості альтернативи gnome-disk-image-mounterяруся далі /media/$USER/.

Демонтувати використання gio mount -u /run/user/$(id -u)/gvfs/archive*(або /media/$USER/залежно від способу встановлення).

udisksctl

Перелік доступних пристроїв:

udisksctl status

Монтаж здійснюється за допомогою:

udisksctl mount -b /dev/sdf

або

udisksctl mount -p block_devices/sdf

Демонтаж здійснюється через:

udisksctl unmount -b /dev/sdf

або

udisksctl unmount -p block_devices/sdf

object-pathМожна дізнатися, виконавши:

udisksctl dump

Об'єкт типу , org.freedesktop.UDisks2.Blockздається, діє , як object-patch, то /org/freedesktop/UDisks2/префікс повинен бути вирізані з шляху для udisksctl , щоб прийняти їх.

gvfs-mount

Список доступних пристроїв можна виконати за допомогою:

gvfs-mount --list

Монтаж їх можна здійснити за допомогою:

gvfs-mount -d /dev/sdf

Демонтаж можливий за допомогою:

gvfs-mount --unmount /media/user/01234567890

Одна з проблем, що залишаються в тому, що я не маю уявлення, як використовувати gvfs-mount --listвихід у команді mount, оскільки --listне відображатимуться імена блокових пристроїв, а спроба використовувати назви пристроїв, які він друкує в монті, призведе до:

Error mounting location: volume doesn't implement mount

Висновок

Хоча обидва gvfs-mountі udisksctlпрацюватимуть над завданнями, їхній інтерфейс недоцільний, оскільки вони не забезпечують доступного для читання людиною статусу доступних дисків, а лише надмірно багатослівний інформаційний дамп.


1
Чи можете ви розширити свою відповідь, включаючи, як встановити ізо gio mount? 18.04 з gio mount -lповерненням Archive Mounter, Type: GDaemonMountале я не зміг його встановити через CLI (можливо , проблема ?).
Пабло А

6

Просте рішення, яке працює як потрібно (монтується до / media / {user} / {diskid}), за винятком того, що воно не може перелічувати пристрої, але йому потрібно надати точну, залежну від регістру мітку тома як аргумент $ 1

Для монтажу :

DEVICE=$(findfs LABEL=$1) && udisksctl mount -b $DEVICE

Демонтувати :

DEVICE=$(findfs LABEL=$1) && udisksctl unmount -b $DEVICE

Приємно. Або просто:udisksctl mount -b $(findfs LABEL=<label>)
Brent Faust

1

Я просто зіткнувся з проблемою і знайшов таке рішення:

udisksctl mount -b /dev/disk/by-labels/$LABEL

Він запитає пароль користувача, навіть якщо це ви та ви вже ввійшли в систему.


0

Я написав цей сценарій Баша, щоб вирішити цю проблему, але пам’ятайте, що я новачок сценарію. Всі пропозиції вітаються! Використання та опис наведено нижче сценарію.

#!/bin/bash
# umanage.sh
# 2014-05-05

BASEPATH="/media/$(whoami)/"
RESULTS=$(udisksctl dump | grep IdLabel | grep -c -i "$1")

case "$RESULTS" in

0 )     echo "Nothing found."
        ;;

1 )     DEVICELABEL=$(udisksctl dump | grep IdLabel | grep -i "$1" | cut -d ":" -f 2 | sed 's/^[ \t]*//')
        DEVICE=$(udisksctl dump | grep -i "IdLabel: \+$DEVICELABEL" -B 12 | grep " Device:" | cut -d ":" -f 2 | sed 's/^[ \t]*//')
        DEVICEPATH="$BASEPATH""$DEVICELABEL"

        if [[ -z $(mount | grep "$DEVICE") ]]
        then
                echo "Found unmounted $DEVICE partition."
                echo "Do you want to mount it in $DEVICEPATH?"
                select yn in "Mount" "Ignore"
                do
                        case $yn in
                        Mount )         udisksctl mount -b "$DEVICE"
                                        break
                                        ;;
                        Ignore )        exit
                                        ;;
                        esac
                done
        else
                echo "Found $DEVICE partition, currently mounted in $DEVICEPATH."
                echo "Do you want to unmount it?"
                select yn in "Unmount" "Ignore"
                do
                        case $yn in
                        Unmount )       udisksctl unmount -b "$DEVICE"
                                        break
                                        ;;
                        Ignore )        exit
                                        ;;
                        esac
                done
        fi
        ;;

* )     if [ $# -eq 0 ]
        then
                echo "No argument supplied"
        else
                echo "$RESULTS possible results. You may be looking for:"
                echo
                udisksctl dump | grep IdLabel | grep -i "$1" | cut -d ":" -f 2 | sed 's/^[ \t]*//' | sed '/^$/d'
                echo
                echo "Please refine your search."
        fi
        ;;

esac

Використання:

  • збережіть сценарій як umanage.sh
  • зробити його виконуваним: chmod + x umanage.sh
  • запустіть його: ./umanage.sh YourDeviceLabel

Сценарій приймає в якості аргументу мітку розділу, який ви хочете змонтувати, і шукає на дамісі udisksctl для відповідних записів.

Якщо розділ знайдено і він не змонтований, відображаються назва пристрою та шлях, і вам пропонується змонтувати розділ. Сценарій теж шукає часткові мітки, і це не буде хвилюватись у верхньому та нижньому регістрі (корисно, коли ви не пам’ятаєте точну мітку).

./umanage.sh PASSPORT
Found unmounted /dev/sdf1 partition.
Do you want to mount it in /media/pixel/My Passport?
1) Mount
2) Ignore
#? 

Якщо розділ знайдений і він уже змонтований, вам пропонується зняти його:

./umanage.sh passp
Found /dev/sdf1 partition, currently mounted in /media/open/My Passport.
Do you want to unmount it?
1) Unmount
2) Ignore
#?

Якщо ваш аргумент відповідає більш ніж результату, скрипт показує вам відповідні мітки розділу і просить уточнити пошук:

./umanage.sh SS
2 possible results. You may be looking for:

SSD-9GB
My Passport

Please refine your search.

0

Сценарій для монтажу накопичувача - mount-menu.sh

mount-menu.shСценарій дозволяє вибрати демонтувати диски / розділи для установки. Для виклику сценарію використання: sudo mount-menu.sh. Цей екран відображається з урахуванням вашого унікального машинного середовища:

mount-menu 1.png

  • За допомогою клавіш зі стрілками виберіть розділ і натисніть Enter

Меню очищає та залишає цю інформацію у вашому терміналі:

=====================================================================
Mount Device:  /dev/nvme0n1p10
Mount Name:    /mnt/mount-menu.FPRAW
File System:   ext4
ID:            Ubuntu
RELEASE:       18.04
CODENAME:      bionic
DESCRIPTION:   Ubuntu 18.04.1 LTS
 Size  Used Avail Use%
  27G  7.9G   18G  32%

Тепер ви можете використовувати: cd /mnt/mount-menu.FPRAWдля доступу до розділу зовнішнього диска.

Тоді ви можете cd home/YOUR_NAMEмати на увазі не ставити /перед собою home. Якщо ви користуєтесь cd /homeцим, ви перейдете до вашого завантажувального диска та поза зовнішнього диска.

mount-menu.sh вміст сценарію

Щоб створити скрипт, відкрийте термінал і введіть:

sudo -H gedit /usr/local/bin/mount-menu.sh

Потім скопіюйте код нижче та вставте його gedit. Збережіть файл та вийдіть gedit.

Тепер позначте файл як виконуваний за допомогою:

sudo chmod a+x /usr/local/bin/mount-menu.sh

Ось сценарій для копіювання:

#!/bin/bash

# NAME: mount-menu.sh
# PATH: /usr/local/bin
# DESC: Select unmounted partition for mounting
# DATE: May 9, 2018. Modified May 11, 2018.

# $TERM variable may be missing when called via desktop shortcut
CurrentTERM=$(env | grep TERM)
if [[ $CurrentTERM == "" ]] ; then
    notify-send --urgency=critical \ 
                "$0 cannot be run from GUI without TERM environment variable."
    exit 1
fi

# Must run as root
if [[ $(id -u) -ne 0 ]] ; then echo "Usage: sudo $0" ; exit 1 ; fi

#
# Create unqique temporary file names
#

tmpMenu=$(mktemp /tmp/mount-menu.XXXXX)     # Menu list
tmpInfo=$(mktemp /tmp/mount-menu.XXXXX)     # Mount Parition Info
tmpWork=$(mktemp /tmp/mount-menu.XXXXX)     # Work file
MountName=$(mktemp -d /mnt/mount-menu.XXXXX)  # Mount directory name

#
# Function Cleanup () Removes temporary files
#

CleanUp () {
    [[ -f $tmpMenu ]] && rm -f $tmpMenu     # If temporary files created
    [[ -f $tmpInfo ]] && rm -f $tmpInfo     #  at various program stages
    [[ -f $tmpWork ]] && rm -f $tmpWork     #  remove them before exiting.
}


#
# Mainline
#

lsblk -o NAME,FSTYPE,LABEL,SIZE,MOUNTPOINT > $tmpMenu

i=0
SPACES='                                                                     '
DoHeading=true
AllPartsArr=()      # All partitions.

# Build whiptail menu tags ($i) and text ($Line) into array

while read -r Line; do
    if [[ $DoHeading == true ]] ; then
        DoHeading=false                     # First line is the heading.
        MenuText="$Line"                    # Heading for whiptail.
        FSTYPE_col="${Line%%FSTYPE*}"           
        FSTYPE_col="${#FSTYPE_col}"         # FS Type, ie `ext4`, `ntfs`, etc.
        MOUNTPOINT_col="${Line%%MOUNTPOINT*}"
        MOUNTPOINT_col="${#MOUNTPOINT_col}" # Required to ensure not mounted.
        continue
    fi

    Line="$Line$SPACES"                     # Pad extra white space.
    Line=${Line:0:74}                       # Truncate to 74 chars for menu.

    AllPartsArr+=($i "$Line")               # Menu array entry = Tag# + Text.
    (( i++ ))

done < $tmpMenu                             # Read next "lsblk" line.

#
# Display whiptail menu in while loop until no errors, or escape,
# or valid partion selection .
#

DefaultItem=0

while true ; do

    # Call whiptail in loop to paint menu and get user selection
    Choice=$(whiptail \
        --title "Use arrow, page, home & end keys. Tab toggle option" \
        --backtitle "Mount Partition" \
        --ok-button "Select unmounted partition" \
        --cancel-button "Exit" \
        --notags \
        --default-item "$DefaultItem" \
        --menu "$MenuText" 24 80 16 \
        "${AllPartsArr[@]}" \
        2>&1 >/dev/tty)

    clear                                   # Clear screen.
    if [[ $Choice == "" ]]; then            # Escape or dialog "Exit".
        CleanUp
        exit 1;
     fi

    DefaultItem=$Choice                     # whiptail start option.
    ArrNdx=$(( $Choice * 2 + 1))            # Calculate array offset.
    Line="${AllPartsArr[$ArrNdx]}"          # Array entry into $Line.

    # Validation - Don't wipe out Windows or Ubuntu 16.04:
    # - Partition must be ext4 and cannot be mounted.

    if [[ "${Line:MOUNTPOINT_col:4}" != "    " ]] ; then
        echo "Partition is already mounted."
        read -p "Press <Enter> to continue"
        continue
    fi

    # Build "/dev/Xxxxx" FS name from "├─Xxxxx" menu line
    MountDev="${Line%% *}"
    MountDev=/dev/"${MountDev:2:999}"

    # Build File System Type
    MountType="${Line:FSTYPE_col:999}"
    MountType="${MountType%% *}"

    break                                   # Validated: Break menu loop.

done                                        # Loop while errors.

#
# Mount partition
#

echo ""
echo "====================================================================="
mount -t auto $MountDev $MountName


# Display partition information.
echo "Mount Device=$MountDev" > $tmpInfo
echo "Mount Name=$MountName" >> $tmpInfo
echo "File System=$MountType" >> $tmpInfo

# Build Mount information (the partition selected for cloning to)
LineCnt=$(ls $MountName | wc -l)
if (( LineCnt > 2 )) ; then 
    # More than /Lost+Found exist so it's not an empty partition.
    if [[ -f $MountName/etc/lsb-release ]] ; then
        cat $MountName/etc/lsb-release >> $tmpInfo
    else
        echo "No LSB-Release file on Partition." >> $tmpInfo
    fi
else
    echo "Partition appears empty" >> $tmpInfo
    echo "/Lost+Found normal in empty partition" >> $tmpInfo
    echo "First two files/directories below:" >> $tmpInfo
    ls $MountName | head -n2 >> $tmpInfo
fi

sed -i 's/DISTRIB_//g' $tmpInfo      # Remove DISTRIB_ prefix.
sed -i 's/=/:=/g' $tmpInfo           # Change "=" to ":="
sed -i 's/"//g' $tmpInfo             # Remove " around "Ubuntu 16.04...".

# Align columns from "Xxxx:=Yyyy" to "Xxxx:      Yyyy"
cat $tmpInfo | column -t -s '=' > $tmpWork
cat $tmpWork > $tmpInfo

# Mount device free bytes
df -h --output=size,used,avail,pcent "$MountDev" >> $tmpInfo

# Display partition information.
cat $tmpInfo

CleanUp                             # Remove temporary files

exit 0

umount-menu.sh для демонтажу дисків / розділів

Повторіть процес створення / виконання файлу розмітки бітів для сценарію umount-menu.sh. Цей скрипт демонструє лише диски / розділи, на які був змонтований mount-menu.sh. Він має те саме меню вибору та доповнює повідомлення:

=====================================================================

/dev/nvme0n1p10 mounted on /mnt/mount-menu.FPRAW unmounted.

Щоб викликати сценарій, використовуйте: sudo umount-menu.sh

umount-menu.sh bash script:

!/bin/bash

# NAME: umount-menu.sh
# PATH: /usr/local/bin
# DESC: Select mounted partition for unmounting
# DATE: May 10, 2018. Modified May 11, 2018.

# $TERM variable may be missing when called via desktop shortcut
CurrentTERM=$(env | grep TERM)
if [[ $CurrentTERM == "" ]] ; then
    notify-send --urgency=critical \ 
                "$0 cannot be run from GUI without TERM environment variable."
    exit 1
fi

# Must run as root
if [[ $(id -u) -ne 0 ]] ; then echo "Usage: sudo $0" ; exit 1 ; fi

#
# Create unqique temporary file names
#

tmpMenu=$(mktemp /mnt/mount-menu.XXXXX)   # Menu list

#
# Function Cleanup () Removes temporary files
#

CleanUp () {
    [[ -f "$tmpMenu" ]] && rm -f "$tmpMenu" #  at various program stages
}


#
# Mainline
#

lsblk -o NAME,FSTYPE,LABEL,SIZE,MOUNTPOINT > "$tmpMenu"

i=0
SPACES='                                                                     '
DoHeading=true
AllPartsArr=()      # All partitions.

# Build whiptail menu tags ($i) and text ($Line) into array

while read -r Line; do
    if [[ $DoHeading == true ]] ; then
        DoHeading=false                     # First line is the heading.
        MenuText="$Line"                    # Heading for whiptail.
        MOUNTPOINT_col="${Line%%MOUNTPOINT*}"
        MOUNTPOINT_col="${#MOUNTPOINT_col}" # Required to ensure mounted.
        continue
    fi

    Line="$Line$SPACES"                     # Pad extra white space.
    Line=${Line:0:74}                       # Truncate to 74 chars for menu.

    AllPartsArr+=($i "$Line")               # Menu array entry = Tag# + Text.
    (( i++ ))

done < "$tmpMenu"                           # Read next "lsblk" line.

#
# Display whiptail menu in while loop until no errors, or escape,
# or valid partion selection .
#

DefaultItem=0

while true ; do

    # Call whiptail in loop to paint menu and get user selection
    Choice=$(whiptail \
        --title "Use arrow, page, home & end keys. Tab toggle option" \
        --backtitle "Mount Partition" \
        --ok-button "Select unmounted partition" \
        --cancel-button "Exit" \
        --notags \
        --default-item "$DefaultItem" \
        --menu "$MenuText" 24 80 16 \
        "${AllPartsArr[@]}" \
        2>&1 >/dev/tty)

    clear                                   # Clear screen.

    if [[ $Choice == "" ]]; then            # Escape or dialog "Exit".
        CleanUp
        exit 1;
     fi

    DefaultItem=$Choice                     # whiptail start option.
    ArrNdx=$(( $Choice * 2 + 1))            # Calculate array offset.
    Line="${AllPartsArr[$ArrNdx]}"          # Array entry into $Line.

    if [[ "${Line:MOUNTPOINT_col:15}" != "/mnt/mount-menu" ]] ; then
        echo "Only Partitions mounted by mount-menu.sh can be unounted."
        read -p "Press <Enter> to continue"
        continue
    fi

    # Build "/dev/Xxxxx" FS name from "├─Xxxxx" menu line
    MountDev="${Line%% *}"
    MountDev=/dev/"${MountDev:2:999}"

    # Build Mount Name
    MountName="${Line:MOUNTPOINT_col:999}"
    MountName="${MountName%% *}"

    break                                   # Validated: Break menu loop.

done                                        # Loop while errors.

#
# Unmount partition
#

echo ""
echo "====================================================================="
umount "$MountName" -l                      # Unmount the clone
rm  -d "$MountName"                         # Remove clone directory

echo $(tput bold)                           # Set to bold text
echo $MountDev mounted on $MountName unmounted.
echo $(tput sgr0)                           # Reset to normal text

CleanUp                                     # Remove temporary files

exit 0
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.