Azure Backup Overview – CodeProject

Azure Backup

Azure Backup is the Azure-based service which you can use to back up and restore your data in the Microsoft cloud. Azure Backup is a reliable, safe and competitively priced cloud-based backup solution which can be used to replace on-premises or off-site backup solutions. There are multiple components in Azure Backup which can be downloaded and deployed depending on what you want backed up. All of these components can be used to back up data to a Recovery Services vault in Azure, regardless of whether you’re protecting data on your premises or in the cloud.

Source: Azure Backup Overview – CodeProject

Hyper-converged infrastructure – Wikipedia

Hyper-converged infrastructure (HCI) is a software-defined IT infrastructure that virtualizes all of the elements of conventional “hardware-defined” systems. HCI includes, at a minimum, virtualized computing (a hypervisor), a virtualised SAN (software-defined storage) and virtualized networking (software-defined networking). HCI typically runs on commercial off-the-shelf (COTS) servers.
The primary difference between converged infrastructure (CI) and hyper-converged infrastructure is that in HCI, both the storage area network and the underlying storage abstractions are implemented virtually in software (at or via the hypervisor) rather than physically, in hardware. Because all of the software-defined elements are implemented within the context of the hypervisor, management of all resources can be federated across all instances of a hyper-converged infrastructure.

Source: Hyper-converged infrastructure – Wikipedia

Design Patterns for Microservices – DZone Microservices

Microservice architecture has become the de facto choice for modern application development. Though it solves certain problems, it is not a silver bullet. It has several drawbacks and when using this architecture, there are numerous issues that must be addressed. This brings about the need to learn common patterns in these problems and solve them with reusable solutions. Thus, design patterns for microservices need to be discussed. Before we dive into the design patterns, we need to understand on what principles microservice architecture has been built:

  1. Scalability
  2. Availability
  3. Resiliency
  4. Independent, autonomous
  5. Decentralized governance
  6. Failure isolation
  7. Auto-Provisioning
  8. Continuous delivery through DevOps

Applying all these principles brings several challenges and issues. Let’s discuss those problems and their solutions.

Source: Design Patterns for Microservices – DZone Microservices

ETL with Spring Cloud Data Flow | Baeldung

1. Overview Spring Cloud Data Flow is a cloud-native toolkit for building real-time data pipelines and batch processes. Spring Cloud Data Flow is ready to be used for a range of data processing use cases like simple import/export, ETL processing, event streaming, and predictive analytics. In this tutorial, we’ll learn an example of real-time Extract Transform and Load (ETL) using a stream pipeline that extracts data from a JDBC database, transforms it to simple POJOs and loads it into a MongoDB.

Source: ETL with Spring Cloud Data Flow | Baeldung

Your Data Protection and Disaster Recovery Checklist – DZone Security

In the pursuit of data protection, businesses nowadays face more hurdles in the security landscape than ever before. We know there’s a growing demand for reliable, scalable infrastructure, but issues with downtime are complicating businesses’ confidence in their existing systems, implicating all-too-precious data in the process.

Source: Your Data Protection and Disaster Recovery Checklist – DZone Security

Improving But Not Learning by Doing – Marginal REVOLUTION

One aspect of knowledge transmission which is more difficult to study is the role of the genius. Cultural generation can get stuck in local optima. Only the genius can see over the valley to the mountain. The occasional genius may have been important even in knowledge generation in the pre-science era. In addition, these kinds of cultural evolution processes work best when feedback is quick and clear. Lengthen the time between input and output and all bets are off. Still this peculiar experiment illustrates how much cultural transmission can achieve and how theory can so dominate our thinking that it reduces vital experimentation.

Source: Improving But Not Learning by Doing – Marginal REVOLUTION

