PyroCMSเป็น CMS โอเพ่นซอร์สที่เขียนด้วย PHP รหัสที่มา PyroCMS โฮสต์บนGitHub ในคู่มือนี้เราจะนำเสนอกระบวนการติดตั้ง PyroCMS ทั้งหมดบนอินสแตนซ์ของ FreeBSD 11 Vultr สแต็คซอฟต์แวร์ที่เราจะใช้คือ: PHP, Nginx, MariaDB และ Composer
ความต้องการ
ก่อนที่คุณจะสามารถติดตั้ง PyroCMS บนเซิร์ฟเวอร์มีข้อกำหนดบางประการที่ต้องปฏิบัติตาม
- VPS ที่มี RAM อย่างน้อย 1GB
- PyroCMS รองรับ Apache หรือ Nginx อย่างไรก็ตามเราจะใช้ LEMP stack
- PHP เวอร์ชัน 7.0 หรือสูงกว่า
- ส่วนขยาย PHP ต่อไปนี้:
PDO
cURL
SQLite
OpenSSL
Mbstring
Fileinfo
Tokenizer
- GD Library, (เวอร์ชั่น 2.0 หรือสูงกว่า); หรือ Imagick (รุ่น 6.5.7 หรือสูงกว่า)
ก่อนที่จะเริ่ม
ตรวจสอบเวอร์ชั่น FreeBSD
uname -ro
# FreeBSD 11.2-RELEASE
ตรวจสอบให้แน่ใจว่าระบบ FreeBSD ของคุณทันสมัย
freebsd-update fetch install
pkg update && pkg upgrade -y
ติดตั้งsudo
, vim
, unzip
, wget
และbash
แพคเกจที่ว่าพวกเขาจะไม่ได้อยู่ในระบบของคุณ
pkg install -y sudo vim unzip wget bash
johndoe
สร้างบัญชีผู้ใช้ใหม่ด้วยชื่อผู้ใช้ที่คุณต้องการเราจะใช้
adduser
# Username: johndoe
# Full name: John Doe
# Uid (Leave empty for default): <Enter>
# Login group [johndoe]: <Enter>
# Login group is johndoe. Invite johndoe into other groups? []: wheel
# Login class [default]: <Enter>
# Shell (sh csh tcsh nologin) [sh]: bash
# Home directory [/home/johndoe]: <Enter>
# Home directory permissions (Leave empty for default): <Enter>
# Use password-based authentication? [yes]: <Enter>
# Use an empty password? (yes/no) [no]: <Enter>
# Use a random password? (yes/no) [no]: <Enter>
# Enter password: your_secure_password
# Enter password again: your_secure_password
# Lock out the account after creation? [no]: <Enter>
# OK? (yes/no): yes
# Add another user? (yes/no): no
# Goodbye!
รันvisudo
คำสั่งและยกเลิกหมายเหตุ%wheel ALL=(ALL) ALL
บรรทัดเพื่ออนุญาตให้สมาชิกของwheel
กลุ่มเรียกใช้งานคำสั่งใด ๆ
# Uncomment by removing the hash (#) sign
%wheel ALL=(ALL) ALL
ตอนนี้เปลี่ยนเป็นผู้ใช้ที่คุณสร้างขึ้นใหม่
su - johndoe
หมายเหตุ: แทนที่johndoe
ด้วยชื่อผู้ใช้ของคุณ
ตั้งค่าเขตเวลา
sudo tzsetup
ติดตั้ง PHP
ติดตั้ง PHP รวมถึงส่วนขยาย PHP ที่จำเป็น
sudo pkg install -y php72 php72-pdo php72-curl php72-sqlite3 php72-openssl php72-mbstring php72-fileinfo php72-tokenizer php72-gd php72-pecl-imagick php72-phar php72-zlib php72-json php72-mbstring php72-xml php72-zip php72-ctype php72-dom php72-simplexml php72-hash php72-filter php72-session php72-pdo_sqlite php72-iconv php72-intl php72-pcntl php72-soap php72-posix php72-mysqli php72-pdo_mysql
ตรวจสอบเวอร์ชั่น
php --version
# PHP 7.2.10 (cli) (built: Oct 2 2018 01:30:18) ( NTS )
# Copyright (c) 1997-2018 The PHP Group
# Zend Engine v3.2.0, Copyright (c) 1998-2018 Zend Technologies
# with Zend OPcache v7.2.10, Copyright (c) 1999-2018, by Zend Technologies
ซอฟท์เชื่อมโยงไปยังphp.ini-production
php.ini
sudo ln -s /usr/local/etc/php.ini-production /usr/local/etc/php.ini
เปิดใช้งานและเริ่ม PHP-FPM
sudo sysrc php_fpm_enable=yes
sudo service php-fpm start
ติดตั้ง MariaDB
ดาวน์โหลดและติดตั้ง MariaDB
sudo pkg install -y mariadb102-client mariadb102-server
ตรวจสอบเวอร์ชั่น
mysql --version
# mysql Ver 15.1 Distrib 10.2.17-MariaDB, for FreeBSD11.2 (amd64) using readline 5.1
เปิดใช้งานและเริ่ม MariaDB
sudo sysrc mysql_enable="yes"
sudo service mysql-server start
รันmysql_secure_installation
สคริปต์เพื่อปรับปรุงความปลอดภัยของการติดตั้งของคุณ
sudo mysql_secure_installation
ล็อกอินเข้าสู่ MariaDB ในฐานะผู้ใช้รูท
sudo mysql -u root -p
# Enter password:
สร้างฐานข้อมูลและผู้ใช้ใหม่และจดจำข้อมูลรับรอง
CREATE DATABASE dbname;
GRANT ALL ON dbname.* TO 'username' IDENTIFIED BY 'password';
FLUSH PRIVILEGES;
ออกจาก MariaDB
exit
ติดตั้ง Nginx
ติดตั้ง Nginx
sudo pkg install -y nginx
ตรวจสอบเวอร์ชั่น
nginx -v
# nginx version: nginx/1.14.0
เปิดใช้งานและเริ่ม Nginx
sudo sysrc nginx_enable=yes
sudo service nginx start
เรียกใช้sudo vim /usr/local/etc/nginx/pyro.conf
และกำหนดค่า Nginx สำหรับ Pyro CMS
server {
listen 80;
server_name example.com; # Check this
root /usr/local/www/pyro/public; # Check this
index index.php index.html;
charset utf-8;
location / {
try_files $uri $uri/ /index.php?$args;
}
location ~ \.php$ {
fastcgi_pass 127.0.0.1:9000; # Run sockstat -4 -6 | grep php-fpm
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}
บันทึกไฟล์และออก
ตอนนี้เราต้องรวมpyro.conf
ไว้ในnginx.conf
ไฟล์หลัก
เรียกใช้sudo vim /usr/local/etc/nginx/nginx.conf
และเพิ่มบรรทัดต่อไปนี้เพื่อhttp {}
บล็อก
include pyro.conf;
ทดสอบการกำหนดค่า Nginx
sudo nginx -t
โหลดซ้ำ Nginx
sudo service nginx reload
ติดตั้งนักแต่งเพลง
ติดตั้งนักแต่งเพลงทั่วโลก
php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
php -r "if (hash_file('sha384', 'composer-setup.php') === '48e3236262b34d30969dca3c37281b3b4bbe3221bda826ac6a9a62d6444cdb0dcd0615698a5cbe587c3f0fe57a54d8f5') { echo 'Installer verified'; } else { echo 'Installer corrupt'; unlink('composer-setup.php'); } echo PHP_EOL;"
php composer-setup.php
php -r "unlink('composer-setup.php');"
sudo mv composer.phar /usr/local/bin/composer
ตรวจสอบเวอร์ชั่น
composer --version
# Composer version 1.7.2 2018-08-16 16:57:12
ติดตั้ง PyroCMS ผ่านผู้เรียบเรียง
สร้างไดเรกทอรีรากของเอกสาร
sudo mkdir -p /usr/local/www/pyro
เปลี่ยนความเป็นเจ้าของของไดเรกทอรีไป/usr/local/www/pyro
johndoe
sudo chown -R johndoe:johndoe /usr/local/www/pyro
นำทางไปยังไดเร็กทอรี root ของเอกสาร
cd /usr/local/www/pyro
การใช้composer
ดาวน์โหลดและติดตั้ง PyroCMS
composer create-project pyrocms/pyrocms .
หมายเหตุ: คุณอาจมีหน่วยความจำไม่เพียงพอเมื่อติดตั้ง Pyro ผ่าน Composer อาจเป็นการดีที่จะหยุด Nginx, PHP-FPM และ MariaDB เพื่อบันทึกการใช้หน่วยความจำและเริ่มต้นอีกครั้งหลังจากขั้นตอนนี้ หากไม่ได้ช่วยให้คุณหลีกเลี่ยงข้อผิดพลาดกับนักแต่งเพลงแล้วคุณจะต้องเพิ่มปริมาณที่เพียงพอของพื้นที่ Swap
เปลี่ยนความเป็นเจ้าของของไดเรกทอรีไป/usr/local/www/pyro
www
sudo chown -R www:www /usr/local/www/pyro
ใช้เว็บเบราว์เซอร์ที่คุณต้องการเปิดไซต์ของคุณและติดตามโปรแกรมติดตั้ง PyroCMS หลังจากติดตามตัวติดตั้งคุณจะได้ PyroCMS และทำงาน ในการเข้าถึงพื้นที่ผู้ดูแลระบบ PyroCMS เพียงต่อท้าย/admin
URL เว็บไซต์ของคุณ