vts163 / funNetworkPrivateCloud

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

funNetworkPrivateCloud

Copyright@Yan Zeng, 旋律果子

E-mail: zengyan16@mails.ucas.edu.cn

QQ Group(付费群): https://www.lingxun.tech/join.html

Telegram Group(免费): https://t.me/melodyNetworkTech

武汉凌讯网络科技有限公司: https://www.lingxun.tech

Bilibili(旋律果子): https://space.bilibili.com/626863

Youtube(旋律果子):https://www.youtube.com/channel/UC7yQPFk1rCiaZDmXXqLwMhw

【好玩的网络-私有云篇】第01期

本系列视频的目的是教你搭建一个简单易用的NAS和软路由一体机,并且科普相关的原理。

视频介绍请访问下面的链接【私有云01】

Youtube:https://youtu.be/Ishw17sEQtc

Bilibili:https://www.bilibili.com/video/BV1Gp4y1W7RG

功能实现(非虚拟化/非黑群/非Openwrt/使用完全开源免费的企业级系统搭建NAS和软路由的所有应用!):

NAS的基本功能:文件/影音资源共享/备份/远程下载 等等···

软路由的基本功能:包含几乎消费级路由器所有功能/科学/远程隧道/动态路由协议 等等···

如何来管理:可以使用Siri语音助手管理,Iphone快捷键,命令行,web监视器 等等···

【好玩的网络-私有云篇】第02期

具体的教程请看视频教程,本文档仅仅只做一些补充以及一些命令的讲解。

Centos的官方网站为:https://www.centos.org

MacOS

diskutil list # 显示所有磁盘
diskutil unmount /Volumes/NO\ NAME # 将自动挂载测磁盘先卸载掉
# 将iso镜像烧录到U盘里
dd if=/Users/YanZENG/nfs/disk-d2550/CentOS-8.3.2011-x86_64-dvd1.iso of=/dev/disk3 bs=4m

# 小技巧,在MacOS中,在输出的磁盘前面加r可以提升读写速度,例如:
dd if=/Users/YanZENG/nfs/disk-d2550/CentOS-8.3.2011-x86_64-dvd1.iso of=/dev/rdisk3 bs=4m
# 可以结合pv命令来显示刷写的进度,这个自己去查一下。在刷写的过程中,也可以打开系统
# 自带的监视器来显示拷贝的速度。

Linux

fdisk -l # 显示所有磁盘,根据磁盘的大小判断哪一个是要制作的安装盘
# Linux系统一般不会自动挂载U盘,如果被自动挂载,可以用下面的命令卸载U盘。
umount /dev/sdb1  #后面要卸载的磁盘根据实际情况填写
# 将iso镜像烧录到U盘里,这里注意和MacOS系统的区别,bs这里的M是大写
dd if=./CentOS-8.3.2011-x86_64-dvd1.iso of=/dev/sdb bs=4M

# 小技巧,在linux中,加入status的参数可以显示写盘进度,用法如下:
dd if=./CentOS-8.3.2011-x86_64-dvd1.iso of=/dev/sdb bs=4M status=progress

Windows

# 随便找一个U盘烧录工具烧录即可。(自己找吧,我帮不了忙,纯净版的太难找了)
# @Potter 提供思路,可以用rufus
# https://rufus.ie

# @本直播间黑粉头子 提供思路,可以使用ventoy
# https://www.ventoy.net/cn/index.html

# redhat 官方推荐 Fedora Media Writer

安装系统之后,需要用到的命令

nmcli # 查看网络状态
nmcli con show # 查看网络连接(主要查看连接名称)
nmcli con up enp1s0 # 启动网络连接(后面接连接名称)
nmcli # 查看网络状态
ping baidu.com # 测试到百度是否连通
nmcli con modify enp1s0 autoconnect yes # 设置某个连接自动连接(插上网线)
exit # 退出终端
# 启动web图形界面
systemctl enable --now cockpit.socket
# (启动完成后浏览器访问 IP地址:9090)
yum -y update  # 更新系统(硬盘直接插到d2550上,首次启动之后更新和设置网络)
reboot # 重启系统

远程登录

ssh root@192.168.4.106

基于CentOS 8的适用于64位树莓派的服务器镜像:https://raspberrypi.club/366.html

设置SSH开机启动

systemctl enable sshd

【好玩的网络-私有云篇】第03期

设置防火墙