How to Improve Critical Thinking as a Programmer – DZone Agile

  • Create mind maps with technical tools. First, you can start using tech tools to visualize your thought processes, gain access to new information, and think more abstractly about the problems you face. For example, you can create interactive mind maps that let you organize different categories of thoughts and related subjects, so you can visualize a high-level rundown of the problem at a glance. From there, it will be easier to spot flaws and brainstorm solutions.
  • See problems through others’ eyes. Thinking laterally, or “outside the box,” is the simplest way to think critically. We’re often limited by our own perceptions, experiences, and cognitive biases, and the best way to remove those filters is to see the problem through someone else’s eyes. There are many ways to do this, but the simplest is simply picking someone’s brain about the problem you’re facing—they may bring to light ideas or avenues of thought you hadn’t previously considered.

Source: How to Improve Critical Thinking as a Programmer – DZone Agile

Microservices: Why Asynchronous Communications? – DZone Microservices

Issues with Asychronous Communication

  1. How should a long-running process on the server be presented to the client? If the server is experiencing a high peak in demand, or if the resources are scarce, chances are the client will be affected too. Should it just wait? Should it timeout? How should the client interpret this situation?
  2. When an upstream dependency (server A calls server B) is unavailable, should the client care? Why should the client be sensitive to our ecosystem. From its standpoint, it reached the server, the rest is all internals.
  3. Guaranteed response time: what if I told you that my server will respond in O(1) no matter what. How is that for usability?
  4. What if the client does not need a response right away? Assume that I place my order in the context of an ecommerce application. I know what I ordered, I know how much I paid and I know when and where I will be delivered. Why should I hang in there until the server does all its housekeeping (updating product stocks, notifying the warehouse, ….)
  5. Better yet, you don’t know whom you’re talking to but you’re sure that your request will be honored. I always feel this way when I need an administrative paper. It seems that I always need to find the right person, and more importantly, at the right time. I always wished I could just submit my request to a “mailbox” and just head home and be sure that it will be fulfilled.
  6. My request is more urgent that yours. Now you’re in a nuclear power plant, and maintenance staff keeps track of the major events there by posting these events to the monitoring application, business as usual, cooling check… Suddenly, Mr Hero realizes that a major event that jeopardizes the safety of the whole neighborhood is about to take place, and posts an emergency stop payload, now I wouldn’t like to be the one who processes a ventilation check while making the emergency stop wait.

Source: Microservices: Why Asynchronous Communications? – DZone Microservices

Microservices: Why Asynchronous Communications? – DZone Microservices

Why Asynchronous?

Or why stick to synchronous communications should we ask? It is true that synchronous communications has come to be regarded as the de facto pattern to exchange information between any two endpoints. Think of TCP, HTTP, FTP … . It does indeed exhibit the following advantages:

  1. Simpler reasoning and tracing: Everything starts when an outbound request in made from the client, and we can step through the whole process all the way until the request is processed by the server and a response is sent accordingly.
  2. “Instantaneous” feedback: When a client breaks the contract, or the server deems the current request as invalid, feedback is sent right away to the client. This can take the form of response codes, redirects, or event stack traces.
  3. Natural: In the sense that we like to think about thing A happens before thing B, or thing C happens as a consequence of thing B.
  4. Translates directly to models: We’re all used to sequence diagrams on UML, and very few people can tell from the back of their head how asynchronous calls are modeled. Instead, we like to think of them as a succession of synchronous calls.

Source: Microservices: Why Asynchronous Communications? – DZone Microservices

Trillion-Dollar Teamwork: Goal-Setting With OKRs – DZone Agile

For this reason, it is absolutely critical that KRs be specific enough to be measurable (this is where KPIs come in), and that they contain a numerical element that makes them easier to form metrics for. In fact, one technique to ensure KR accuracy is creating KRs according to the S.M.A.R.T. method. The S.M.A.R.T. method dictates that goals should be: Specific; Measurable; Achievable; Relevant; and Timebound.

Source: Trillion-Dollar Teamwork: Goal-Setting With OKRs – DZone Agile