用Docker快速構建LEMP環(huán)境的方法示例
LEMP (Linux + Nginx + MySQL + PHP) 基本是如今網(wǎng)頁開發(fā)者的必備環(huán)境,正常情況下我們可以直接通過系統(tǒng)包管理工具如 apt、yum 直接安裝使用,然而由于兼容考慮,系統(tǒng)自帶的軟件源往往更新緩慢,在半年左右就會停滯在上個版本,影響開發(fā)者對新功能的跟進測試。
為了追求最新版本,不少開發(fā)者開始下載源碼包自己進行編譯,但過程過于繁瑣,到后來也催化出類似 Oneinstack、lamp.sh 等一鍵安裝包。
而 Docker 的推出,可以大大簡化以上的過程。在 Docker Hub 上有許多維護者將 php、nginx 等各個組件打包成一個個 image,作為用戶只要拉取組合相關的 image 即可搭建 LEMP。而且基于 Docker 的特性至少帶來以下優(yōu)點:
- 更新迅速,隨時回滾指定版本
- 容器隔離,安全性高
- 無系統(tǒng)殘留,不存在依賴鏈沖突
兩個月前我就開始著手構建整個 LEMP 的框架,并根據(jù)需要自行維護了部分 image,相關編排模板開源在 https://github.com/metowolf/docker-lemp。當前整個博客、API 站都跑在 docker 上,運行起來相當穩(wěn)定。
容器
| 容器名 | 版本 |
| metowolf/php | 7.3.1, 7.3, 7, current |
| metowolf/nginx | 1.15.8, 1.15, 1, current |
| mysql/mysql-server | 8.0.15 |
| phpmyadmin/phpmyadmin | 4.8.5 |
| abiosoft/caddy | 0.11.2 |
| redis | 5.0.3-alpine |
演示
下面我用一個簡單的例子做個示范。
首先需要安裝 docker 和 docker-compose 兩個環(huán)境。為了方便演示,這里直接使用 PWD 的試用主機來運行。
$ curl -fsSL https://get.docker.com -o get-docker.sh $ sh get-docker.sh $ curl -L "https://github.com/docker/compose/releases/download/1.23.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose $ chmod +x /usr/local/bin/docker-compose
登陸服務器,拉取編排模板
$ git clone https://github.com/metowolf/docker-lemp.git $ cd docker-lemp
創(chuàng)建配置文件
$ cp .env.example .env $ cp docker-compose.example.yml docker-compose.yml
創(chuàng)建 nginx 配置
$ cat > etc/nginx/config/example.conf <<EOF
server {
listen 80;
server_name example.com *.direct.labs.play-with-docker.com;
root /var/www/example.com;
index index.php;
location / {
try_files \$uri \$uri/ /index.php?\$query_string;
}
location ~ \.php\$ {
fastcgi_split_path_info ^(.+\.php)(/.+)\$;
fastcgi_pass php-fpm:9000;
fastcgi_index index.php;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME \$document_root\$fastcgi_script_name;
fastcgi_param PATH_INFO \$fastcgi_path_info;
}
}
EOF
創(chuàng)建 phpinfo 文件
$ mkdir wwwroot/example.com/ $ cat > wwwroot/example.com/index.php <<EOF <?php phpinfo(); EOF
啟動容器
$ docker-compose up -d php-fpm nginx mysql
啟動成功后,如果沒有意外,我們就能在 80 端口看到熟悉的頁面了。
高級玩法
QUIC
在編排示例中,我添加了一個 caddy 來反代 nginx,以此來獲得 quic 特性。借助 docker 的特性,我們可以讓 caddy 單獨監(jiān)聽 443 udp 端口,讓 nginx 依舊監(jiān)聽 443 tcp 端口,這樣可以同時兼顧 TLSv1.3 和 quic。
nginx 配置中需要添加一個返回頭,提醒瀏覽器嘗試連接 quic
add_header alt-svc 'quic=":443"; ma=2592000; v="44,43,39"';
brotli
在 nginx 容器中,我將 brotli 編譯成動態(tài)模塊,可以根據(jù)需要開啟。
新建 etc/nginx/nginx.conf 配置文件
user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
# 掛載 brotli 模塊
load_module modules/ngx_http_brotli_filter_module.so;
load_module modules/ngx_http_brotli_static_module.so;
events {
worker_connections 1024;
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
#tcp_nopush on;
keepalive_timeout 65;
#gzip on;
include /etc/nginx/conf.d/*.conf;
}
新建 etc/nginx/config/brotli.conf 配置文件
brotli on; brotli_comp_level 6; brotli_types application/x-httpd-php application/javascript application/x-javascript application/xml application/json text/plain text/javascript text/css text/xml image/jpeg image/gif image/png image/svg+xml;
修改 docker-compose.yml 掛載 nginx.conf 配置文件
--- docker-compose.yml +++ docker-compose.yml @@ -11,6 +11,7 @@ - php-fpm volumes: - ./log/nginx:/var/log/nginx:rw + - ./etc/nginx/nginx.conf:/etc/nginx/nginx.conf:rw - ./etc/nginx/config:/etc/nginx/conf.d:rw - ./etc/ssl:/etc/nginx/ssl:rw - ./wwwroot:/var/www:rw @@ -65,6 +66,8 @@
最后更新容器編排即可
$ docker-compose up -d --no-deps --build
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
docker?pull出現(xiàn)錯誤或速度慢具體解決辦法
docker pull的時候速度特別慢,急死我了,相信看到文章的你跟我是一個心情,下面這篇文章主要給大家介紹了關于docker?pull出現(xiàn)錯誤或速度慢的具體解決辦法,需要的朋友可以參考下2024-05-05
Docker Gitlab+Jenkins+Harbor構建持久化平臺操作
這篇文章主要介紹了Docker Gitlab+Jenkins+Harbor構建持久化平臺操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11
Docker使用nodejs鏡像構建express服務的方法
這篇文章主要介紹了Docker使用nodejs鏡像構建express服務,主要包括nodejs容器的啟動,安裝nodejs第三方依賴模塊及啟動nodejs服務的相關操作,本文給大家介紹的非常詳細,需要的朋友可以參考下2022-07-07

