<?xml version="1.0" encoding="utf-8"?><feed xmlns="http://www.w3.org/2005/Atom"><title type="text">Blog posts by Szołkowski Blog</title><link href="http://world.optimizely.com" /><updated>2026-04-13T09:00:00.0000000Z</updated><id>https://world.optimizely.com/blogs/szokowski-blog/</id> <generator uri="http://world.optimizely.com" version="2.0">Optimizely World</generator> <entry><title>OptiPowerTools.Hangfire 2.0.0: CMS 13 Support and Sample Jobs</title><link href="https://szolkowski.github.io/2026/04/13/OptiPowerTools-Hangfire-2.0-CMS-13-Support" /><id>When I released OptiPowerTools.Hangfire back in March, it targeted Optimizely CMS 12. With CMS 13 now out and running on .NET 10, it was time to bring the package along. Version 2.0.0 adds full CMS 13 support, and I also shipped 1.0.1 on the CMS 12 line with sample jobs to help people get started faster.</id><updated>2026-04-13T09:00:00.0000000Z</updated><summary type="html">Blog post</summary></entry> <entry><title>Running the Optimizely CMS 13 Alloy Site on macOS with Docker</title><link href="https://szolkowski.github.io/2026/04/09/optimizely-alloy-on-macos-apple-silicon" /><id>In my first Apple Silicon post and the 2025 revisit I covered running an Optimizely Foundation site on an M1/ARM Mac. This time I wanted to try something smaller — the official Alloy template site for Optimizely CMS 13, which ships with a ready-made Docker Compose setup. On Windows it works out of the box, but on macOS with Apple Silicon a few adjustments are needed before everything runs smoothly.</id><updated>2026-04-09T09:00:00.0000000Z</updated><summary type="html">Blog post</summary></entry> <entry><title>OptiPowerTools.Hangfire: A Drop-in Hangfire Integration for Optimizely CMS 12</title><link href="https://szolkowski.github.io/2026/03/31/OptiPowerTools.Hangfire-A-Drop-in-Hangfire-Integration-for-Optimizely-CMS-12" /><id>Back in 2024, I wrote a post on Adding Hangfire to Episerver/Optimizely CMS 12, walking through each step of integrating Hangfire into an Optimizely project — the authorization filter, the controller, the view with an iframe, the menu provider, the startup wiring. It was a fair amount of boilerplate, but it worked and people found it useful.</id><updated>2026-03-31T08:00:00.0000000Z</updated><summary type="html">Blog post</summary></entry> <entry><title>Catalog Traversal with Hangfire. Part 3: Advanced Job Management</title><link href="https://szolkowski.github.io/2026/03/03/Catalog-Traversal-with-Hangfire-Part-3-Advanced-Job-Management" /><id>In Part 1, I showed how to build a memory-efficient catalog traversal service, and in Part 2, I demonstrated practical patterns using Optimizely’s built-in scheduled jobs.</id><updated>2026-03-03T08:00:00.0000000Z</updated><summary type="html">Blog post</summary></entry> <entry><title>Catalog Traversal in Action. Part 2: Real-World Scheduled Job Patterns</title><link href="https://szolkowski.github.io/2026/02/24/Catalog-Traversal-in-Action-Part-2-Real-World-Scheduled-Job-Patterns" /><id>In my previous post, I showed how to build a memory-efficient catalog traversal service for Optimizely Commerce. The service uses streaming to process large catalogs without loading everything into memory at once.</id><updated>2026-02-24T08:00:00.0000000Z</updated><summary type="html">Blog post</summary></entry> <entry><title>Memory-Efficient Catalog Traversal in Optimizely Commerce. Part 1: Building the Service</title><link href="https://szolkowski.github.io/2026/02/18/Memory-Efficient-Catalog-Traversal-in-Optimizely-Commerce-Part-1-Building-the-Service" /><id>If you’ve worked with Optimizely Commerce for any length of time, you’ve probably faced this scenario: you need to process an entire product catalog in a scheduled job. Maybe you’re syncing to an external PIM system, exporting data for analytics, or performing bulk updates. The straightforward approach of loading all products into memory works fine for small catalogs, but once you hit thousands of products, things start to get uncomfortable.</id><updated>2026-02-18T08:00:00.0000000Z</updated><summary type="html">Blog post</summary></entry> <entry><title>Memory-Efficient Catalog Traversal in Optimizely Commerce. Part 1: Building the Service</title><link href="https://szolkowski.github.io/2026/01/18/Memory-Efficient-Catalog-Traversal-in-Optimizely-Commerce-Part-1-Building-the-Service" /><id>If you’ve worked with Optimizely Commerce for any length of time, you’ve probably faced this scenario: you need to process an entire product catalog in a scheduled job. Maybe you’re syncing to an external PIM system, exporting data for analytics, or performing bulk updates. The straightforward approach of loading all products into memory works fine for small catalogs, but once you hit thousands of products, things start to get uncomfortable.</id><updated>2026-01-18T08:00:00.0000000Z</updated><summary type="html">Blog post</summary></entry> <entry><title>Quiet Performance Wins: Scheduled Job for SQL Index Maintenance in Optimizely</title><link href="https://szolkowski.github.io/2025/10/08/Quiet-Performance-Wins-Scheduled-Job-for-SQL-Index-Maintenance-in-Optimizely" /><id>As Optimizely CMS projects grow, it’s not uncommon to introduce custom tables—whether for integrations, caching, or specialized business logic. But with great schema comes great responsibility: SQL Server indexes and statistics need love too.</id><updated>2025-10-08T08:00:00.0000000Z</updated><summary type="html">Blog post</summary></entry> <entry><title>How to automatically remove orphaned Opti jobs from the DB</title><link href="https://szolkowski.github.io/2025/09/04/automatically-removing-orphaned-jobs-from-db" /><id>Optimizely CMS provides a simple yet powerful built-in job system that handles most standard scheduling scenarios with ease. Developers can easily implement these jobs to run automatically on a defined schedule or trigger them manually through the CMS interface. From my experience as an Optimizely/Episerver developer, manual jobs are especially useful for one-off operations or bulk content updates. Typically, these jobs serve a temporary purpose and are removed from the codebase in subsequent releases once they’ve fulfilled their role.</id><updated>2025-09-04T08:00:00.0000000Z</updated><summary type="html">Blog post</summary></entry> <entry><title>Tunning Application Insights telemetry filtering in Optimizely</title><link href="https://szolkowski.github.io/2025/06/12/episerver-and_application_insights_filters" /><id>Application Insights is a cloud-based service designed to monitor web applications, providing insights into performance, errors, and user behavior, which integrates very well with the Optimizely CMS/Commerce solution and is included in the default DXP experience. However, like any generic tool for complex systems, it can be tuned to work even better for specific platforms and projects.</id><updated>2025-06-12T08:00:00.0000000Z</updated><summary type="html">Blog post</summary></entry> <entry><title>Running full Optimizely development setup on M1 (ARM) based machine</title><link href="https://szolkowski.github.io/2025/05/26/episerver-on-apple-silicon-2025" /><id>A few years ago I posted post about how to run Optimizely/Episerver on M1 (ARM) based machine, so I think it is high time to revisit and check what did change.</id><updated>2025-05-26T08:00:00.0000000Z</updated><summary type="html">Blog post</summary></entry> <entry><title>Adding Hangfire to Episerver/Optimizely CMS 12</title><link href="https://szolkowski.github.io/2024/07/31/adding-hangfire-to-epi-12" /><id>Episerver/Optimizely contains build ScheduledJobs support which does its job for internal EPI jobs and simple custom cases, however, when the app grows and we need more and more jobs it fails behind dedicated solutions.</id><updated>2024-07-31T12:57:48.0000000Z</updated><summary type="html">Blog post</summary></entry> <entry><title>Adding Hangfire to Episerver/Optimizely CMS 12</title><link href="https://szolkowski.github.io/2024/07/11/adding-hangfire-to-epi-12" /><id>Episerver/Optimizely contains build ScheduledJobs support which does its job for internal EPI jobs and simple custom cases, however, when the app grows and we need more and more jobs it fails behind dedicated solutions.</id><updated>2024-07-11T10:46:48.0000000Z</updated><summary type="html">Blog post</summary></entry> <entry><title>Add SonarCloud/SonarQube to Episerver/Optimizely 12 project using Github actions</title><link href="https://szolkowski.github.io/2023/08/15/add-sonarcloud-to-epi-12-pipeline" /><id>In my previous post Add Github pipelines/workflows to Episerver 12 project I have briefly explained how to add simple pipeline/workflow to Episerver/Optimizely 12 project. Having project build for each PR and on main branch push is nice improvement, but we can make it even better. For this example I will add SonarCloud integration to my existing workflow from my previous post. You can see it on my Foundation fork - it will be using Github actions on each pull request and on main branch.</id><updated>2023-08-15T17:31:48.0000000Z</updated><summary type="html">Blog post</summary></entry> <entry><title>Add Github pipelines/workflows to Episerver 12 project</title><link href="https://szolkowski.github.io/2022/07/30/add-github-pipeline-to-epi-12" /><id>With Episerver 12 moving to .NET 5/6 civilization come to devops handling of Episerver projects and we can easily integrate modern CI approaches using pipelines. For this example I will add simple building of my Foundation fork using Github version of pipelines called “workflows” on each pull request and on main branch.</id><updated>2022-07-30T15:31:48.0000000Z</updated><summary type="html">Blog post</summary></entry> <entry><title>Episerver Foundation on Apple Silicon (M1)!</title><link href="https://szolkowski.github.io/2022/07/28/episerver-on-apple-silicon" /><id>With introduction of .NET 6 Episerver/Optimizely packages developing it on M1 machine is now possible, however there are still some problems with initial configuration, but lets not go ahead of ourself.</id><updated>2022-07-28T19:29:19.0000000Z</updated><summary type="html">Blog post</summary></entry></feed>