前言
這是我第一次用 PHP 的包管理工具 composer
一開始用 docker 進行部署,但一直出問題,最後還是選擇直接在伺服器上安裝 php-fpm 搭配 nginx 的方案了。
PS:docker方式真的搞得心好累,現在回想起來還心有餘悸😢
docker方案
先把我的 docker 方案放上來吧,畢竟也折騰了好久,處於基本可用的狀態。
目錄結構
目錄結構如下
php-code
├─ log // 日誌
│ ├─ nginx
│ └─ php
├─ conf // 配置
│ ├─ nginx
│ │ ├─ nginx.conf
│ │ └─ test.conf
│ └─ php
│ ├─ conf.d
│ │ └─ docker-php-ext-xdebug.ini
│ ├─ php-fpm.conf
│ └─ php.ini
├─ code // PHP程式碼
├─ docker-compose.yml
├─ Dockerfile
└─ .env
nginx配置
server {
listen 8080;
server_name localhost;
root /usr/share/nginx/html/public;
index index.php index.html index.htm;
charset utf-8;
client_max_body_size 100M;
location ~ \.php$ {
fastcgi_pass php-fpm:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /var/www/html/public$fastcgi_script_name;
fastcgi_param SCRIPT_NAME $fastcgi_script_name;
include fastcgi_params;
}
location / {
if (!-e $request_filename){
rewrite ^(.*)$ /index.php?s=$1 last; break;
}
}
}
access_log /var/log/nginx/access.log main;
error_log /var/log/nginx/error.log warn;
server_tokens off;
PHP配置
主要是開啟除錯日誌,可以看到程式執行的時候有什麼報錯
docker-php-ext-xdebug.ini
xdebug.remote_enable = On
xdebug.remote_handler = dbgp
xdebug.remote_host = host.docker.internal
xdebug.remote_port = 9001
xdebug.remote_log = /var/log/php/xdebug.log
xdebug.idekey = PHPSTOR
php-fpm.conf
[global]
error_log = /proc/self/fd/2
; https://github.com/docker-library/php/pull/725#issuecomment-443540114
log_limit = 8192
[www]
; if we send this to /proc/self/fd/1, it never appears
access.log = /proc/self/fd/2
clear_env = no
; Ensure worker stdout and stderr are sent to the main error log.
catch_workers_output = yes
decorate_workers_output = no
php.ini
log_errors=On
dockerfile
構建docker映象,這個專案要求的PHP版本是7.4
讓我感到很奇怪的是 PHP 的官方映象里居然沒有 composer,還得自己折騰。
這個 dockerfile 參考了很多文章部落格,結果發現還不如自己折騰一下,已知問題是 gd 外掛安裝沒有生效,猜測是還需要使用 apt 安裝
php-gd
,然後docker-php-ext-install
才能生效。
FROM composer:2.2 as composer
FROM php:7.4.33-fpm as php
# 映象資訊
LABEL Author="DealiAxy"
LABEL Version="2023.11"
LABEL Description="PHP 7-fpm 開發環境映象."
# 更新為國內映象
RUN apt install apt-transport-https ca-certificates \
&& mv /etc/apt/sources.list /etc/apt/sources.list.bak \
&& echo "Acquire::http::Pipeline-Depth \"0\";" > /etc/apt/apt.conf.d/99nopipelining \
&& echo 'deb http://mirrors.tuna.tsinghua.edu.cn/debian/ bullseye main contrib non-free' > /etc/apt/sources.list \
&& echo 'deb http://mirrors.tuna.tsinghua.edu.cn/debian/ bullseye-updates main contrib non-free' >> /etc/apt/sources.list \
&& echo 'deb http://mirrors.tuna.tsinghua.edu.cn/debian/ bullseye-backports main contrib non-free' >> /etc/apt/sources.list \
&& apt-get update
# bcmath, calendar, exif, gettext, sockets, dba,
# mysqli, pcntl, pdo_mysql, shmop, sysvmsg, sysvsem, sysvshm 擴充套件
RUN docker-php-ext-install -j$(nproc) bcmath calendar exif gettext sockets dba mysqli pcntl pdo_mysql shmop sysvmsg sysvsem sysvshm iconv
RUN apt update && apt-get install -y git zip libpng-dev libzip-dev && \
rm -rf /var/lib/apt/lists/* && \
ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && \
docker-php-ext-install pdo pdo_mysql mysqli gd zip bcmath opcache && \
docker-php-ext-enable mysqli gd
# 複製程式碼
COPY --chown=www-data:www-data ./code /var/www/html
# copy vender
COPY --from=composer /usr/bin/composer /usr/bin/composer
WORKDIR /var/www/html
RUN composer config -g repo.packagist composer https://mirrors.aliyun.com/composer/ \
&& composer config -g --unset repos.packagist \
&& composer install \
&& ls -la
EXPOSE 9000
CMD ["php-fpm"]
環境變數 .env
APP_NAME=php-oa
docker-compose
version: "3.6"
services:
nginx:
image: nginx:stable-alpine
container_name: ${APP_NAME}_nginx
restart: unless-stopped
volumes:
- ./conf/nginx/nginx.conf:/etc/nginx/conf.d/default.conf
- ./code:/usr/share/nginx/html
- ./log/nginx:/var/log/nginx
ports:
- "8080:8080"
depends_on:
- php-fpm
networks:
- default
- swag
php-fpm:
build: .
user: 'www-data:www-data'
container_name: ${APP_NAME}-php
restart: unless-stopped
volumes:
# - ./conf/php:/usr/local/etc/php
- ./code/public:/var/www/html/public
- ./conf/php/php-fpm.conf:/usr/local/etc/php-fpm.d/docker.conf
- ./conf/php/php.ini:/usr/local/etc/php/php.ini
- ./log/php:/var/log/php
networks:
- default
networks:
swag:
name: swag
external: true
default:
name: ${APP_NAME}
直接部署方案
這是最容易的方案
我的伺服器是 Ubuntu 22.04 ,官方源的 PHP 是8.1版本,這裡需要新增 PPA 才能使用 7.4 版本。
新增 PPA 源
sudo apt install software-properties-common
sudo add-apt-repository ppa:ondrej/php -y
sudo apt update
安裝PHP7.4
並且把常用擴充套件也安裝了
sudo apt install php7.4 php7.4-fpm
sudo apt install php7.4-{cli,common,curl,zip,gd,mysql,xml,mbstring,json,intl}
裝完檢視狀態
sudo systemctl status php7.4-fpm.service
安裝和配置 nginx
安裝就不多說了
直接配置
在 /etc/nginx/sites-available
裡增加一個配置檔案
這裡的檔名是 php.conf
我們把 PHP 程式碼放在 /var/www/html/php-code
設定網站根目錄為 PHP 程式碼下的 public
目錄 (這是這個專案設計成這樣的)
server {
server_name domain.com;
listen 8081;
root /var/www/html/php-code/public;
index index.php index.html index.htm;
charset utf-8;
client_max_body_size 100M;
location ~ \.php$ {
include snippets/fastcgi-php.conf;
fastcgi_pass unix:/run/php/php-fpm.sock;
}
location / {
if (!-e $request_filename){
rewrite ^(.*)$ /index.php?s=$1 last; break;
}
}
}
安裝 composer 和安裝依賴
使用 composer 安裝依賴
如果沒有這一步的話,那就跟5、6年前在使用 PHP 的時候沒有區別
官方地址
可以直接透過官方源安裝,並且使用 php 直接執行安裝指令碼
sudo apt-get install curl
sudo apt-get install php php-curl
curl -sS https://getcomposer.org/installer -o composer-setup.php
sudo php composer-setup.php --install-dir=/usr/local/bin --filename=composer
sudo composer self-update
國內源
透過國內源下載二進位制檔案
curl https://mirrors.cloud.tencent.com/composer/composer.phar -o /usr/local/bin/composer
curl https://mirrors.aliyun.com/composer/composer.phar -o /usr/local/bin/composer
chmod +x /usr/local/bin/composer
檢查 composer
composer -v
配置映象
得先配置一下國內映象,可以參考這個專案: https://github.com/china-speed/china-speed.github.io
composer config -g repo.packagist composer https://mirrors.aliyun.com/composer/
composer config -g --unset repos.packagist
安裝依賴
cd /var/www/html/php-code
composer install
搞定
處理許可權問題
不知道是不是所有 PHP 專案都喜歡在專案下面建立和修改檔案,這也給docker部署方式帶來了不小的挑戰
直接在系統上部署好一點,首先把程式碼目錄所有者轉移給 www-data 使用者
chown -R www-data:www-data /var/www/html
為了本使用者也能寫入,新增一下使用者組
usermod -a -G www-data {username}
對了,PHP檔案還需要可執行許可權才行……
chmod -R u+rwx /var/www/html/php-code
給組內的使用者也新增一下讀寫許可權
chmod -R g+rw /var/www/html/php-code
基本就搞定了。
使用 ThinkPHP 框架的後端也不存在什麼啟動後端服務的概念,直接這樣把程式碼放在目錄裡就搞定了,直接訪問即可。
參考資料
- https://linux.how2shout.com/how-to-install-php-7-4-on-ubuntu-22-04-lts-jammy-linux/
- https://www.myfreax.com/secure-nginx-with-let-s-encrypt-on-ubuntu-22-04/
- https://www.cherryservers.com/blog/how-to-install-composer-ubuntu
- https://www.myfreax.com/how-to-install-php-on-ubuntu-20-04/
- https://learnku.com/articles/31344
- https://github.com/mouyong/docker-php/tree/master/fpm