百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

「文章」树莓派 4B 变身 NAS 服务器

nanshan 2024-10-14 11:22 18 浏览 0 评论

前言

本文是视频 沦为矿渣的树莓派②变身NAS服务器 的图文版,建议先观看视频之后再来查看。


树莓派由于体积非常小,只有一张银行卡的大小,而且还支持 WiFi ,所以拿它当服务器也是一个不错的选择。只要找一个有电源的地方,丢在那里就行。

如果只是当成服务器来使用,可以感兴趣的人会比较少,如果能够在上面装些下载软件,再开启 smb 共享,那么树莓派也是可以当成一台的简单的 NAS 来使用的。

安装系统

个人推荐先使用官方系统 raspios , 不建议使用以前的 raspbian ,raspbian 是 32 位的系统,如果有使用 docker 的话,就会知道,32 位的 docker 镜像非常的少。如果可以的话,一定要装 64 位的系统,不管是官方的 raspios 还是 Ubuntu 都行。

这里我以官方的 raspios 来作为演示。

下载来源:清华镜像站(https://mirrors.tuna.tsinghua.edu.cn/raspberry-pi-os-images/

由于是当 NAS 使用,建议使用 lite 版 (https://mirrors.tuna.tsinghua.edu.cn/raspberry-pi-os-images/raspios_lite_arm64/images/raspios_lite_arm64-2020-08-24/2020-08-20-raspios-buster-arm64-lite.zip

下载后将里面的 img 镜像解压出来,然后使用镜像写入工具。我使用的是 usb image tools (我的网盘里面有),也可以使用其它的工具,例如 Etcher ,win32diskimager 等等。

开启 ssh

镜像写入完成后,如果直接弹出读卡器,然后启动树莓派的话,会发现无法用 ssh 连接。解决的方法也很简单,将内存卡重新插回电脑,在里面建立一个文件夹,名字为 ssh

这样系统启动后就开启 ssh 了。

换源

备份原来的

cp /etc/apt/source.list /etc/apt/source.list.bak

/etc/apt/source.list

deb https://mirrors.tuna.tsinghua.edu.cn/debian/ buster main contrib non-free
deb-src https://mirrors.tuna.tsinghua.edu.cn/debian/ buster main contrib non-free
deb https://mirrors.tuna.tsinghua.edu.cn/debian/ buster-updates main contrib non-free
deb-src https://mirrors.tuna.tsinghua.edu.cn/debian/ buster-updates main contrib non-free
deb https://mirrors.tuna.tsinghua.edu.cn/debian/ buster-backports main contrib non-free
deb-src https://mirrors.tuna.tsinghua.edu.cn/debian/ buster-backports main contrib non-free
deb https://mirrors.tuna.tsinghua.edu.cn/debian-security buster/updates main contrib non-free
deb-src https://mirrors.tuna.tsinghua.edu.cn/debian-security buster/updates main contrib non-free

/etc/apt/source.list.d/raspi.list

deb http://mirrors.tuna.tsinghua.edu.cn/raspberrypi/ buster main ui

我使用的是 nano 编辑器,对文本内容进行修改之后,想保存退出,需要按 ctrl + X 退出,然后编辑器会问,是否要保存,按 Y 选择 yes ,再让你确认保存的文件名,按回车键即可。

更改好源之后,输入

apt update

安装常用应用

apt install vim samba zsh docker.io -y


挂载硬盘

将硬盘通过 usb 连接到树莓派,在终端输入

lsblk

列出所有可用块设备的信息,例如我的显示

NAME        MAJ:MIN RM  SIZE RO TYPE MOUNTPOINT
sda           8:0    0 55.9G  0 disk 
├─sda1        8:1    0 53.9G  0 part 
├─sda2        8:2    0    1K  0 part 
└─sda5        8:5    0    2G  0 part 
mmcblk0     179:0    0 14.7G  0 disk 
├─mmcblk0p1 179:1    0  256M  0 part /boot/firmware
└─mmcblk0p2 179:2    0 14.5G  0 part /

我需要挂载 sda1 这个分区,想将它挂载到 /mnt/to 这个目录下,所以我先创建这个文件夹,再进行挂载

mkdir /mnt/to
mount /dev/sda1 /mnt/to

这种情况下,如果我们重启了机器,那么就得重新挂载硬盘,如果你并不频繁重启机器,这样或许还可以接受。若不是的话,可以了解一下自动挂载。

首先查看硬盘的 UUID ,可以使用 blkid 命令

# blkid     
/dev/mmcblk0p1: LABEL="system-boot" UUID="85F3-CC2B" TYPE="vfat" PARTUUID="da84cd12-01"
/dev/mmcblk0p2: LABEL="writable" UUID="b96d647f-679e-4582-87d0-2d8c7afc91f4" TYPE="ext4" PARTUUID="da84cd12-02"
/dev/sda1: UUID="041ff92b-0a5c-49f4-b965-0d3a55ef8284" TYPE="ext4" PARTUUID="0eff14f3-01"
/dev/sda5: UUID="b82db7cf-756f-4109-8800-9c0d9bb58810" TYPE="swap" PARTUUID="0eff14f3-05"
/dev/mmcblk0: PTUUID="da84cd12" PTTYPE="dos"

这里我想挂载的是 /dev/sda1 ,所以我复制它的 UUID 041ff92b-0a5c-49f4-b965-0d3a55ef8284 记住它的 type 是 ext4 ,你的有可能是其它的,例如 ntfs 之类。

编辑 /etc/fstab

nano /etc/fstab

在最下面添加一行

UUID=041ff92b-0a5c-49f4-b965-0d3a55ef8284 /mnt/to ext4 defaults     0 0

填好后,按 ctrl + o 保存,回车键确认,再按 ctrl + x 退出。

设置 smb 共享

此时我想通过 smb 的方式将硬盘中的内容共享出来,我需要先编辑 samba 的配置文件

vim /etc/samba/smb.conf

然后在最后添加这么几行

[to]
    path = /mnt/to
    browseable = yes 
    guest ok = yes

保存退出,然后重启 smbd

service smbd restart

此时在 资源管理器 的 网络 中,点击树莓派对应的设备名,应该就可以看到一个名字为 to 的共享文件夹。由于上面是设置 guest ok ,所以不用身份验证就可以直接打开。

但这样可能不是你想要的,毕竟任何人都可以直接访问,不安全。能否添加账号密码来验证呢?答案是可以的。

如果你装的是树莓派的 raspbian 或者 raspios ,默认就有一个 pi 用户,如果你安装的是 Ubuntu ,默认情况下就有一个 ubuntu 用户。那么现在就到 samba 里面添加这个同名用户。

smbpasswd -a pi

用 Ubuntu 的

smbpasswd -a ubuntu

之后会让你设置密码,需要设置两次。会如下面这样显示。

New SMB password:
Retype new SMB password:
Added user ubuntu.

然后我们可以再来修改 smb 配置文件。

vim /etc/samba/smb.conf

在最后面添加这么几行

[test]
    path = /mnt/to/test
    writable =yes
    valid users = ubuntu
    force create mode = 0644

保存退出,然后重启 smbd

service smbd restart

然后在网络中应该就可以看到名字为 test 的共享文件夹,直接双击打开的话,会要求你输入账号和密码。账号就是 pi 或者 ubuntu ,密码是你刚才自己设置的。

安装我家云导航

导航下载,在网盘中的【不仅限于盒子】、【贝壳云and我家云】文件夹中。我使用的是 2019 年的旧版导航,用新的应该也可以。

先进入 /opt 这个目录

cd /opt

想安装需要先把导航压缩包传进树莓派,达到这个目的的方法有很多。我使用的终端是 xshell ,我先在树莓派里安装一个 lrzsz

apt install lrzsz

安装完成后,使用 rz 命令,就可以把电脑里的文件,传输到树莓派里面了。

entware_navi.tgzinstall_navi.sh 这两个文件,传到 /opt 目录下,然后安装脚本执行权限,再执行安装

chmod +x install_navi.sh
./install_navi.sh

然后等一段时间……

完成后就可以在浏览器输入树莓派的 ip 来访问这个导航界面了。

实测 qb 启动不了,控制台那个是给我家云的 omv 用的,装在其它设备上本来就是没法用的。其它的功能好像都还可以用吧。

相关推荐

0722-6.2.0-如何在RedHat7.2使用rpm安装CDH(无CM)

文档编写目的在前面的文档中,介绍了在有CM和无CM两种情况下使用rpm方式安装CDH5.10.0,本文档将介绍如何在无CM的情况下使用rpm方式安装CDH6.2.0,与之前安装C5进行对比。环境介绍:...

ARM64 平台基于 openEuler + iSula 环境部署 Kubernetes

为什么要在arm64平台上部署Kubernetes,而且还是鲲鹏920的架构。说来话长。。。此处省略5000字。介绍下系统信息;o架构:鲲鹏920(Kunpeng920)oOS:ope...

生产环境starrocks 3.1存算一体集群部署

集群规划FE:节点主要负责元数据管理、客户端连接管理、查询计划和查询调度。>3节点。BE:节点负责数据存储和SQL执行。>3节点。CN:无存储功能能的BE。环境准备CPU检查JDK...

在CentOS上添加swap虚拟内存并设置优先级

现如今很多云服务器都会自己配置好虚拟内存,当然也有很多没有配置虚拟内存的,虚拟内存可以让我们的低配服务器使用更多的内存,可以减少很多硬件成本,比如我们运行很多服务的时候,内存常常会满,当配置了虚拟内存...

国产深度(deepin)操作系统优化指南

1.升级内核随着deepin版本的更新,会自动升级系统内核,但是我们依旧可以通过命令行手动升级内核,以获取更好的性能和更多的硬件支持。具体操作:-添加PPAs使用以下命令添加PPAs:```...

postgresql-15.4 多节点主从(读写分离)

1、下载软件[root@TX-CN-PostgreSQL01-252software]#wgethttps://ftp.postgresql.org/pub/source/v15.4/postg...

Docker 容器 Java 服务内存与 GC 优化实施方案

一、设置Docker容器内存限制(生产环境建议)1.查看宿主机可用内存bashfree-h#示例输出(假设宿主机剩余16GB可用内存)#Mem:64G...

虚拟内存设置、解决linux内存不够问题

虚拟内存设置(解决linux内存不够情况)背景介绍  Memory指机器物理内存,读写速度低于CPU一个量级,但是高于磁盘不止一个量级。所以,程序和数据如果在内存的话,会有非常快的读写速度。但是,内存...

Elasticsearch性能调优(5):服务器配置选择

在选择elasticsearch服务器时,要尽可能地选择与当前业务量相匹配的服务器。如果服务器配置太低,则意味着需要更多的节点来满足需求,一个集群的节点太多时会增加集群管理的成本。如果服务器配置太高,...

Es如何落地

一、配置准备节点类型CPU内存硬盘网络机器数操作系统data节点16C64G2000G本地SSD所有es同一可用区3(ecs)Centos7master节点2C8G200G云SSD所有es同一可用区...

针对Linux内存管理知识学习总结

现在的服务器大部分都是运行在Linux上面的,所以,作为一个程序员有必要简单地了解一下系统是如何运行的。对于内存部分需要知道:地址映射内存管理的方式缺页异常先来看一些基本的知识,在进程看来,内存分为内...

MySQL进阶之性能优化

概述MySQL的性能优化,包括了服务器硬件优化、操作系统的优化、MySQL数据库配置优化、数据库表设计的优化、SQL语句优化等5个方面的优化。在进行优化之前,需要先掌握性能分析的思路和方法,找出问题,...

Linux Cgroups(Control Groups)原理

LinuxCgroups(ControlGroups)是内核提供的资源分配、限制和监控机制,通过层级化进程分组实现资源的精细化控制。以下从核心原理、操作示例和版本演进三方面详细分析:一、核心原理与...

linux 常用性能优化参数及理解

1.优化内核相关参数配置文件/etc/sysctl.conf配置方法直接将参数添加进文件每条一行.sysctl-a可以查看默认配置sysctl-p执行并检测是否有错误例如设置错了参数:[roo...

如何在 Linux 中使用 Sysctl 命令?

sysctl是一个用于配置和查询Linux内核参数的命令行工具。它通过与/proc/sys虚拟文件系统交互,允许用户在运行时动态修改内核参数。这些参数控制着系统的各种行为,包括网络设置、文件...

取消回复欢迎 发表评论: