2025 ผู้เขียน: John Day | [email protected]. แก้ไขล่าสุด: 2025-01-13 06:58
สร้างเซิร์ฟเวอร์คลาวด์ที่เชื่อถือได้ของคุณเอง
ขั้นตอนที่ 1: ฮาร์ดแวร์
- ใช้กล่องโลหะแล้วทาสีด้วยสีที่คุณชื่นชอบ (ฉันใช้ตัวควบคุมการจัดเก็บข้อมูลแบบเก่า)
- จานสีงานอดิเรกที่ทนต่ออย่างน้อย 75 C
- ราสเบอร์รี่ pi 3
- การ์ด Micro SD (ฉันใช้ 16GB แต่คุณสามารถใช้ขนาดใดก็ได้ >= 4GB)
- ฮับ USB พร้อมแจ็คไฟภายนอก
- อะแดปเตอร์ USB เป็น sata
- ดิสก์ไดรฟ์
- สายเคเบิลเครือข่าย + เต้ารับเครือข่ายที่ผนัง
- สายไฟ + แจ็คเสียบไฟ
- กู้คืนสลักเกลียวจากพอร์ตอนุกรมหรือ vga ของคอมพิวเตอร์เครื่องเก่า
- พอร์ต USB กู้คืนจากคอมพิวเตอร์เครื่องเก่า
Raspberry pi ติดอยู่กับแผ่นงานอดิเรกสีด้วยสลักเกลียวจากพอร์ต vga
ดิสก์ถูกยึดด้วยสลักเกลียวปกติที่ด้านหลัง
ขั้นตอนที่ 2: การเดินสายไฟ
แจ็คอินพุตไฟเชื่อมต่อกับพอร์ต usb ที่กู้คืนทั้งสองพอร์ต
ใช้ USB ตัวแรก (หลังสายทั้งหมดที่ด้านหน้าซ้าย) เป็นแหล่งพลังงาน ใช้เฉพาะสายสีแดงและสีดำและเชื่อมต่อกับแจ็คอินพุตไฟ สาย USB สายแรกในพอร์ตนี้จ่ายไฟให้กับ pi ส่วนสาย USB สายที่สองจะให้พลังงานแก่ฮับ USB
usb ตัวที่สอง (อันที่ด้านหลัง - มีประโยชน์สำหรับการเชื่อมต่ออุปกรณ์เพิ่มเติม) มีสีแดงและสีดำเชื่อมต่อโดยตรงกับอินพุตพลังงาน ในขณะที่สีขาวและสีเขียวของแต่ละพอร์ตเชื่อมต่อกับสาย usb ที่กู้คืนจากเมาส์เก่าบางตัว (สีขาวโดยตรง) เชื่อมต่อกับ pi)
สาย Lan เชื่อมต่อเต้ารับเครือข่ายภายนอกเข้ากับพอร์ต Raspberry pi LAN
ดิสก์เชื่อมต่อผ่านอะแดปเตอร์ usb กับ sata ไปยังฮับ USB ที่ใช้พลังงานจากภายนอก (ดิสก์ที่มีความจุมากขึ้นต้องการพลังงานมากกว่า และเราไม่ต้องการทำให้ pi ไม่เสถียร) ซึ่งเชื่อมต่ออยู่ในพอร์ต pi อันใดอันหนึ่ง
ขั้นตอนที่ 3: ซอฟต์แวร์
ติดตั้งระบบปฏิบัติการ
ใช้ Centos 7 สำหรับแขนเพื่อความปลอดภัยที่สูงขึ้น (https://mirror.centos.org/altarch/7/isos/armhfp/); ทดสอบแล้ว: CentOS-Userland-7-armv7hl-Minimal-1611-RaspberryPi3.img.xz บทช่วยสอนที่นี่:
วางรูปภาพบนการ์ด micro sd จากคอมพิวเตอร์ Linux ของคุณ (สำหรับ windows ตรวจสอบ:
xzcat CentOS-Userland-7-armv7hl-Minimal-1611-RaspberryPi3.img.xz | sudo dd of=$/path/to/sd/card status=progress bs=4M
รหัสผ่านรูท: centos
ใช้ nmtui เพื่อกำหนดค่าเครือข่ายและตั้งค่าที่อยู่ IP แบบคงที่
ตั้งค่าดิสก์
สร้างหนึ่งพาร์ติชั่นในแต่ละดิสก์ (ดีกว่าที่จะเล็กกว่าดิสก์ทั้งหมดเล็กน้อย - สมมติว่าเล็กกว่า 1GB - ดิสก์ที่แตกต่างกันที่มีความจุเท่ากัน - เช่น: wd vs toshiba - มีขนาดต่างกัน:)) วิธีนี้คุณจะปลอดภัยหากคุณต้องการเปลี่ยนดิสก์ตัวใดตัวหนึ่ง
สร้างระบบไฟล์ btrfs raid 1 บนดิสก์ของคุณ
mkfs.btrfs -d raid1 -m raid1 /dev/sda1 /dev/sdb1
ป้ายกำกับระบบไฟล์ btrfs /dev/sda1 rpi3
เมานต์ระบบไฟล์โดยใช้ autofs (ป้องกันการบูท pi ไม่ได้หากมีสิ่งผิดปกติกับดิสก์)
yum ติดตั้ง -y autofs
ต่อท้าย fllowing ไปที่ /etc/auto.master:
/- /etc/auto.ext-usb --timeout=300
สร้าง /etc/auto.ext-usb ด้วยเนื้อหา:
/srv -fstype=auto, compress=lzo, noatime:/dev/disk/by-label/rpi3
บริการ autofs เริ่มต้นใหม่
ls /srv, df -h ยืนยันว่าติดตั้งแล้ว
ติดตั้ง owncloud
ข้อกำหนดเบื้องต้น (apache, php, mariadb):
yum ติดตั้ง -y httpd;yum ติดตั้ง -y mod_ssl; yum ติดตั้ง -y เซิร์ฟเวอร์ mariadb; yum ติดตั้ง -y php*
ติดตั้ง owncloud 9 ซึ่งเข้ากันได้กับ php54 ที่มาพร้อมกับ centos7 ซึ่งเป็นบทช่วยสอนที่ดีสำหรับสิ่งนั้น:
download.owncloud.org/download/repositories…
หลังจาก owncloud เปิดใช้งานแล้ว ให้ย้าย data dir จากตำแหน่งเริ่มต้นไปยังไดรฟ์ใหม่ (/srv)
บริการ httpd หยุด
แก้ไข /var/www/html/owncloud/config/config.php และทำการเปลี่ยนแปลงนี้:
'datadirectory' => '/srv/owncloud/data', mkdir /srv/owncloud; mv /var/www/html/owncloud/data /srv/owncloud && chown -R apache:apache /srv/owncloud/data/
บริการ httpd เริ่ม
คุณสามารถติดตั้งไคลเอนต์เดสก์ท็อป owncloud บน linux / windows และสำหรับโทรศัพท์ ฉันใช้ foldersync
-
เปิดใช้งานและกำหนดค่า SELinux
(เวอร์ชันที่ใช้งานได้คือ: selinux-policy-3.13.1-166.el7.5.noarch, selinux-policy-targeted-3.13.1-166.el7.5.noarch)
ตรวจสอบให้แน่ใจว่าคุณไม่ได้อัปเดตนโยบายนั้น (ใน /etc/yum.conf ผนวก: แยก = selinux-policy*)
คืนค่าคอน -Rv /
/boot/cmdline.txt ควรมี: selinux=1 security=selinux enforcecing=1
/etc/sysconfig/selinux ควรมี: SELINUX=enforcecing และ SELINUXTYPE=targeted
รีบูต
ทำการตั้งค่าต่อไปนี้หลังจากรีบูต:
yum ติดตั้ง -y policycoreutils-python
semange fcontext -a -t httpd_sys_rw_content_t /srv/owncloud(/.*)?
setsebool -P httpd_builtin_scripting=1; setsebool -P httpd_can_network_connect=1; setsebool -P httpd_enable_cgi=1; setsebool -P
หากคุณพบปัญหาใด ๆ ให้ใส่การ์ด sd ลงในคอมพิวเตอร์เครื่องอื่นและแก้ไข cmdline.txt ให้มี: selinux=0
รักษาความปลอดภัยกล่องของคุณ
เปลี่ยนรหัสผ่านรูท
สร้างผู้ใช้ของคุณเอง (adduser -s /bin/bash "me") และตั้งรหัสผ่านที่คาดเดายาก (passwd "me")
กำหนดค่า sshd ให้ฟังบนพอร์ตอื่นและไม่อนุญาตให้รูทล็อกอิน
ใน /etc/ssh/sshd_config ให้ตั้งค่า Port
(สมมติว่า 2222), PermitRootLogin no
บอก SELinux และ firewalld เกี่ยวกับความตั้งใจของคุณ:
จัดการพอร์ต -a -t ssh_port_t -p tcp 2222
บริการ firewalld เริ่ม && systemctl เปิดใช้งาน firewalld.service
firewall-cmd --permanent --add-port 2222/tcp
firewall-cmd --reload
บริการ sshd รีสตาร์ท
ตั้งเป็นสาธารณะ
บนเราเตอร์อินเทอร์เน็ตของคุณส่งต่อพอร์ตนี้ไปยัง ip แบบคงที่ของคุณที่ตั้งไว้ในขั้นตอนแรก: 80, 443, 2222
ตั้งค่า DDNS บนเราเตอร์ของคุณ เพื่อให้คุณสามารถเข้าถึงกล่องของคุณได้จากทุกที่
ปรับจูน
ตั้งค่า apache เป็น 5 procs เนื่องจากหน่วยความจำเหลือน้อย:
/etc/httpd/conf.modules.d/00-mpm.conf
LoadModule mpm_prefork_module modules/mod_mpm_prefork.so
StartServers 5
MinSpareServers 5
MaxSpareServers 5
ขีดจำกัดเซิร์ฟเวอร์ 5
MaxClients5
MaxRequestsPerChild 3000
บริการ httpd เริ่มใหม่
ตั้งค่า cron เพื่อขัดดิสก์ทุกสัปดาห์และสร้างสแน็ปช็อตในแต่ละคืน (ใน /etc/crontab)
01 02 * * 6 รูท btrfs สครับเริ่มต้น /srv01 01 * * * root /usr/sbin/btrfs subvolume snapshot -r /srv /srv/@$(printf "\%s" $(/bin/date +\%d \%b\%Y-\%k-\%M))
ตรวจสอบระดับเสียงเป็นครั้งคราวด้วย: btrfs dev stats /srv
ใช้สุนัขเฝ้าบ้านเพื่อรีเซ็ตโดยอัตโนมัติหากไม่ตอบสนอง (ราสเบอร์รี่ pi3 มีฮาร์ดแวร์):
yum ติดตั้ง -y watchdog
/etc/watchdog.conf
อุปกรณ์เฝ้าระวัง = /dev/watchdogwatchdog-timeout = 15
ช่วงเวลา = 1logtick = 1 log-dir = /var/log/watchdog
เรียลไทม์ = yespriority = 1
บริการ watchdog start && systemctl เปิดใช้งาน watchdog.service