The rsync plugin can be used to transfer files to remote machines, and run a user-defined script afterwards.
Example
kind: pipeline
name: default
steps:
- name: deploy
  image: drillster/drone-rsync
  settings:
    hosts: [ "server-prod1", "server-prod2" ]
    source: ./target
    target: ~/packages
    include: [ "app.jar", "app.jar.md5" ]
    script:
      - cd ~/packages
      - md5sum -c app.jar.md5
Properties
- hostsarrayrequired- list of hosts (remote machines) - Default: none 
- portnumberoptional- port to connect to on the remote machines - Default: 22 
- userstringoptional- user to connect as on the remote machines - Default: root 
- keystringoptional- private SSH key for the remote machines Secret recommended- Default: none 
- sourcestringoptional- source folder to copy from - Default: ./ 
- targetstringoptional- target folder on remote machines to copy to - Default: none 
- includearrayoptional- rsync include filter - Default: none 
- excludearrayoptional- rsync exclude filter - Default: none 
- recursivebooleanoptional- instruct plugin to recursively copy - Default: false 
- deletebooleanoptional- instruct plugin to delete the target folder before copying - Default: false 
- argsstringoptional- instruct plugin to use these additional rsync CLI arguments, e.g. "--blocking-io" - Default: none 
- scriptarrayoptional- list of commands to execute on remote machines over SSH after rsync occurs - Default: none 
- prescriptarrayoptional- list of commands to execute on remote machines before rsync occurs - Default: none