BreadcrumbHomeResourcesBlog Zend Server To ZendPHP Deployment With Ansible For IBM I August 8, 2024 Zend Server to ZendPHP Deployment With Ansible for IBM iMigrationIBM iBy Shlomo VanunuZend is excited to announce the immediate availability of the ZendPHP Ansible Playbook, an automation utility designed to streamline Zend Server to ZendPHP deployment for IBM i systems. This Playbook will allow you to quickly provision ZendPHP and consistently deploy applications at scale using existing Zend Server processes.In this blog, we will walk you through the steps for installing and configuring the ZendPHP Ansible Playbook and related Python modules, which is the prerequisite software for using the ZendPHP Ansible Playbook for IBM i tool.Table of ContentsWhy Migrate from Zend Server to ZendPHP?ZendPHP Deployments Using the Ansible PlaybookBefore Beginning Your Zend Server to ZendPHP Deploymentzpk2ansible Installation & UsageFinal ThoughtsAdditional ResourcesTable of Contents1 - Why Migrate from Zend Server to ZendPHP?2 - ZendPHP Deployments Using the Ansible Playbook3 - Before Beginning Your Zend Server to ZendPHP Deployment4 - zpk2ansible Installation & Usage5 - Final Thoughts6 - Additional ResourcesBack to topWhy Migrate from Zend Server to ZendPHP?ZendPHP, when paired with the ZendHQ extension, delivers the building blocks your IBM i team needs to create modern, scalable, and secure web applications. Working together, ZendPHP and ZendHQ provide scheduled security patches, advanced debugging capabilities, unmatched observability, intuitive orchestration tooling, job management and deployment functionality, and so much more.Rest Easy With Secure and Supported RuntimesZendPHP runtimes keep your mission-critical PHP applications secure, compliant, and performing at a high level. Learn more about how ZendPHP and ZendHQ can benefit your IBM i app, or start a free trial today.Explore ZendPHP Free Trial DetailsBack to topZendPHP Deployments Using the Ansible PlaybookThe ZendPHP Ansible Playbook (zpk2ansible) is a command line utility that builds an Ansible Playbook based on a Zend Server deployment package (ZPK) to deploy the application to the server. Visit this blog post to learn more about the development of the ZendPHP Ansible Playbook.The tool is written in Python. Supported operating systems include Linux and IBM i, and the playbook requires:Ansible-core version 2.11 or newer (installed v2.15)The zpk2ansible tool relies on the ansible.builtin.split filter plugin, a part of the ansible-core and included in Ansible installationsBack to topBefore Beginning Your Zend Server to ZendPHP DeploymentBefore beginning your Zend Server to ZendPHP deployment using Ansible, there are a few prerequisites you will need to address. Use these steps to get started.Downloading IBM i ACS AccessBegin by downloading the IBM i Access Client Solutions (ACS) Open Source Package Management utility. This utility is the preferred way for install open source related software on IBM i servers. As ACS is required, please see the associated documentation for installation instructions.To begin, download the latest Base Package, IBMiAccess_v1r1.zip, from the IBM website. IBM recommends using a 'bash' shell for SSH connections:SSH sessions runs 'bash' shellQP2TERM uses the 'sh' shellChange the default IBM i shell to 'bash'Next, use a SQL client interface, STRSQL or iACS RunSQLCALL QSYS2.SET_PASE_SHELL_INFO('*DEFAULT','/QOpenSys/pkgs/bin/bash’)Use the 'chsh' package./QOpenSys/pkgs/bin/chsh -s /QOpenSys/pkgs/bin/bashFor 'bash' shell troubleshooting tips and processes, please visit this IBM i guide.Installing Python ACS or yum commandPython v3.9+ is required to use the Ansible collection at release 2.14 and up. The following modules and packages must be installed using QP2TERM or any SSH terminal:yum install gityum install python39yum install python39-pip yum install python39-develyum install python39-cryptographyyum install python39-paramikoyum install pase-utf8-localeyum install sshpass (# allows specifying ssh password if desired) /Qopensys/pkgs/bin/yum install git python39 python39-pip python39-devel python39-cryptography python39-cryptography python39-paramiko pase-utf8-locale sshpass Python-39 is also available via the IBM i ACS Open Source Package Management. Launch the IBM i ACS, then select Open Source Package Management, as pictured below.Once the Open Source Package Management Utility is Available, select the Available Packages tab. Scroll to locate 'python 39,' then click the install button.Follow the install screen and wait for the 'completed' message.From the Open Source Package Management Menu, select the 'Installed Packages' tab. Then select 'View' followed by 'Refresh' or press F5 to refresh the list.Install Ansible Using Python pip CommandFor an IBM i Ansible Control node, the latest package levels of Ansible v2.14 or v2.15 are required and should be installed with python pip command or another package manager supported by your operating system, such as apt or yum.Please note, the Open Source Package Management offers Ansible pre-packaged v2.9 only, which is not suitable for our zpk2ansible installation. We recommend installing Ansible with pip, with full Ansible recommended and Ansible-core as an alternative.Full AnsibleTo install full Ansible at 7.X (v2.14 core) or 8.X (v2.15 core), use Python pip. To install level 8.1 that includes v2.15.6 Ansible-core, use the following command:python3.9 -m pip install --user ansible==8.1 Ansible-coreTo install Ansible-core instead of full Ansible, some additional IBM i dependent collections may need to be installed via Ansible-galaxy. To install Ansible-core v2.15.1, use the following command:python3.9 -m pip install --user ansible-core==2.15.1Ensure that all dependent collections installed correctly.Use the Ansible-Galaxy CommandUse the Ansible-galaxy command in the package manager for Ansible to install a collection from Ansible Galaxy. Begin by using the following command to list installed collections:ansible-galaxy collection listIf it doesn't show on the list, perform the following collection install commands:ansible-galaxy collection install community.general ansible-galaxy collection install openstack.cloud ansible-galaxy collection install ansible.posixConfigure the /home/user/.profile file for language environment variables and Ansible path.export PATH export LANG=en_US.UTF-8 export LC_ALL=en_US.UTF-8 export PATH=~/.local/bin:$PATH /home/user/.local/bin:/QOpenSys/pkgs/bin:/opt/zend/zendphp/bin:/QOpenSys/usr/bin:/usr/ccs/bin:/QOpenSys/usr/bin/X11:/usr/sbin:.:/usr/bin: Back to topzpk2ansible Installation & UsageInstalling and using zpk2ansible for IBM i can be completed in a few simple steps. For more information about the playbook, check out the full documentation.To start, use the Zend Server provided zdpack tool to create your application's .zpk file:/usr/local/zendphp74/bin/zdpack create /www/zendphp74/htdocs /usr/local/zendphp74/bin/zdpack pack /www/zendphp74/htdocs Using QP2TERM or any SSH terminal, set up a Python venv virtual environment to run the utility (python3.9-venv is installed with the python39 core).python -m venv venv source venv/bin/activateNext, install the zpk2ansible utility inside the venv environment.wget https://repos.zend.com/zendphp/zpk2ansible/zpk2ansible-latest.whl venv/bin/pip install ./zpk2ansible-latest.whl venv/bin/zpk2ansible --version To run the playbooks, add target IBM i in a text file named hosts_ibmi.ini or inventory.ini. The .ini file describes the targets to which you are deploying your application. Here is an inventory.ini example:[myhosts] 10.151.17.45 ansible_ssh_user=shlomo ansible_ssh_pass=xxxxx 10.151.16.35 ansible_ssh_user=shlomo ansible_ssh_pass=xxxxx [myhosts:vars] ansible_python_interpreter="/QOpensys/pkgs/bin/python3“ ansible_ssh_common_args='-o StrictHostKeyChecking=no’ Check the inventory.ini, then ping the server to verify connection:ansible-inventory -i inventory.ini --list ansible myhosts -m ping -i inventory.ini zpk2ansible Command StructureUsage: zpk2ansible [OPTIONS] COMMAND [ARGS]Options include:version - show the version and exithelp - show this message and exitvenv/bin/zpk2ansible –help venv/bin/zpk2ansible –versionCommands include:build - Builds Ansible playbook file from a ZPK fileinspect - inspects a ZPK file used by Zend Deployment tool to deploy PHPvenv/bin/zpk2ansible build /path/to/your/myapp.zpk venv/bin/zpk2ansible inspect /path/to/your/myapp.zpkZpk2ansible Inspect command then inspects the .zpk file created using zdpack tool:venv/bin/zpk2ansible inspect /path/to/your/myapp.zpkThe output for this command will include various details for the given .zpk file, such as dependencies, status of existing webserver vhost and PHP-FPM pool configurations, overrideable parameters, and, most importantly, a sample build command for the playbook.yaml generation. The inspect command will also notify the user of invalid ZPK items, such as directory, file, or inspection.Sample Build CommandsIn addition to specifying the interactive mode or the chosen web server, this sample command demonstrates how you can override variables in the .zpk file. Here are examples of sample build commands created with the inspect command:zpk2ansible build htdocs-0.1.zpk htdocs-0.1.com --interactive --nginx --appdir /var/www/htdocs-0.1 --user www-data -v locale="None" -v db_host="None" -v db_name="htdocs" -v db_username="root" -v db_password="None" -v skip_base="false"Add a virtual host name for the Apache vhost configuration, change directory location, and change username:(vhost {the second parm after the .zpk name} / --appdir {application directory location} / --user {use a valid IBM i user name} )Deploy Your ApplicationBegin by building and creating the ZendPHP Ansible Playbook:venv/bin/zpk2ansible build /path/to/your/myapp.zpkImplement a sample build command for IBM i:venv/bin/zpk2ansible build /home/shlomo/htdocs-0.1.zpk VhostName.com --interactive --appdir /www/SV2ansible/ --user shlomo -v locale="None" -v db_host="None" -v db_name="htdocs" -v db_username="root" -v db_password="None" -v skip_base="false"The playbook.yml will be created in the current working directory (CWD). Now, run the Ansible playbook.yml created with the above build command to deploy the .zpk file. Use the created hosts_ibmi.ini or inventory.ini.ansible-playbook -i inventory.ini playbook.ymlThis should result in the application installed to the selected directory, /www/SV2ansible.The suggested Apache virtual host configuration file apache.conf should be created under the named directory. Check and modify the virtual host apache.conf suggested directives as needed. The Include directive will be added to the/www/zendphp/conf/httpd.conf Apache configuration, as well as the optional/www/zendphp/conf/vhosts/*.conf.The directory names vhosts will create under/www/zendphp/conf, containing a symlnk to the virtual host apache.conf configuration.Manually add the listen to ip:port command to/www/zendphp/conf.Listen *:10281 Listen *:10280 Back to topFinal ThoughtsMigrating from Zend Server to ZendPHP will keep your application secure, compliant, and delivering excellent results for end users. With Zend Server 2019 having reached end of life, the time has never been better to begin your Zend Server IBM i migration to ZendPHP using tools such as zpk2ansible. To ease the strain of migration, we recommend completing this process in stages. For example, to migrate from Zend Server 2019 to ZendPHP, you may need to first temporarily upgrade to Zend Server 2021. No matter your plan, Zend is here to help. Our expertise is at your disposal. Reach out today with questions or to begin your migration to ZendPHP.Streamline Your Zend Server IBM i MigrationMake the Zend PHP experts your PHP experts. Our services are built to streamline your Zend Server to ZendPHP migration through ongoing support and deployment tools for IBM i such as the ZendPHP Ansible Playbook.Speak With an Expert Today View Playbook DocumentationBack to topAdditional ResourcesOn-Demand Webinar - The Peaks and Valleys of PHP Containerization and OrchestrationOn-Demand Webinar - Choosing the Right PHP for Your IBM iDatasheet - ZendPHPDatasheet - ZendHQWhite Paper - Modernizing IBM iBlog - How to Install (and Configure) Ansible to Deploy a PHP ApplicationBlog - Exploring ZendHQ for IBM iBack to top
Shlomo Vanunu Principal Technical Support Engineeer, Zend by Perforce Shlomo joined the Zend development team 16 years ago and is a part of the IBM i Global Services Team, involved in the development of the Zend for IBMi product installation base. He provides technical services, support, and education for Zend Products for IBMi and related technologies on IBMi.Shlomo has worked in the IT industry for 35 years and has experience with IBMi OS system, programming, and several other OS variants.