Skip to main content

Cloud adoption, paradigm shift and watch list

So while some of organisations may have security concerns, others may want to take benefit from economy of scale and may want to migrate from on-premises (in-house or colocated) hosting to cloud infrastructures such as Amazon Web Services (AWS), Google Cloud platform (GCP) or Microsoft's Azure etc.

In reality, security should be your real concern for all types of infrastructures. While public cloud is open to world and requires stringent security controls within cloud, your on-premises data stored on encrypted disks requires more or local access and physical security controls.

There are benefits of cloud and flexibility or pay as much as you use would suit most of its tenants. There are cases where cloud could become too expensive for certain applications where on-premises infrastructure may be beneficial for your organisation, however you are talking an extreme scale here.

Majority of enterprise solutions are still hosted on on-premises infrastructure and some are sceptic about cloud maturity and others are waiting for right time or right person to make the shift. There are also some adopters who followed the time and speed but without a complete understanding on benefits of cloud ecosystem the migrations resulted in dearer and more complex solutions since they simply lifted and shifted application on like for like infrastructure in the cloud.

So without mentioning any names if a Fortune 100 company moved from cloud ecosystem to in-house infrastructure, they would have gone through the learning curve of most advanced cloud architecture and would have been taking full advantage or benefit of cloud. The reason they would move to on-premises would be further cost savings and they are well equipped to create that mini cloud in-house cutting down on cloud provider costs.

Cloud adoption should be on everyone's agenda these days however to check thermometer and make it reality you should have the target model in your mind and fully understand how you will get there. Working on on-premises for years has created many experts in the field from operations to management and while cloud is pretty much same infrastructure in the cloud it really is the next generation and an enormous mindshift for users of legacy systems. If you are not there yet, there is nothing wrong to play with it at small cost but get your vision and economies right before you make the final decision.

So the questions you should be asking yourself when deciding migration to Cloud should include below;

a) Solution Architecture

You have to have right architecture to be able to run your solution or application. However the better your architecture is, the resilient, the scaleable, the reliable, the economical, the secure and the innovative your solution will be.

b) Application design

The application designed to run on specific hardware or computers may not be as cost effective as if you redesign your application to be able to interact with cloud and take advantage of modern technologies such as serverless architecture including AWS Lambda or Google Cloud Function.

c) Security & Governance

Cloud security can be as secure as you design and as weak as you leave. No matter what type of business you run the security should be paramount and there should be no compromise in investing on security. While you may want to deliver latency based content, you may be required to maintain high availability in certain regions. 

d) Test/ DR/ Resilience & data protection

You may or may not have dedicated UAT, development or DR environments in the past but it will be good idea to introduce these while migrating to the cloud as it is today's requirement and you can now do it in cloud at very low cost. If you already had these, the cloud works differently and these environments need to be factored within design and architecture of your solution.

e) Operational management

The changes in cloud can all be automated or in other words scripted including the pre-test exact changes in very much like for like temporary environment at fraction of cost. However it all needs an entirely different approach on how you plan and implement those changes. Backup and patching type activities will have to become more sophisticated and automated processes that work without failing. The monitoring and alarming will take a different direction on what events may trigger incidents and how many of those can trigger self healing system. Your operational resources will have to be trained up to become DevOps engineers rather than technology isolated engineers. It may also reduce the number of resources you require to manage the infrastructure but you'll need more architects to continuously improve and optimise your environment.

f) Continuously improvement

While I recommend you to invest as much time and resources as you can do to start an ideal cloud based architecture and even if you get it perfect for once I guarantee there will always be improvements and optimisations you can make. You should not hesitate to invest in good architects always working on your infrastructure as they will make it more reliable, more optimised and more economical every day.

g) Staged approach

Unless you have the beans and brain, you could take staged approach by transferring your UAT, development and DR environments to cloud where you can spin up solution for the time and scale you require at a small cost. This also gives you opportunity to understand what non-conventional approaches you can adopt while working on cloud and eventually you will find it more sensible to roll-out your production environment within cloud more efficiently and more economically.



Popular posts from this blog

Useful website performance and load testing tools

http://tsung.erlang-projects.org/ http://httpd.apache.org/docs/2.0/programs/ab.html http://phantomjs.org/ https://developers.google.com/speed/pagespeed/ http://servermonitoringhq.com/blog/how_to_quickly_stress_test_a_web_server https://code.google.com/p/httperf/ http://loadimpact.com/ http://www.paessler.com/webstress http://loaduiweb.org/ http://en.wikipedia.org/wiki/Web_server_benchmarking http://en.wikipedia.org/wiki/Load_testing http://www.loadui.org/ http://www.loadtestingtool.com/index.shtml http://www.appdynamics.com/blog/devops/load-testing-tools-explained-the-server-side/

Copy files and folders using SCP with spaces in path

Copying data from one system to other with file or folder names that contain spaces in path can be achieved using this guide. In this case I am copying data from Macbook to Windows 10 computer. In order to copy the data easily it is better to use bash commands. Windows computer can support WSL (Windows subsystem for Linux) and you can run one of few linux distributions to use shell commands. I have Ubuntu set up within my Windows 10 using WSL. If you do not have WSL, you can set it up using my guide here . The copy can be performed in two ways: 1) Using SCP Source (MacOs) path: /home/Users/username/Documents/data extract from 2020/ First of all you add escape sequence to the path so it will become:  /home/Users/me/Documents/data\ extract\ from\ 2020/ . While this works on local system for SCP you'll have to double the escape sequences by replacing \ with \\, as below. Figure out your source computer IP address using "ifconfig" command. Now using scp command on target syst

TrueCrypt on macOS X Mojave 10.14

If you have updated your macOS recently to Mojave otherwise known as verison 10.14 you may not be able to install the last version of Truecrypt in order to access your old volumes encrypted with Truecrypt software. This article will guide you to get this working on your MacOS v10.14 (Mjoave) . Download the package from  https://truecrypt.ch/downloads/  or  https://www.truecrypt71a.com/downloads/ . Find downloaded package using Finder in your HDD/Users/username/Downloads folder and will look like  TrueCrypt 7.1a Mac OS X.dmg . Open file location in Finder and open or double click on  TrueCrypt 7.1a Mac OS X.dmg . This will mount Truecrypt 7.1a and will have Truecrypt 7.1a.mpkg in it. Drag the package T rueCrypt 7.1a.mpkg and drop in your Downloads folder. From Locations in Finder you can eject your TrueCrypt mount. Now go to your Downloads location, find the file  TrueCrypt 7.1a.mpkg , right click and select Show Package Contents . Find the file Contents/distribution.di