| Both sides previous revisionPrevious revisionNext revision | Previous revision |
| servers:bsd:nginx:wordpress [2025/08/28 00:28] – [PHP-FPM Socket] Sean Rhone | servers:bsd:nginx:wordpress [2025/10/31 02:11] (current) – Sean Rhone |
|---|
| ===== Prerequisites ===== | ===== Prerequisites ===== |
| |
| * [[bsd:server:freebsd_14.3|FreeBSD 14.3]] | * [[bsd:server:freebsd_15.0|FreeBSD 15.0]] |
| * [[servers:bsd:nginx_php_php-fpm|nginx + PHP + PHP-FPM]] | * [[servers:bsd:freenginx_php_php-fpm|freenginx + PHP + PHP-FPM]] |
| * [[servers:bsd:nginx:lets_encrypt|Let's Encrypt]] | * [[servers:bsd:nginx:lets_encrypt|Let's Encrypt]] |
| * [[servers:bsd:mariadb|MariaDB]] | * [[servers:bsd:mariadb|MariaDB]] |
| su - | su - |
| |
| pkg install git-lite php84-mysqli php84-intl php84-mbstring php84-xml | pkg install git-lite php85-mysqli php85-intl php85-mbstring php85-xml |
| |
| ====== Download Source ====== | ====== Download Source ====== |
| ====== Database ====== | ====== Database ====== |
| |
| mariadb -u 'root' -p | su - |
| | |
| | mariadb |
| |
| CREATE DATABASE wordpress; | CREATE DATABASE wordpress; |
| GRANT ALL PRIVILEGES ON wordpress.* to wordpress@localhost; | GRANT ALL PRIVILEGES ON wordpress.* to wordpress@localhost; |
| |
| FLUSH PRIVILEGES; | FLUSH PRIVILEGES;EXIT; |
| | |
| EXIT | |
| |
| ====== nginx + PHP-FPM Configuration ====== | ====== nginx + PHP-FPM Configuration ====== |
| ; General | ; General |
| php_value[date.timezone] = "America/New_York" | php_value[date.timezone] = "America/New_York" |
| | |
| | ; Errors |
| | php_value[error_reporting] = "~E_ALL" |
| | php_value[display_errors] = "Off" |
| |
| ; End</code> | ; End</code> |
| su - | su - |
| |
| ee '/usr/local/etc/nginx/default.d/blog.conf' | ee '/usr/local/etc/freenginx/default.d/blog.conf' |
| |
| <code> | <code> |
| su - | su - |
| |
| ee '/usr/local/etc/nginx/vhosts.d/blog.conf' && service 'nginx' reload && sync | ee '/usr/local/etc/freenginx/vhosts.d/blog.conf' && service 'nginx' reload |
| |
| <code> | <code> |
| server { | server { |
| listen 443 ssl; | listen 443 ssl; |
| # http2 on; | http2 on; |
| server_name 'blog.realmofespionage.xyz'; | server_name 'blog.realmofespionage.xyz'; |
| root '/usr/local/www/blog'; | root '/usr/local/www/blog'; |
| index 'index.php'; | index 'index.php'; |
| |
| include '/usr/local/etc/nginx/default.d/blog.conf'; | include '/usr/local/etc/freenginx/default.d/blog.conf'; |
| include '/usr/local/etc/nginx/default.d/headers.conf'; | include '/usr/local/etc/freenginx/default.d/headers.conf'; |
| |
| client_max_body_size '10M'; | client_max_body_size '10M'; |
| |
| # add_header Content-Security-Policy "default-src 'self'; script-src 'self' 'unsafe-inline' 'unsafe-eval'; style-src 'self' 'unsafe-inline'; font-src 'self' data:; img-src 'self' data: s.w.org" always; | |
| |
| # access_log /var/log/nginx/blog-access.log; | # access_log /var/log/nginx/blog-access.log; |
| |
| * https://blog.realmofespionage.xyz | * https://blog.realmofespionage.xyz |
| | * Database Host: ''127.0.0.1'' |
| |
| ====== Settings ====== | ====== Settings ====== |
| * Date Format: Y/m/d | * Date Format: Y/m/d |
| |
| ===== DB Connection Fix ===== | ===== wp-config.php ===== |
| |
| * https://forums.freebsd.org/threads/wordpress-cant-connect-to-mysql-database.71914/#post-436461 | * :!: WordPress set-up needs to generate this file first ((put settings in the ''custom values'' section towards the bottom)) |
| * ''DB_HOST'' to ''127.0.0.1'' | * Doesn't need ''^M'' |
| |
| su - | su - |
| |
| ee '/usr/local/www/blog/wp-config.php' | su -m 'www' -c "ee '/usr/local/www/blog/wp-config.php'" |
| |
| <code>define( 'DB_HOST', 'localhost' );^M</code> | <code> |
| | define( 'AUTOMATIC_UPDATER_DISABLED', true ); |
| |
| <code>define( 'DB_HOST', '127.0.0.1' );^M</code> | define( 'WP_DEBUG', false ); |
| | define( 'WP_DEBUG_DISPLAY', false ); |
| |
| ====== Temp Commands ====== | /* End */</code> |
| |
| ===== Update ===== | ====== Scripts ====== |
| |
| * https://github.com/WordPress/WordPress/commits/master/ | ===== Updater ===== |
| |
| su - | mkdir -p ~/'.local/scripts/www/blog' && ee ~/'.local/scripts/www/blog/updater.sh' && chmod +x ~/'.local/scripts/www/blog/updater.sh' |
| |
| su -m 'www' -c "'/usr/local/bin/git' -C '/usr/local/www/blog' pull origin 'master'" | <code> |
| | #!/bin/sh |
| | |
| | su -m 'www' -c "git -C '/usr/local/www/blog' reset --hard 'origin/master'" |
| | su -m 'www' -c "git -C '/usr/local/www/blog' pull 'origin' 'master' --rebase" |
| | |
| | # End</code> |
| | |
| | ~/'.local/scripts/www/blog/updater.sh' |
| | |
| | su 'root' -c ~/'.local/scripts/www/blog/updater.sh' |
| |
| ===== Maintenance ===== | ===== Maintenance ===== |
| |
| su - | mkdir -p ~/'.local/scripts/www/blog' && ee ~/'.local/scripts/www/blog/maintenance.sh' && chmod +x ~/'.local/scripts/www/blog/maintenance.sh' |
| |
| su -m 'www' -c "'/usr/local/bin/git' -C '/usr/local/www/blog' reset --hard" | <code> |
| | #!/bin/sh |
| |
| su -m 'www' -c "'/usr/local/bin/git' -C '/usr/local/www/blog' pull origin 'master' --rebase" | su -m 'www' -c "'/usr/local/bin/git' -C '/usr/local/www/blog' gc --aggressive --prune='all'" |
| | su -m 'www' -c "'/usr/local/bin/git' -C '/usr/local/www/blog' fsck --full --strict" |
| |
| su -m 'www' -c "'/usr/local/bin/git' -C '/usr/local/www/blog' gc --aggressive --prune='all'" | '/usr/local/bin/mariadb-check' -o -f -e --auto-repair 'wordpress' |
| |
| su -m 'www' -c "'/usr/local/bin/git' -C '/usr/local/www/blog' fsck --full --strict" | # End</code> |
| |
| mariadb-check -u 'root' -p -o -f -e --auto-repair 'wordpress' | ~/'.local/scripts/www/blog/maintenance.sh' |
| | |
| | su 'root' -c ~/'.local/scripts/www/blog/maintenance.sh' |
| | |
| | ===== Git Fix ===== |
| | |
| | * :!: Set email for ''user.email'' |
| | * :!: [[#initial_setup|Initial set-up]] needs re-completed for database connection ((re-use existing details)) |
| | |
| | mkdir -p ~/'.local/scripts/www/blog' && ee ~/'.local/scripts/www/blog/git-fix.sh' && chmod +x ~/'.local/scripts/www/blog/git-fix.sh' |
| | |
| | <code> |
| | #!/bin/sh |
| | |
| | su -m 'www' -c "rm -Rf '/usr/local/www/blog/.git'" |
| | su -m 'www' -c "git -C '/usr/local/www/blog' init --initial-branch='master'" |
| | su -m 'www' -c "git -C '/usr/local/www/blog' add '.'" |
| | |
| | ################################################## |
| | su -m 'www' -c "git -C '/usr/local/www/blog' config 'user.email' 'espionage724@x'" |
| | ################################################## |
| | |
| | su -m 'www' -c "git -C '/usr/local/www/blog' commit --message='x'" |
| | |
| | su -m 'www' -c "git -C '/usr/local/www/blog' remote add 'origin' 'https://github.com/WordPress/WordPress.git'" |
| | su -m 'www' -c "git -C '/usr/local/www/blog' pull --depth '1' --recurse-submodules 'origin' 'master' --rebase" |
| | |
| | su -m 'www' -c "git -C '/usr/local/www/blog' reset --hard 'origin/master'" |
| | su -m 'www' -c "git -C '/usr/local/www/blog' gc --aggressive --prune='all'" |
| | su -m 'www' -c "git -C '/usr/local/www/blog' fsck --full --strict" |
| | |
| | # End</code> |
| | |
| | ~/'.local/scripts/www/blog/git-fix.sh' |
| | |
| | su 'root' -c ~/'.local/scripts/www/blog/git-fix.sh' |
| | |
| | ====== cron ====== |
| | |
| | ===== Updater ===== |
| | |
| | * 02:00AM Every day |
| | |
| | su - |
| | |
| | ee '/etc/cron.d/blog-updater' |
| | |
| | <code> |
| | # |
| | SHELL=/bin/sh |
| | |
| | 0 2 * * * root '/home/espionage724/.local/scripts/www/blog/updater.sh' |
| | |
| | # End</code> |
| |
| ====== Backup ====== | ====== Backup ====== |
| mariadb -u 'root' -p --execute='CREATE DATABASE wordpress;' | mariadb -u 'root' -p --execute='CREATE DATABASE wordpress;' |
| |
| mariadb -u 'root' -p 'wordpress' < '/home/espionage724/wordpress-database-manual-'*'.sql' | cat ~/'wordpress'*'.sql' | mariadb -u 'root' -p 'wordpress' |
| | |
| | ===== Settings ===== |
| | |
| | su - |
| | |
| | su -m 'www' -c "ee '/usr/local/www/blog/wp-config.php'" |
| | |
| | define( 'DB_HOST', 'localhost' );^M |
| |
| mariadb -u 'root' -p 'wordpress' < '/home/espionage724/wordpress.sql' | define( 'DB_HOST', '127.0.0.1' );^M |
| |