相关链接
本教程基于Debian13的阿里云服务器,使用Docker部署项目适配的 PHP7.4、MySQL5.7 (其实是APT包已经不支持这两个老版本…),并在宿主机安装 Nginx+Certbot 实现站点上线。
项目资源获取
LGnewUI-2采用授权下载方式,需要在 LGNewUi-Auth - 情侣小站在线授权系统 登录并经授权后,下载项目源代码。
Docker的安装配置
参考阿里云给出的文档,按序执行即可:
#删除Docker相关源sudo rm -f /etc/apt/sources.list.d/*docker*.list#卸载Docker和相关的软件包for pkg in docker.io docker-buildx-plugin docker-ce-cli docker-ce-rootless-extras docker-compose-plugin docker-doc docker-compose podman-docker containerd runc; do sudo apt-get remove -y $pkg; done
#添加 GPG 密钥sudo apt updatesudo apt install ca-certificates curlsudo install -m 0755 -d /etc/apt/keyringssudo curl -fsSL http://mirrors.cloud.aliyuncs.com/docker-ce/linux/debian/gpg -o /etc/apt/keyrings/docker.ascsudo chmod a+r /etc/apt/keyrings/docker.asc#将该软件源添加到 Apt 源列表中。sudo tee /etc/apt/sources.list.d/docker.sources <<EOFTypes: debURIs: http://mirrors.cloud.aliyuncs.com/docker-ce/linux/debianSuites: $(. /etc/os-release && echo "$VERSION_CODENAME")Components: stableSigned-By: /etc/apt/keyrings/docker.ascEOF
sudo apt update#安装Docker社区版本,容器运行时containerd.io,以及Docker构建和Compose插件sudo apt install -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
#启动Dockersudo systemctl start docker#设置Docker守护进程在系统启动时自动启动sudo systemctl enable docker配置镜像源:
sudo nano /etc/docker/daemon.json轩辕镜像 一键配置脚本:
bash <(wget -qO- https://xuanyuan.cloud/docker.sh)镜像源配置示例:
{ "registry-mirrors": [ "https://docker.m.daocloud.io", "https://docker.1panel.live/" ]}如果配置后仍然无法拉取(docker pull)镜像,请考虑使用科学上网工具。
对于不同设备,可以使用以下命令传输离线镜像包:
# 拉取镜像(设备1)docker pull ...
# 打包镜像(设备1) | <path>/<name>.tar为自定义路径的tar文件,<image_name>为拉取的镜像名称docker save -o <path>/<name>.tar <image_name>
# 将<name>.tar上传到服务器中,然后加载镜像(设备2--服务器)docker load -i <path>/<name>.tarPHP、MySQL的compose配置
# 创建docker文件夹mkdir ~/php74mkdir ~/mysql57
# 编辑php的docker-compose(参考下文给出的yml)nano ~/php74/docker-compose.yml
# 编辑mysql的docker-compose(参考下文给出的yml)nano ~/mysql57/docker-compose.ymlphp7.4-fpm 配置示例:
version: '3.9'services: php: image: 'php:7.4-fpm' ports: - '9000:9000' volumes: - '/var/www:/var/www' restart: always container_name: php74-fpmmysql5.7 配置示例:
version: '3.9'services: mysql: image: 'mysql:5.7.44' volumes: - '/data/mysql:/var/lib/mysql' environment: - MYSQL_DATABASE=LGnewUI2 - MYSQL_ROOT_PASSWORD=yourpassword ports: - '3306:3306' restart: always container_name: mysql57可以先拉取镜像,或者参考上一节的内容,加载离线镜像包:
# 拉取镜像 (方式1)sudo docker pull php:7.4-fpmsudo docker pull mysql:5.7.44
# 加载镜像 (方式2)sudo docker load -i <path>/<name>.tar随后就可以启用容器了:
cd ~/php74sudo docker compose up -d
cd ~/mysql57sudo docker compose up -d现在需要创建docker网络,用于连通php与mysql:
sudo docker network create mynetsudo docker network connect mynet php74-fpmsudo docker network connect mynet mysql57Nginx、Certbot安装与配置(网站上线)
# 使用apt-get获取nginx、certbotapt-get update && apt-get install -y nginxapt-get install -y certbotapt-get install -y python3-certbot-nginx
# 开机自启动与即刻运行nginxsystemctl enable nginx && systemctl start nginx创建源码存放目录,并上传资源:
# 需要以root身份mkdir /var/www/lovecd /var/www/love# 随后通过SFTP等工具上传源码至此使用certbot(自动续签)申请ssl证书(确保域名都已在DNS处解析过):
# 将<your-main-domain>更换为你的主要站点域名sudo certbot certonly --nginx -d <your-main-domain>
# 一些相关命令# 查看所有已安装的证书sudo certbot certificates# 删除证书sudo certbot delete --cert-name example.com<your-main-domain>示例:love.example.com| 作为主要访问地址
编辑Nginx配置文件,并上线网站:
# 编辑配置(参考下文)sudo nano /etc/nginx/sites-available/default
# 创建启用软链接ln -s /etc/nginx/sites-available/default /etc/nginx/sites-enabled/default
# 测试配置格式正确否nginx -t
# 重载nginx使配置生效sudo systemctl reload nginxNginx(LGnewUI-2)配置文件(将<your-main-domain>替换为自定义域名):
# ==================== Love站点 - HTTP ====================server { listen 80; server_name <your-main-domain>;
# HTTP自动跳转HTTPS return 301 https://$host$request_uri;}
# ==================== Love站点 - HTTPS ====================server { listen 443 ssl http2; server_name <your-main-domain>;
ssl_certificate /etc/letsencrypt/live/<your-main-domain>/fullchain.pem; ssl_certificate_key /etc/letsencrypt/live/<your-main-domain>/privkey.pem;
root /var/www/love; index index.php index.html index.htm;
client_max_body_size 100m; client_body_timeout 60s;
gzip on; gzip_types text/plain text/css application/javascript text/xml application/xml application/xml+rss text/javascript; gzip_comp_level 6; gzip_vary on;
location ~ ^.+?\.php(/.*)?$ { fastcgi_pass 127.0.0.1:9000; fastcgi_split_path_info ^(.+\.php)(/.*)$; set $path_info $fastcgi_path_info; fastcgi_param PATH_INFO $path_info; include fastcgi_params; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; }
location / { try_files $uri $uri/ /index.php?$query_string; }}防IP直连的Nginx配置(选用)
直接给出配置文件新增字段:
# ==================== 防IP访问 - HTTP ====================server { listen 80 default_server; listen [::]:80 default_server; # 匹配所有未绑定的域名和直接 IP 访问 # 444直接关闭连接,不返回任何信息,比 403 更安全 server_name _; return 444;}
# ==================== 防IP访问 - HTTPS ====================server { listen 443 ssl http2 default_server; listen [::]:443 ssl http2 default_server; server_name _;
# 配置一个无效或自签名的 SSL 证书,或指向不存在的证书路径 # 目的是让通过 IP 的 HTTPS 访问因证书错误而失败 ssl_certificate /data/customSSL/dummy.crt; ssl_certificate_key /data/customSSL/dummy.key;
# 也可以直接返回错误,但证书错误通常能阻止连接建立 return 444;}启用之前,需要先使用openssl申请自签名无效证书:
mkdir -p /data/customSSLopenssl req -x509 -nodes -days 3650 -newkey rsa:2048 \ -keyout /data/customSSL/dummy.key \ -out /data/customSSL/dummy.crt \ -subj "/CN=unused"LGnewUI-2 新版本依赖补全
此节用于解决LGnewUI部署引导中大多数问题。
SourceGuardian 加密依赖文件
将此文件上传到服务器后,进入PHP容器的bash环境进行依赖安装:
# 把ixed.7.4.lin文件从宿主机复制到容器docker cp ixed.7.4.lin php74-fpm:/usr/local/lib/php/extensions/no-debug-non-zts-20190902/# 进容器配置php.inidocker exec -it php74-fpm bashecho "extension=ixed.7.4.lin" >> /usr/local/etc/php/conf.d/ixed.iniecho "sourceguardian.enable_vm_hybrid=1" >> /usr/local/etc/php/conf.d/ixed.iniPHP基本配置与依赖拓展
# 进入容器bash环境(请判断你是否在宿主机中)docker exec -it php74-fpm bash
# 基本配置echo 'upload_max_filesize = 20M' >> /usr/local/etc/php/conf.d/custom.iniecho 'post_max_size = 20M' >> /usr/local/etc/php/conf.d/custom.ini
# mysql拓展docker-php-ext-install pdo_mysql mysqli
# EXIF拓展docker-php-ext-install exif
# 换阿里云apt源echo "deb http://mirrors.aliyun.com/debian bullseye main contrib non-free" > /etc/apt/sources.listecho "deb http://mirrors.aliyun.com/debian-security bullseye-security main contrib non-free" >> /etc/apt/sources.listapt-get update
# GD拓展(图片处理)apt-get install -y libpng-dev libjpeg-dev libwebp-dev --no-install-recommendsdocker-php-ext-configure gd --with-jpeg --with-webpdocker-php-ext-install gd
# Zip拓展(压缩)apt-get install -y libzip-dev --no-install-recommendsdocker-php-ext-install zip
# Intl拓展(国际化)apt-get install -y libicu-dev --no-install-recommendsdocker-php-ext-install intl
# imagick拓展apt-get install -y libmagickwand-dev --no-install-recommendspecl install imagickdocker-php-ext-enable imagick
# mysql-client(mysqldump)apt-get install -y default-mysql-client
# FFmpegapt-get install -y ffmpeg --no-install-recommends
# 退出容器bash环境,重启容器exitdocker restart php74-fpm路径权限问题
在上文中,PHP 的挂载路径为/var/www/,而docker容器的权限身份一般是uid=33(www-data) gid=33(www-data) groups=33(www-data),需要保持路径所属身份一致:
# 确认容器权限身份,一般为uid=33(www-data) gid=33(www-data) groups=33(www-data)docker exec php74-fpm id www-data# 1. 创建与容器内匹配的用户和组(UID/GID 都是 33)sudo groupadd -g 33 www-data 2>/dev/nullsudo useradd -u 33 -g 33 -M -s /sbin/nologin www-data 2>/dev/null# 2. 设置项目目录所有者sudo chown -R 33:33 /var/www/MySQL数据库填写
在上文的compose文件中,已经创建了一个数据库:
- 地址:
mysql57 - 库名:
LGnewUI2 - 用户:
root - 密码:
yourpassword
和风天气API—生成Ed25519密钥对
cd ~# 生成私钥文件openssl genpkey -algorithm Ed25519 -out private.pem# 导出公钥文件openssl pkey -in private.pem -pubout -out public.pem# 查看内容cat private.pemcat public.pem其他
发现错误或想要改进这篇文章?
文章修订历史 (13 次)
查看变更记录
CMS:Update Posts “lgnewui2”
CMS:Update Posts “lgnewui2”
CMS:Update Posts “lgnewui2”
CMS:Update Posts “lgnewui2”
CMS:Update Posts “lgnewui2”
CMS:Update Posts “lgnewui2”
CMS:Update Posts “lgnewui2”
CMS:Update Posts “lgnewui2”
CMS:Update Posts “lgnewui2”
CMS:Update Posts “lgnewui2”
CMS:Update Posts “lgnewui2”
CMS:Update Posts “lgnewui2”
CMS:Update Posts "lgnewui2"