- PVSM.RU - https://www.pvsm.ru -
Всем привет!
Хочу поделиться с вами моим опытом создания сетевого жесткого диска на Raspberry Pi. Моя статья отлично подойдет тем, кто использует линукс в качестве основной ОС, т.к. тут я активно использую SSHFS.
Всех заинтересовавшихся прошу под кат.
Нам необходимо:
Для начала необходимо установить на Raspberry Pi Raspbian или Arch Linux ARM.
В статье я буду использовать Raspbian.
$ sudo dcfldd bs=4M if=имя_вашего_образа_.img of=путь_к_вашей_карте
В моем случае команда выглядит так:
$ sudo dcfldd bs=4M if=2014-12-24-wheezy-raspbian.img of=/dev/mmcblk0
Обратите внимание, что в пути к вашей карте не надо указывать номер раздела (даже если он один). Образ записывается на всю карту.
bs — block size — размер одного блока, записывающегося на карту. Если при установленных 4M запись не работает, то необходимо поставить 1M, но это приведет к увеличению времени записи.
$ sync
Это позволит убедиться в том что все данные были записаны на карту и очистит буфер
$ sudo raspi-config
$ sudo reboot
$ sudo rpi-update
и после этого
$ sudo apt-get update
и
$ sudo apt-get upgrade
$ ssh-keygen -t rsa -C "your_email@example.com"
$ ssh-copy-id pi@192.168.0.102
Вас попросят ввести согласие на продолжение подключения. Нужно ввести yes. После чего вас попросят ввести пароль от учетный записи на Raspberry Pi. Вводим и его.
$ ssh pi@192.168.0.102
$ sudo passwd root
И введите новый пароль для root'a
$ sudo apt-get install vim
$ ssh root@192.168.0.102
и выполняем команду:
$ usermod -l новое_имя -d /home/новое_имя -m pi
Я использую в качестве нового имени inn0kenty, т.е. в моем случае команда выглядит так:
$ usermod -l inn0kenty -d /home/inn0kenty -m pi
У меня работает DHCP, поэтому при каждом подключении Raspberry Pi к домашней сети ей будет выдаваться новый ip адрес, что меня конечно не устраивает. Для того чтобы сделать ip статическим необходимо выполнить:
$ sudo vim /etc/network/interfaces
В открывшемся файле меняем
iface eth0 inet dhcp
на
iface eth0 inet static
address 192.168.0.98
netmask 255.255.255.0
network 192.168.0.0
broadcast 192.168.0.255
gateway 192.168.0.1
Указав при этом параметры вашей сети. Netmask и broadcast можно узнать с помощью команды sudo ifconfig, а gateway с помощью sudo route -nee.
$ ssh inn0kenty@192.168.0.98
На этом шаге я покажу как упростить подключение по ssh и сделать его более безопасным.
$ sudo vim /etc/ssh/sshd_config
И устанавливаем в нем запрет входить по ssh пользователю root и отключаем аутентификацию по паролю:
PasswordAuthentication no
PermitRootLogin no
А также меняем порт
Port 22226 (например)
$ sudo reboot
$ ssh -p 22226 inn0kenty@192.168.0.98
Но столь длинную команду можно упростить и свести к минимуму. Для этого на вашей основной ОС отредактируем файл config. В домашней директории выполните:
$ vim .ssh/config
и вставьте туда следующие строчки:
Host 192.168.0.98
Hostname 192.168.0.98
User inn0kenty
Port 22226
После этого для подключение к вашей Raspberry Pi необходимо будет набрать только
$ ssh 192.168.0.98
В этом разделе я хочу рассказать как подключаться по ssh к Raspberry Pi не только из локальной сети, но и извне.
Если у вас внешний ip статический, то, ура, можно особо не париться. Достаточно сделать переадресацию с внешнего ip на внутренний.
Но если у вас, как и у меня, внешний ip динамический, то на помощь нам придет dynamic dns.
Лично я пользуюсь noip.com т.к. он бесплатен, хотя и требует периодически заходить на сайт и подтверждать, что вы еще пользуетесь адресом, который они вам дали.
Итак, регистрируйтесь там и переходите в Add a Host.
$ vim .ssh/config
И добавляем туда
Host доменное_имя
Hostname доменное_имя
User inn0kenty
Port 22226
Сохраняем.
$ mkdir hdd
$ sudo blkid
В выводе должно быть что-то типа такого:
/dev/mmcblk0p1: SEC_TYPE="msdos" LABEL="boot" UUID="936C-7154" TYPE="vfat"
/dev/mmcblk0p2: UUID="c1398422-7a7c-4863-8a8f-45a1db26b4f2" TYPE="ext4"
/dev/sda1: LABEL="Seagate Expansion Drive" UUID="7CD8E7DCD8E792A6" TYPE="ntfs"
Последняя строчка как раз то, что нам нужно. Запоминаем UUID.
$ sudo apt-get install ntfs-3g
$ sudo vim /etc/fstab
UUID="*" ** ntfs-3g rw,force,exec,users 0 0
где * - это ваш UUID (у меня 7CD8E7DCD8E792A6)
а ** - это путь к вашей папке монтирования (у меня /home/inn0kenty/hdd)
$ sudo apt-get install sshfs
$ mkdir pi
$ sshfs 192.168.0.98:/home/inn0kenty/hdd pi
Все. Все наши файлы с жесткого диска оказались в папке pi на вашей основной машине
$ sudo umount pi
или
$ fusermount -u pi
$ sshfs доменное_имя:/home/inn0kenty/hdd pi
#!/bin/bash
ABSOLUTE_FILENAME=`readlink -e "$0"` #имя файла
#имя директории в которой файл находится
DIRECTORY=`dirname "$ABSOLUTE_FILENAME"`
if [ "x$1" = "x-nh" ] || [ "x$1" = "x-nothome" ] ; then
sshfs -o nonempty доменное_имя:/home/inn0kenty/hdd $DIRECTORY
# -o nonempty говорит sshfs о том что директория в которую
# монтируют не пуста
else
sshfs -o nonempty 192.168.0.98:/home/inn0kenty/hdd $DIRECTORY
fi
$ chmod +x mount.sh
$ mv mount.sh pi/
$ vim .bashrc
И добавьте туда строчку
alias pimount='/home/inn0kenty/pi/mount.sh'
Разумеется подставив ваши данные.
Сохраните и перезапустите bash.
Теперь можно монтировать вашу Raspberry Pi одной командой
$ pimount
Причем если указать ключ -nh или -nothome, то ваша Raspberry Pi примонтируется через доменное имя т.е. можно использовать вашу Raspberry Pi по полной даже не находясь в одной локальной сети с ней.
$ pimount -nh
или
$ pimount -nothome
Последний шаг — установка торрент-качалки. Я предпочитаю Deluge.
$ sudo apt-get install deluged
$ sudo apt-get install python-mako
$ sudo apt-get install deluge-web
$ sudo vim /etc/default/deluge-daemon
и вводим туда следующее:
# Configuration for /etc/init.d/deluge-daemon
# The init.d script will only run if this variable non-empty.
DELUGED_USER="ваше_имя_пользователя" # !!!CHANGE THIS!!!!
# Should we run at startup?
RUN_AT_STARTUP="YES"
Затем сохраняем и закрываем
$ sudo vim /etc/init.d/deluge-daemon
и вводим туда следующее:
#!/bin/sh
### BEGIN INIT INFO
# Provides: deluge-daemon
# Required-Start: $local_fs $remote_fs
# Required-Stop: $local_fs $remote_fs
# Should-Start: $network
# Should-Stop: $network
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Daemonized version of deluge and webui.
# Description: Starts the deluge daemon with the user specified in
# /etc/default/deluge-daemon.
### END INIT INFO
# Author: Adolfo R. Brandes
# Updated by: Jean-Philippe "Orax" Roemer
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
DESC="Deluge Daemon"
NAME1="deluged"
NAME2="deluge"
DAEMON1=/usr/bin/deluged
DAEMON1_ARGS="-d" # Consult `man deluged` for more options
DAEMON2=/usr/bin/deluge-web
DAEMON2_ARGS="" # Consult `man deluge-web` for more options
PIDFILE1=/var/run/$NAME1.pid
PIDFILE2=/var/run/$NAME2.pid
UMASK=022 # Change this to 0 if running deluged as its own user
PKGNAME=deluge-daemon
SCRIPTNAME=/etc/init.d/$PKGNAME
# Exit if the package is not installed
[ -x "$DAEMON1" -a -x "$DAEMON2" ] || exit 0
# Read configuration variable file if it is present
[ -r /etc/default/$PKGNAME ] && . /etc/default/$PKGNAME
# Load the VERBOSE setting and other rcS variables
[ -f /etc/default/rcS ] && . /etc/default/rcS
# Define LSB log_* functions.
# Depend on lsb-base (>= 3.0-6) to ensure that this file is present.
. /lib/lsb/init-functions
if [ -z "$RUN_AT_STARTUP" -o "$RUN_AT_STARTUP" != "YES" ]
then
log_warning_msg "Not starting $PKGNAME, edit /etc/default/$PKGNAME to start it."
exit 0
fi
if [ -z "$DELUGED_USER" ]
then
log_warning_msg "Not starting $PKGNAME, DELUGED_USER not set in /etc/default/$PKGNAME."
exit 0
fi
#
# Function to verify if a pid is alive
#
is_alive()
{
pid=`cat $1` > /dev/null 2>&1
kill -0 $pid > /dev/null 2>&1
return $?
}
#
# Function that starts the daemon/service
#
do_start()
{
# Return
# 0 if daemon has been started
# 1 if daemon was already running
# 2 if daemon could not be started
is_alive $PIDFILE1
RETVAL1="$?"
if [ $RETVAL1 != 0 ]; then
rm -f $PIDFILE1
start-stop-daemon --start --background --quiet --pidfile $PIDFILE1 --make-pidfile
--exec $DAEMON1 --chuid $DELUGED_USER --user $DELUGED_USER --umask $UMASK -- $DAEMON1_ARGS
RETVAL1="$?"
else
is_alive $PIDFILE2
RETVAL2="$?"
[ "$RETVAL2" = "0" -a "$RETVAL1" = "0" ] && return 1
fi
is_alive $PIDFILE2
RETVAL2="$?"
if [ $RETVAL2 != 0 ]; then
sleep 2
rm -f $PIDFILE2
start-stop-daemon --start --background --quiet --pidfile $PIDFILE2 --make-pidfile
--exec $DAEMON2 --chuid $DELUGED_USER --user $DELUGED_USER --umask $UMASK -- $DAEMON2_ARGS
RETVAL2="$?"
fi
[ "$RETVAL1" = "0" -a "$RETVAL2" = "0" ] || return 2
}
#
# Function that stops the daemon/service
#
do_stop()
{
# Return
# 0 if daemon has been stopped
# 1 if daemon was already stopped
# 2 if daemon could not be stopped
# other if a failure occurred
start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --user $DELUGED_USER --pidfile $PIDFILE2
RETVAL2="$?"
start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --user $DELUGED_USER --pidfile $PIDFILE1
RETVAL1="$?"
[ "$RETVAL1" = "2" -o "$RETVAL2" = "2" ] && return 2
rm -f $PIDFILE1 $PIDFILE2
[ "$RETVAL1" = "0" -a "$RETVAL2" = "0" ] && return 0 || return 1
}
case "$1" in
start)
[ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME1"
do_start
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
stop)
[ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME1"
do_stop
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
restart|force-reload)
log_daemon_msg "Restarting $DESC" "$NAME1"
do_stop
case "$?" in
0|1)
do_start
case "$?" in
0) log_end_msg 0 ;;
1) log_end_msg 1 ;; # Old process is still running
*) log_end_msg 1 ;; # Failed to start
esac
;;
*)
# Failed to stop
log_end_msg 1
;;
esac
;;
*)
echo "Usage: $SCRIPTNAME {start|stop|restart|force-reload}" >&2
exit 3
;;
esac
:
$ sudo chmod 755 /etc/init.d/deluge-daemon
$ sudo update-rc.d deluge-daemon defaults
$ sudo invoke-rc.d deluge-daemon start
После сохранения можно будет попасть на web ui просто вбив ваше доменное имя в адресную строку браузера.
Я надеюсь, что моя статья хоть кому-то окажется полезной. Спасибо за уделенное внимание и потраченное время.
Автор: inn0kenty
Источник [3]
Сайт-источник PVSM.RU: https://www.pvsm.ru
Путь до страницы источника: https://www.pvsm.ru/linux/79421
Ссылки в тексте:
[1] загрузок: http://www.raspberrypi.org/downloads/
[2] отсюда: https://www.noip.com/download?page=linux
[3] Источник: http://habrahabr.ru/post/247783/
Нажмите здесь для печати.