<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Bislon A Zulu</title>
    <description>The latest articles on DEV Community by Bislon A Zulu (@bislon_azulu_8947d844c5c).</description>
    <link>https://dev.to/bislon_azulu_8947d844c5c</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F2023492%2F49e8975b-df9d-48ba-99c5-072bd86f9221.jpg</url>
      <title>DEV Community: Bislon A Zulu</title>
      <link>https://dev.to/bislon_azulu_8947d844c5c</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/bislon_azulu_8947d844c5c"/>
    <language>en</language>
    <item>
      <title>HandyHub - Your Go-To Tradesman Directory</title>
      <dc:creator>Bislon A Zulu</dc:creator>
      <pubDate>Wed, 18 Sep 2024 19:00:15 +0000</pubDate>
      <link>https://dev.to/bislon_azulu_8947d844c5c/handyhub-your-go-to-tradesman-directory-9c2</link>
      <guid>https://dev.to/bislon_azulu_8947d844c5c/handyhub-your-go-to-tradesman-directory-9c2</guid>
      <description>&lt;h1&gt;
  
  
  HandyHub: Connecting Clients with Reliable Tradesmen
&lt;/h1&gt;

&lt;h2&gt;
  
  
  Project Purpose
&lt;/h2&gt;

&lt;p&gt;HandyHub is designed to bridge the gap between clients and skilled tradesmen in their area. Our goal is to streamline the process of finding and hiring tradesmen, making it easier for clients to access essential services like plumbing, electrical work, and repairs through a user-friendly platform.&lt;/p&gt;

&lt;h2&gt;
  
  
  Team Members, Roles, and Timeline
&lt;/h2&gt;

&lt;p&gt;The HandyHub project is part of the ALX SE program’s final project, and the development team consists of:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Bislon Zulu (Myself)&lt;/strong&gt;: Responsible for backend development, including database design, API creation, and overall project architecture.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Project Timeline&lt;/strong&gt;: Development is ongoing, with the Minimum Viable Product (MVP) currently complete and under review.&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Who Is HandyHub For?
&lt;/h2&gt;

&lt;p&gt;HandyHub serves two primary audiences:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Clients&lt;/strong&gt;: Homeowners, businesses, or anyone in need of tradesmen services such as electricians, plumbers, or contractors.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Tradesmen&lt;/strong&gt;: Skilled workers looking to expand their client base by listing their services and being discovered by potential clients.&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  My Personal Focus
&lt;/h2&gt;

&lt;p&gt;As the sole engineer, my main focus has been on building the backend infrastructure for HandyHub. This includes ensuring smooth API integration and managing the database. The project is designed to provide a mobile-friendly experience, using technologies like Flask and PostgreSQL to power its core functionality.&lt;/p&gt;

&lt;p&gt;HandyHub helps clients easily find tradesmen based on location and specialization, much like how apps like Uber connect riders with drivers. &lt;/p&gt;

&lt;p&gt;When I started working on HandyHub, it wasn’t just another project to tick off my list; it was a personal mission. As I walked through my neighborhood, I often saw outdated flyers and makeshift signs advertising services. It struck me that there had to be a better way to connect people with the services they need. Many skilled tradesmen were limited to a small radius for advertising their services, while clients struggled to find reliable professionals. HandyHub was created to address these issues by offering a modern, efficient way to connect people with the services they require.&lt;/p&gt;

&lt;h2&gt;
  
  
  Project Summary
&lt;/h2&gt;

&lt;p&gt;HandyHub successfully simplifies the process of finding and connecting with skilled tradesmen. The platform allows service providers to reach a broader audience and offers users an easy way to find reliable professionals. By combining technology with community needs, HandyHub provides both a directory and a rating system to ensure trust between clients and tradesmen.&lt;/p&gt;

&lt;h2&gt;
  
  
  Result of the Project
&lt;/h2&gt;

&lt;p&gt;The final result is a web application where users can search for tradesmen by location and specialization. Tradesmen can create profiles showcasing their skills, certifications, and contact details. This modern approach eliminates the need for outdated advertising methods like flyers.&lt;/p&gt;

&lt;h2&gt;
  
  
  Technologies Used
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Frontend&lt;/strong&gt;: We chose HTML5, CSS3, and JavaScript to build a mobile-first, responsive interface. This stack was selected for its flexibility and the opportunity to deepen our understanding of core JavaScript principles and responsive design techniques without additional frameworks.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Backend&lt;/strong&gt;: Flask and Python were selected for their lightweight nature, which facilitates the development of REST APIs that meet our project’s needs. Flask’s minimalistic approach allowed us to maintain control over the application’s structure.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Database&lt;/strong&gt;: PostgreSQL was chosen for its robust relational data management and strong community support. It efficiently handles structured data, such as tradesman profiles and client reviews, ensuring data integrity.&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  The Most Difficult Technical Challenge
&lt;/h2&gt;

&lt;p&gt;The most challenging aspect of this project was working within the Windows Subsystem for Linux (WSL). Although WSL was chosen to maintain a Linux-based workflow consistent with other ALX tasks, it presented a steep learning curve. Configuring and integrating tools and services within WSL proved difficult, especially with issues related to PostgreSQL and network settings. Ultimately, I decided to switch to development directly in Windows to expedite the process and meet deadlines. This experience, though challenging, contributed significantly to my growth as a developer.&lt;/p&gt;

&lt;h2&gt;
  
  
  Conclusion
&lt;/h2&gt;

&lt;p&gt;Working on HandyHub has been a rewarding journey, blending technology with community service. I’m proud of how the project has evolved from an initial idea to a functional platform that connects tradesmen with clients. Despite challenges, especially with WSL, the project has been a valuable learning experience.&lt;/p&gt;

&lt;p&gt;I’m a passionate software engineer dedicated to creating solutions that positively impact the community. You can explore the HandyHub project on &lt;a href="https://github.com/balldash/HandyHub" rel="noopener noreferrer"&gt;GitHub&lt;/a&gt;. For further connections, feel free to reach out to me on &lt;a href="https://www.linkedin.com/in/bislonzulu/" rel="noopener noreferrer"&gt;LinkedIn&lt;/a&gt;.&lt;/p&gt;

</description>
      <category>webdev</category>
      <category>beginners</category>
      <category>programming</category>
      <category>python</category>
    </item>
    <item>
      <title>Postmortem: HandyHub Service Outage</title>
      <dc:creator>Bislon A Zulu</dc:creator>
      <pubDate>Tue, 03 Sep 2024 22:40:11 +0000</pubDate>
      <link>https://dev.to/bislon_azulu_8947d844c5c/postmortem-handyhub-service-outage-kde</link>
      <guid>https://dev.to/bislon_azulu_8947d844c5c/postmortem-handyhub-service-outage-kde</guid>
      <description>&lt;p&gt;Issue Summary&lt;br&gt;
Duration: August 25, 2024, 14:00 - 16:30 GMT+2&lt;br&gt;
Impact: HandyHub’s search and browse functionality was down, affecting 60% of users. Users experienced slow response times and were unable to search for tradesmen.&lt;br&gt;
Root Cause: A misconfigured API Gateway routing rule caused requests to loop indefinitely, leading to high server load and eventual service downtime.&lt;/p&gt;

&lt;p&gt;Timeline&lt;br&gt;
14:00 - Issue detected via monitoring alert indicating high server load.&lt;br&gt;
14:05 - Initial investigation by on-call engineer; assumption was a DDoS attack.&lt;br&gt;
14:15 - Misleading path: Network team investigated potential external threats.&lt;br&gt;
14:30 - Customer complaints confirmed the issue was affecting search functionality.&lt;br&gt;
14:45 - Escalated to backend engineering team.&lt;br&gt;
15:00 - Identified misconfigured API Gateway routing rule.&lt;br&gt;
15:15 - Applied temporary fix by disabling the problematic rule.&lt;br&gt;
15:45 - Full resolution by correcting the routing configuration.&lt;br&gt;
16:30 - Services fully restored and monitored for stability.&lt;br&gt;
Root Cause and Resolution&lt;br&gt;
Root Cause: The API Gateway had a misconfigured routing rule that caused requests to loop back to the gateway instead of being routed to the appropriate backend service. This misconfiguration led to an exponential increase in server load, causing the search and browse functionality to become unresponsive.&lt;/p&gt;

&lt;p&gt;Resolution: The issue was resolved by first disabling the problematic routing rule to stop the looping requests. Then, the routing configuration was corrected to ensure that requests were properly directed to the backend services. A thorough review of all routing rules was conducted to prevent similar issues in the future.&lt;/p&gt;

&lt;p&gt;Corrective and Preventative Measures&lt;br&gt;
Improvements:&lt;/p&gt;

&lt;p&gt;Implement stricter validation and testing of API Gateway configurations before deployment.&lt;br&gt;
Enhance monitoring to detect unusual traffic patterns indicative of routing issues.&lt;br&gt;
Conduct regular audits of routing rules and configurations.&lt;br&gt;
Tasks:&lt;/p&gt;

&lt;p&gt;Patch API Gateway: Update the API Gateway to the latest version to include any bug fixes and improvements.&lt;br&gt;
Add Monitoring: Implement detailed monitoring on API Gateway traffic to detect anomalies.&lt;br&gt;
Automate Testing: Develop automated tests for API Gateway configurations to catch misconfigurations early.&lt;br&gt;
Review and Document: Conduct a comprehensive review of current routing rules and document them thoroughly.&lt;br&gt;
Training: Provide training for engineers on best practices for configuring and managing API Gateways.&lt;br&gt;
By addressing these measures, we aim to improve the reliability and stability of HandyHub’s services, ensuring a better user experience and reducing the likelihood of similar outages in the future.&lt;/p&gt;

&lt;p&gt;Fun Fact: During the outage, our team discovered that the coffee machine was also down. Coincidence? We think not! ☕🚨&lt;/p&gt;

&lt;p&gt;Remember, always keep your API Gateway and your coffee machine in top shape! 😉&lt;/p&gt;

</description>
    </item>
  </channel>
</rss>
