How to deploy .war files in Plesk Onyx 17.8 despite no longer supported TomCat?

前端 未结 3 1749
猫巷女王i
猫巷女王i 2021-01-23 01:53

Up to and including version 17.5 Plesk Onyx came with a Tomcat installation, which is no longer supported from version 17.8. Thus no .war files can be deployed and executed anym

3条回答
  •  礼貌的吻别
    2021-01-23 02:21

    We had the same issue: After a successful deploy on Plesk Onyx 17.5 our hoster announced a forced update to 17.8 justified by GDPR requirements by Plesk. Knowing that this would break our production environment, we set up a new machine to test our possibilities. I was very happy to find your idea here @ThirstForKnowledge - which sounds great to my ears - but Docker was not an option for us as our virtualized hosting environment was not possible to run an Docker host. So we came up with another idea, which may be helpful for others with the same difficulties to face with.

    1. Idea

    Install Tomcat as standalone application and deploy .war with Tomcat Manager shipped by default. Create a cron script checking for updates of the Tomcat .zip archive and install JRE by using package manager, which auto-updates by Plesks initiation regularly.

    2. Solution

    • Install JRE by using package manager
    • Install Tomcat by using the .zip from their mirrors
    • Harden it against attacks by following one of various online tutorials
    • Make it a service and enable it for start at bootup
    • Configure Tomcat manager application (localhost only, look three steps ahead)
    • Block Tomcats default port by Plesk firewall
    • Set up Plesks subscription with encryption and automatic redirection to HTTPS
    • Use Plesks ability to change Apache configuration and set up reverse proxy to Tomcats port
    • Check domain for a running Tomcat server and valid encryption
    • Log in to Tomcat manager
    • Undeploy all demo applications and deploy your .war
    • Deactivate manager access to prevent attacks (or configure Fail2Ban appropriately) (may not be needed if you follow all next steps but safe is safe)
    • Change reverse proxy configuration to point / to your application
    • Create a script to update Tomcat and cron it by Plesk

    3. Explanation

    Users connections will be guided to your Tomcat/Java application but encryption and all the other hosting stuff can be done by Plesk interface. Updates will be driven by Plesks package updater for Java and by the cron script for Tomcat. Deploying and undeploying is be made really easy by Tomcat manager which is only shortly exposed to the WWW when needed and credentials are securely transmitted. Tomcat needed to be manually installed because our package manager only had Tomcat 7 in his repositories, this maybe defers to your installation so check it before!

    4. Open questions

    Does anyone have more experience or finds security weaknesses or leaks with this approach? Does anyone have a nicer idea to fulfill this taks? Do we miss something? I'm happy about all considerations :)

提交回复
热议问题