NewRelic Alternative For Monitoring Laravel Octane

Valerio Barbera

I recently had the opportunity to discuss the adoption of Inspector by a team of developers based in Brazil. At the time they were using NewRelic to monitor their applications, but found that it was not compatible with Laravel Octane.

Ever since Laravel Octane was released I have thoroughly studied its internal dynamics to make sure that Inspector Laravel package continues to work as usual. Due to its characteristics I always suspected that Octane could cause a lot of headaches for “infrastructure oriented” monitoring platforms.

Let me give you some technical details.

Introduction to Laravel Octane

Laravel Octane is a high-performance application server for Laravel, designed to significantly boost the performance of Laravel applications. It was introduced in Laravel 8.x and provides a way to serve Laravel applications using high-performance application servers like Swoole and RoadRunner.

As the official documentation says: 

Octane boots your application once, keeps it in memory, and then feeds it requests at supersonic speeds.

Laravel documentation

Your Laravel application runs inside a long-running process which can create problems for the monitoring agents installed on your machine to know what is happening inside it.

Install Laravel Octane

To install Laravel Octane, run the following command in your terminal:

composer require laravel/octane

Then, install the desired server (Swoole or RoadRunner). I choose swoole for this demostration:

composer require swoole/ide-helper
php artisan octane:install --server=swoole

Running the Laravel Octane server

Once installed, you can run Octane using the following Artisan command:

php artisan octane:start

This will start a Swoole or RoadRunner-based server, depending on your configuration. Now, every request that comes in will be served by this long-running server, significantly reducing the overhead of starting the Laravel application for each HTTP request.

Internal workflow of Laravel Octane

To better understand its characteristics let’s break down the internal workflow in a simplified way.

Server Start:

  • Octane boots Laravel once and keeps it in memory.
  • Workers (child processes) are spawned to handle requests.
  • These workers run in a loop, processing requests in the background.

Request Handling:

  • When an HTTP request arrives, it is assigned to a worker.
  • The worker processes the request (e.g., resolving routes, handling controller logic).
  • The worker returns the response to the client.

Concurrency Management:

  • If multiple requests arrive simultaneously, they are handled by different workers concurrently.
  • Swoole or RoadRunner ensures asynchronous I/O operations to maximize performance and responsiveness.

Task Dispatching:

  • Octane can dispatch background tasks (e.g., queues or asynchronous jobs) to reduce blocking in the main request flow.

Here is a graphical representation of these steps:

┌──────────────┐  1. Start Laravel App
│   Artisan    │─────────────────────┐
│ octane:start │                     │
└───────┬──────┘                     ▼
        │                  ┌─────────────────┐
        │ 2. Bootstrap App │  Laravel Kernel │
        │                  └─────────────────┘
        │                            │
        ▼                            ▼
┌─────────────────────────────┐  ┌───────────────────┐
│  Start Workers in Pool      │  │ Framework Loaded  │
└──────────────┬──────────────┘  └───────────────────┘
               │
               ▼
        ┌─────────────┐
        │ Worker Pool │─────┐
        └─────────────┘     │
                            ▼
                   ┌──────────────────┐
                   │ Incoming Request │
                   └─────┬────────────┘
                         │
              ┌──────────▼───────────┐
              │ Assign Request to    │
              │ Free Worker          │
              └──────────┬───────────┘
                         │
                         ▼
           ┌─────────────────────────┐
           │ Process Request (Worker)│
           └───────────┬─────────────┘
                       │
                       ▼
              ┌─────────────────┐
              │ Return Response │
              └─────────────────┘
                       │
                       ▼
             ┌──────────────────┐
             │ Worker Ready for │
             │ Next Request     │
             └──────────────────┘

How to monitor Laravel with Octane

NewRelic as many other monitoring platform try to monitor your application using monitoring agents installed on the server, at the infrastructure level. So outside your application.

Since Laravel Octane execute your application in a long-running process that never ends, these kind of agents can’t be able to monitor what’s happening inside.

Inspector instead works with a simple Laravel package so it’s installed inside your application. You don’t need to install anything on the VM or the cloud infrastructure. It doesn’t matter where your application is running. Inspector is integrated with your framework, not with the server.

Recently the package has surpassed 1.2 million installations. Stats from Packagist.

After installing the package you should attach the Octane specialized middleware to the application routes:

Laravel 11

use \Inspector\Laravel\Middleware\InspectorOctaneMiddleware;

return Application::configure(basePath: dirname(__DIR__))
    ->withRouting(
        // routes
    )
    ->withMiddleware(function (Middleware $middleware) {
        // Append the middleware
        $middleware->appendToGroup('web', InspectorOctaneMiddleware::class)
            ->appendToGroup('api', InspectorOctaneMiddleware::class);
    })
    ->withExceptions(function (Exceptions $exceptions) {
        //
    })->create();

Laravel <= 10

/**
 * The application's route middleware groups.
 *
 * @var array
 */
protected $middlewareGroups = [
    'web' => [
        ...,
        //\Inspector\Laravel\Middleware\WebRequestMonitoring::class,
        \Inspector\Laravel\Middleware\InspectorOctaneMiddleware::class,
    ],
    
    'api' => [
        ...,
        //\Inspector\Laravel\Middleware\WebRequestMonitoring::class,
        \Inspector\Laravel\Middleware\InspectorOctaneMiddleware::class,
    ],
]

That’s it.

Your application will continue to be monitored as a “standard” Laravel installation without any side effect.

Other NewRelic bottlenecks

The team of Brazilian devs delved even deeper into the motivations that drove them to look for valid alternatives to NewRelic.

They wanted to monitor other internal applications as well. Applications that are less critical but for which the company would benefit from real-time monitoring data.

The problem was the complexity of making NewRelic at work on other applications and even more problematic was the big increase in costs.

Costs to monitor other hosts, costs to share the monitoring environment with other users, and the complexity to configure and use the platform.

For me it was a revealing discussion. I had never heard all these details about the various use cases in which Inspector provides a design and pricing policy much more convenient than platforms aimed at large corporations.

So, thank you guys, I’m happy to collaborate with such open minded developers like you. The Inspector community continues to grow.

Monitor your Laravel application for free

Inspector is a Code Execution Monitoring tool specifically designed for software developers. You don’t need to install anything on the infrastructure, just install the Laravel package and you are ready to go.

Inspector is super easy to use and require zero configurations.

If you are looking for HTTP monitoring, database query insights, and the ability to forward alerts and notifications into your preferred messaging environment try Inspector for free. Register your account.

Or learn more on the website: https://inspector.dev

Inspector Code Execution Monitoring

Related Posts

Struggling with RAG in PHP? Discover Neuron AI components

Implementing Retrieval-Augmented Generation (RAG) is often the first “wall” PHP developers hit when moving beyond simple chat scripts. While the concept of “giving an LLM access to your own data” is straightforward, the tasks required to make it work reliably in a PHP environment can be frustrating. You have to manage document parsing, vector embeddings,

Enabling Zero-UI Observability

It is getting harder to filter through the noise in our industry right now. New AI tools drop every day, and navigating the hype cycle can be exhausting. But the reality is that our day-to-day job as developers is changing. Most of us have already integrated AI agents (like Claude, Cursor, or Copilot) into our

Neuron AI Laravel SDK

For a long time, the conversation around “agentic AI” seemed to happen in a language that wasn’t ours. If you wanted to build autonomous agents, the industry nudge was often to step away from the PHP ecosystem and move toward Python. But for those of us who have built our careers, companies, and products on