定制 dgvirtual/deploy-via-ftp 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

dgvirtual/deploy-via-ftp

Composer 安装命令:

composer require dgvirtual/deploy-via-ftp

包简介

Simple script package for deploying PHP projects to a shared hosting server via FTP or FTPS.

README 文档

README

This is a simple script package for deploying PHP projects to a shared hosting server via FTP or FTPS. It allows you to synchronize directories or upload individual files using lftp and curl.

Author

Name: Donatas Glodenis
Email: dg@lapas.info

Dependencies

This project has the following dependencies:

  • bash: Used to run the deployment script itself;
  • lftp: Used for synchronizing directories;
  • curl: Used for uploading individual files;
  • composer: Required for installing this package and updating the vendor directory before and after deployment.

Note: The project has been tested on Ubuntu 24.04 LTS.

Ensure that bash, lftp, curl, and composer are installed and accessible in your system's PATH.

Installation

You can install this package via Composer by running these commands at the root of your project:

composer require dgvirtual/deploy-via-ftp:dev-master

Note: although the project will not be used on the production server, it should be installed using composer require and not require-dev, as the app removes all dev-only packages before deploying vendor directory, and it should not remove itself.

This will install the deploy-via-ftp package from your GitHub repository and make the deployment script available in your project.

Then you will be able to run the deploy script via command:

./vendor/dgvirtual/deploy-via-ftp/src/deploy.sh [options]

You can also add an entry to your project's composer.json scripts section:

    "scripts": {
        "deploy": "./vendor/dgvirtual/deploy-via-ftp/src/deploy.sh"
    }

to be able to run the script more conveniently as

composer deploy [options]

Usage

Synchronizing Directories

You can use the following commands to synchronize directories with your remote FTP server:

composer deploy app
composer deploy vendor
composer deploy public
composer deploy public dry-run

You can also combine multiple directories in a single command:

composer deploy app vendor

Available Arguments

  • app: Synchronize the app directory only.
  • vendor: Synchronize the vendor directory only.
  • public: Synchronize the public_html directory only.
  • dry-run: Perform dry run (without changing content on the server).

Uploading a Single File

To upload a single file, use the following command:

composer deploy onefile [local_path]

Example:

composer deploy onefile app/Controllers/Test.php

This will upload app/Controllers/Test.php to the corresponding location on your FTP server. The remote path will be determined based on the local path.

Configuration

Before you can use the deployment script, you need to configure your FTP settings.

  1. On the first run, if the .ftp_config file is missing in the main project directory, the script will prompt you to create it by running an install.sh script.
  2. The install.sh script will:
    • Copy ftp-config.example to .ftp_config.
    • Optionally add .ftp_config to your .gitignore file.
    • Instruct you to edit .ftp_config with your FTP credentials.

Example .ftp_config:

# .ftp_config
USERNAME="myname"
PASSWORD="mySecretPass"
PROTOCOL="ftps"  # or "ftp"
PORT=21
SERVER="ftp.example.com"

# Remote directories
REMOTE_APP="/myproject/app"
REMOTE_VENDOR="/myproject/vendor"
REMOTE_PUBLIC_HTML="/public_html"

# Exclusion patterns
APP_EXCLUDE_GLOBS=""
VENDOR_EXCLUDE_GLOBS=""
PUBLIC_EXCLUDE_GLOBS="--exclude-glob='uploads/*' --exclude-glob='index.php'"

# Local directories
LOCAL_APP="app"
LOCAL_VENDOR="vendor"
LOCAL_PUBLIC_HTML="public"

Edit this file with your FTP credentials and paths as needed.

Notes

  • The script assumes that your project follows a structure where directories like app, vendor, and public_html are located in the base directory, while the server you deploy to places app and vendor inside myproject directory, which, along with public_html, is at the root of the directory structure accessible to ftp.
  • Make sure to review the exclusion patterns in the .ftp_config file and adjust them to suit your project.

If you have any issues or need further assistance, feel free to contact the author at dg@lapas.info.

This README.md file provides clear instructions for installing, configuring, and using the deploy-via-ftp script, tailored specifically for your needs.

统计信息

  • 总下载量: 1
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 1
  • Forks: 0
  • 开发语言: Shell

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-01-06