What is DevOps?
DevOps represents a change in the IT culture, it is not only about software. DevOps focus on rapid delivery, focus on people and seeks to improve the developer-admin teams. If in our IBMi world, we want to be part of DevOps team, we should be able to implement some automation tools and implement the so called "infraestructure as a code".
I played a bit in windows and linux world with Chef and my colleagues just kept telling me "no, you cant do DevOps on AS400". (I know, i did my best educating them to use IBM instead ... usually when they pronounce that AS400 word, i dont listen).
How can i start using some DevOps tools on IBMi?
There are many tools than can help multidisciplinary teams (windows, linux, db teams) to work in the world of DevOps: Chef, Ansible, Salt, Puppet... If you already know one of them, try to adapt them to the IBMi world.
It takes a lot of time and effort to understand this tools, but you will be able to manage a huge amount of nodes in your infrastructure. Some of this tools uses agents or SSH sessions and they are based on configuration instead of programming.
Recently i deployed recently 12 IBMi partitions... they were with "initial state": LIC and sofware installed and latest PTF installed. Then, it came to my mind how many repetitive tasks i would need to perform to configure those systemes!
Because all systems are part of same dev/integration/test/production enviroment), imagine adding system values, configuring subsystems, set secure values (system values, journals, firewall) and deploy software and packages (php, node, tools for developes, apache configuration, etc).
No, i dont want to repeat myself doing that all the time.
Python Fabric: decentralized DevOps.
After checking alternatives, i decided to go to a most simple implementation of DevOps and dont use a complicated "centralized" system.
Everything i need is just my computer ,a repository of code and SSH access to my nodes. Simplicity does not mean bad or non-DevOps.
There are a couple of decentralized light-DevOps tools that could be very funny to use: Fabric and BundleWrap. Fabric is more about to program in python what to do with tasks. BundleWrap is most about configuration and it is also Python based.
I choice Fabric.
Fabric is a python library and command-line tool for streamlining the use of SSH for application deployment or systems administration tasks. It uses SSH tuneling via paramiko library. it is a very proactive tool and you can start to automate many tasks in your IBMi in minutes.
With Fabric, it is simple to write some code on your computer and run it against all your nodes.
Lets start installing Fabric ( i tested on Python27).
> pip install fabric
Next step is to create your directory and start typing tasks! For a "Hello World" i recommend you to use a single node and simple command
Note: On those examples im using simple password, but of course it is better to manage your connections with SSH keys and know_hosts.
Create the file "fabfile.py" in your directory and write this code:
from fabric.api import run def test(): run('uname -s')
Now we can use the command fab --list and see the tasks included:
fab --list
Available commands
test
and run it with
> fab -H (your node) test
and the output should be like
[myserver] Executing task 'test' [myserver] run: uname -s [myserver] Login password for 'andres': [myserver] out: bsh: /bin/bash: not found [myserver] out: Fatal error: run() received nonzero return code 1 while executing! Requested: uname -s Executed: /bin/bash -l -c "uname -s" Aborting. Disconnecting from myserver... done.
Oops! failed! But why? Well, Fabric is looking for a default Linux bash in "/bin/bash" so we need to tell Fabric that this is an IBMi and i want to use another bash. We are lucky, Fabric provides a settings context manager to change our enviroment.
from fabric.api import run,env env.shell = "/QOpenSys/usr/bin/bsh -c" # Change user name, my SSH user env.user = "ACL" def test(): run('uname -s')
> fab -H (your node) test
C:\pythonmanagement>fab -H myserver test [myserver] Executing task 'test' [myserver] run: uname -s [myserver] Login password for 'ACL': [myserver] Login password for 'ACL': [myserver] out: OS400 [myserver] out: Done. Disconnecting from myserver... done.
So thats all!.
With the command line we told our program what node to connect and what task should perform. Fabric gives and output and we can know at the moment the status of our task.
Now it comes to my mind a big amount of tasks that we could perform with Fabric:
1. Define host names into our scripts or even roles (development servers, production servers, etc).
2. Define any kind of tasks to perform at a time.
3. Check status of services in our servers and response to them.
4. Deploy a bashscript to all our servers and call it from Fabric. But, what if we want to run IBMi/OS commands? Just simple, change enviromental shell to "system" command
from fabric.api import run,env IBM_PASE = "/QOpenSys/usr/bin/bsh -c" IBM_OS = "system" env.user = "ACL" def set_hosts(): # Define my hosts. env.hosts = ['disibic21', 'disibic22'] def check_lib(): env.shell = IBM_OS try: run('crtlib test1') except: print('................. Library exists') def test(): env.shell = IBM_PASE run('uname -s')
in this code:
1. we define 2 shells: "system" and "bash", so we can call IBMi commands or PASE commands depending of our fabric task.
2. We define 2 hosts to run the task.
3. Add an exception to handle an error.
4. In each task, it is possible to change the environmental settings of the type of BASH.
To run this code > fab set_hosts check_lib test
C:\pythonmanagement>fab set_hosts check_lib test [disibic21] Executing task 'check_lib' [disibic21] run: crtlib test1 [disibic21] Login password for 'ACL': [disibic21] out: CPF2111: Library TEST1 already exists. [disibic21] out: Fatal error: run() received nonzero return code 255 while executing! Requested: crtlib test1 Executed: system "crtlib test1" Aborting. ................. Library exists [disibic22] Executing task 'check_lib' [disibic22] run: crtlib test1 [disibic22] out: CPF2111: Library TEST1 already exists. [disibic22] out: Fatal error: run() received nonzero return code 255 while executing! Requested: crtlib test1 Executed: system "crtlib test1" Aborting. ................. Library exists [disibic21] Executing task 'test' [disibic21] run: uname -s [disibic21] out: OS400 [disibic21] out: [disibic22] Executing task 'test' [disibic22] run: uname -s [disibic22] out: OS400 [disibic22] out: Done. Disconnecting from disibic21... done. Disconnecting from disibic22... done.
As you noticed, im writing 2 tasks in 1 single file. This is because by default Fabric has a single, serial execution method, thought there is an alternative parallel mode.
The default mode perform the following:
- set_host
- check_lib in node1
- check_lib in node2
- test in node1
- test in node2
> Fab -H myserver1,myserver2 test
This method is very simplistic for now, but useful to understand Fabric.If your number of servers is huge or tasks need time to perform, it is better to use a parallel approach, but i would not explain it for now. Check in Parallel Fabric
Other things we could do is to get and put files into our file systems (with secure copy) and deploy IFS files, software, PTFs, etc.
There is also a very interesting project for a web-interface for Fabric to deploy code stored in a repository and logs of deployments are stored. This project is called FabricBolt.
This is everything for this post...i added some examples on my github
No hay comentarios:
Publicar un comentario