# 设置防火墙主要是为了方便以后的演示。防火墙默认的zone是public,只开放了22号端口等少量端口。
# 设置zone为trusted,则开放所有的端口,局域网内的设备都能进行访问。
# 安全警告:小白在我没讲网络安全之前,请不要将设备直接暴露在公网中!
firewall-cmd --set-default-zone=trusted # 设置默认区域为trusted区域,开放所有的端口。

设置selinux

# selinux是centos8上的一个安全软件,默认是打开的。为了避免以后的麻烦,现在将它关闭。
setenforce 0 # 临时关闭selinux
# 永久关闭selinux
sed -i "s#SELINUX=enforcing#SELINUX=disabled#g" /etc/selinux/config

设置分享目录以及安装软件

cd /media  # change dictionary, 改变路径,也就是就是进入这个文件夹
ll # 显示当前目录中的所有文件以及文件夹
mkdir public # 在当前目录下创建public目录,相当于建立了public的文件夹

yum -y install nfs-utils # 安装nfs协议软件

配置分享目录以及启动软件

# 将/media/public 目录通过nfs协议分享出去
echo "/media/public 192.168.0.0/16(rw,root_squash,async,insecure) 172.16.0.0/12(rw,root_squash,async,insecure) 10.0.0.0/8(rw,root_squash,async,insecure)" >> /etc/exports

systemctl start nfs-server.service # 启动NFS服务
systemctl enable nfs-server.service # 设置NFS服务开机自行启动

showmount -e localhost # 在本机查看已经成功分享的目录
showmount -e 192.168.4.20 # 在其他机器上查看服务器192.168.4.20上的NFS分享

# 挂载NFS到本地(MacOS和Linux用户)
mount -t nfs 192.168.4.20:/media/public ./nfs-fun # 这条命令在客户机运行,不是在服务器中运行。

# win挂载的方法是映射磁盘驱动器,具体方法自己查一下或者等大佬来补充吧,win对nfs的UTF-8编码支持不是很好)

挂载新磁盘以及格式化并重新分享

fdisk -l # 显示所有磁盘
fdisk /dev/sda  # 给硬盘分区
mkfs.xfs /dev/sda1 # 将分区格式化为xfs格式
cd /media
mkdir disk # 创建新文件夹
mount /dev/sda1 /media/disk  # 将磁盘分区挂载到disk目录下
vim /etc/exports # 修改NFS配置文件
systemctl restart nfs-server.service # 重新启动NFS服务,主要是为了更新配置文件
showmount -e localhost # 查看是否分享成功
chmod 777 -R /media/disk # 修改权限,任何人都可以读,写硬盘

【好玩的网络-私有云篇】第04期

登录服务器

ssh root@192.168.4.20 # 登录服务器

安装samba

yum -y install samba samba-common samba-common-tools samba-common-libs samba-test

配置samba

# 配置文件位置 /etc/samba/smb.conf
# 写入配置文件
cat > /etc/samba/smb.conf << EOF
# See smb.conf.example for a more detailed config file or
# read the smb.conf manpage.
# Run 'testparm' to verify the config is correct after
# you modified it.

[global]
	# 网络权限
    hosts allow = 127.0.0.1 192.168.0.0/16 172.16.0.0/12 10.0.0.0/8
	# 匿名访问支持
    map to guest = Bad User
[smb-public]
	# 匿名访问权限 yes
    guest ok = yes 
	# 要分享的目录
    path = /media/public
	# 读写权限(可读可写)
    read only = no
EOF


systemctl start smb # 启动smb服务
systemctl enable smb # 设置smb开机启动

vim /etc/samba/smb.conf # 编辑smb配置文件
# 测试smb配置文件是否有语法错误
testparm
systemctl restart smb # 重新启动smb服务

windows系统访问 smb

# 步骤1. 打开“文件资源管理器”
# 步骤2. 点击左上角“计算机”
# 步骤3. 点击“映射网络驱动器”
# 步骤4. 在文件夹中输入 “\\192.168.4.20\smb-public”
# 步骤5. 点击完成
# 步骤6. 在“计算机”中就可以看到smb分享的文件夹了

开机挂载磁盘

# UUID=36b3df0c-9ff3-471c-919a-6e7301ab5736 /media/disk                   xfs    defaults,noatime        0 0

fdisk -l
blkid /dev/sda1
vim /etc/fstab

About

License:Apache License 2.0