<?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: barfrakud</title>
    <description>The latest articles on DEV Community by barfrakud (@barfrakud).</description>
    <link>https://dev.to/barfrakud</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%2F407820%2Fd68248a5-dda5-47ab-aec6-a788fadbfc6c.png</url>
      <title>DEV Community: barfrakud</title>
      <link>https://dev.to/barfrakud</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/barfrakud"/>
    <language>en</language>
    <item>
      <title>How to set up XDebug with VSCode in a Laravel Sail environment</title>
      <dc:creator>barfrakud</dc:creator>
      <pubDate>Sun, 15 Dec 2024 22:27:24 +0000</pubDate>
      <link>https://dev.to/barfrakud/how-to-set-up-xdebug-with-vscode-in-a-laravel-sail-environment-1oci</link>
      <guid>https://dev.to/barfrakud/how-to-set-up-xdebug-with-vscode-in-a-laravel-sail-environment-1oci</guid>
      <description>&lt;h1&gt;
  
  
  How to set up XDebug with VSCode in a Laravel Sail environment
&lt;/h1&gt;

&lt;p&gt;If you’re working on a Laravel project with Sail and want to debug your code using VSCode, setting up Xdebug is a great way to streamline your development workflow. In this guide, we’ll walk through all the steps you need to get Xdebug up and running.&lt;/p&gt;

&lt;h2&gt;
  
  
  1. Update Your &lt;code&gt;.env&lt;/code&gt; File
&lt;/h2&gt;

&lt;p&gt;First, open your project’s &lt;code&gt;.env&lt;/code&gt; file and add the following line:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;SAIL_XDEBUG_MODE=develop,debug,coverage
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;strong&gt;What this does:&lt;/strong&gt;&lt;br&gt;&lt;br&gt;
Enables Xdebug in &lt;code&gt;develop&lt;/code&gt;, &lt;code&gt;debug&lt;/code&gt;, and &lt;code&gt;coverage&lt;/code&gt; modes within the Sail environment. This gives you all the necessary tools for an effective debugging session.&lt;/p&gt;
&lt;h2&gt;
  
  
  2. Adjust &lt;code&gt;docker-compose.yml&lt;/code&gt;
&lt;/h2&gt;

&lt;p&gt;Next, you’ll need to update the &lt;code&gt;docker-compose.yml&lt;/code&gt; file to ensure your custom PHP configuration (including Xdebug) is applied inside the container. Add the following volume mapping under the main application service:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight yaml"&gt;&lt;code&gt;&lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s1"&gt;'&lt;/span&gt;&lt;span class="s"&gt;./docker/8.3/php.ini:/etc/php/8.3/cli/conf.d/99-sail.ini'&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;strong&gt;Context:&lt;/strong&gt;&lt;br&gt;&lt;br&gt;
Here’s how your &lt;code&gt;services&lt;/code&gt; section might look (don’t change existing lines, just add the above mapping):&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight yaml"&gt;&lt;code&gt;&lt;span class="na"&gt;services&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
    &lt;span class="na"&gt;laravel.test&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
        &lt;span class="na"&gt;build&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
            &lt;span class="na"&gt;context&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s1"&gt;'&lt;/span&gt;&lt;span class="s"&gt;./docker/8.3'&lt;/span&gt;
            &lt;span class="na"&gt;dockerfile&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;Dockerfile&lt;/span&gt;
            &lt;span class="na"&gt;args&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
                &lt;span class="na"&gt;WWWGROUP&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s1"&gt;'&lt;/span&gt;&lt;span class="s"&gt;${WWWGROUP}'&lt;/span&gt;
        &lt;span class="na"&gt;image&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s1"&gt;'&lt;/span&gt;&lt;span class="s"&gt;sail-8.3/app'&lt;/span&gt;
        &lt;span class="na"&gt;extra_hosts&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
            &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s1"&gt;'&lt;/span&gt;&lt;span class="s"&gt;host.docker.internal:host-gateway'&lt;/span&gt;
        &lt;span class="na"&gt;ports&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
            &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s1"&gt;'&lt;/span&gt;&lt;span class="s"&gt;${APP_PORT:-80}:80'&lt;/span&gt;
            &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s1"&gt;'&lt;/span&gt;&lt;span class="s"&gt;${VITE_PORT:-5173}:${VITE_PORT:-5173}'&lt;/span&gt;
        &lt;span class="na"&gt;environment&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
            &lt;span class="na"&gt;WWWUSER&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s1"&gt;'&lt;/span&gt;&lt;span class="s"&gt;${WWWUSER}'&lt;/span&gt;
            &lt;span class="na"&gt;LARAVEL_SAIL&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="m"&gt;1&lt;/span&gt;
            &lt;span class="na"&gt;XDEBUG_MODE&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s1"&gt;'&lt;/span&gt;&lt;span class="s"&gt;${SAIL_XDEBUG_MODE:-off}'&lt;/span&gt;
            &lt;span class="na"&gt;XDEBUG_CONFIG&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s1"&gt;'&lt;/span&gt;&lt;span class="s"&gt;${SAIL_XDEBUG_CONFIG:-client_host=host.docker.internal}'&lt;/span&gt;
            &lt;span class="na"&gt;IGNITION_LOCAL_SITES_PATH&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s1"&gt;'&lt;/span&gt;&lt;span class="s"&gt;${PWD}'&lt;/span&gt;
        &lt;span class="na"&gt;volumes&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
            &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s1"&gt;'&lt;/span&gt;&lt;span class="s"&gt;.:/var/www/html'&lt;/span&gt;
            &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s1"&gt;'&lt;/span&gt;&lt;span class="s"&gt;./docker/8.3/php.ini:/etc/php/8.3/cli/conf.d/99-sail.ini'&lt;/span&gt;
        &lt;span class="na"&gt;networks&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
            &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;sail&lt;/span&gt;
        &lt;span class="na"&gt;depends_on&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
            &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;mysql&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  3. Publish Sail’s Configuration
&lt;/h2&gt;

&lt;p&gt;Run the following Artisan command:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;sail artisan sail:publish
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;strong&gt;Why?&lt;/strong&gt;&lt;br&gt;&lt;br&gt;
This publishes Sail’s configuration files to your project, allowing you to customize them if you need to tweak the environment further.&lt;/p&gt;
&lt;h2&gt;
  
  
  4. Configure Xdebug in &lt;code&gt;docker/8.3/php.ini&lt;/code&gt;
&lt;/h2&gt;

&lt;p&gt;Open &lt;code&gt;docker/8.3/php.ini&lt;/code&gt; and add these lines:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight ini"&gt;&lt;code&gt;&lt;span class="nn"&gt;[XDebug]&lt;/span&gt;
&lt;span class="py"&gt;xdebug.mode&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="s"&gt;${XDEBUG_MODE}&lt;/span&gt;
&lt;span class="py"&gt;xdebug.start_with_request&lt;/span&gt; &lt;span class="p"&gt;=&lt;/span&gt; &lt;span class="s"&gt;yes&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;strong&gt;What this does:&lt;/strong&gt;  &lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;code&gt;xdebug.mode=${XDEBUG_MODE}&lt;/code&gt; ensures the mode is pulled from your &lt;code&gt;.env&lt;/code&gt; file.
&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;xdebug.start_with_request = yes&lt;/code&gt; means a debug session starts automatically with every HTTP request, so you won’t have to manually trigger it.&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  5. Update Your VSCode Debug Configuration
&lt;/h2&gt;

&lt;p&gt;In your &lt;code&gt;.vscode/launch.json&lt;/code&gt;, modify or add a debug configuration block like this:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight json"&gt;&lt;code&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="nl"&gt;"name"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"Listen for Xdebug"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="nl"&gt;"type"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"php"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="nl"&gt;"request"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"launch"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="nl"&gt;"port"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="mi"&gt;9003&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="nl"&gt;"pathMappings"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt;
        &lt;/span&gt;&lt;span class="nl"&gt;"/var/www/html"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"${workspaceFolder}"&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="p"&gt;},&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="nl"&gt;"hostname"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"localhost"&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;strong&gt;Explanation:&lt;/strong&gt;  &lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Port 9003&lt;/strong&gt; is the default for Xdebug 3.
&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;pathMappings&lt;/strong&gt; maps the container’s &lt;code&gt;/var/www/html&lt;/code&gt; directory to your local project directory (the &lt;code&gt;${workspaceFolder}&lt;/code&gt;), ensuring breakpoints align correctly with the code running in Docker.&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Summary of the Steps
&lt;/h2&gt;

&lt;ol&gt;
&lt;li&gt;Add &lt;code&gt;SAIL_XDEBUG_MODE=develop,debug,coverage&lt;/code&gt; to &lt;code&gt;.env&lt;/code&gt;.&lt;/li&gt;
&lt;li&gt;Update &lt;code&gt;docker-compose.yml&lt;/code&gt; to include the volume mapping for &lt;code&gt;php.ini&lt;/code&gt;.&lt;/li&gt;
&lt;li&gt;Run &lt;code&gt;sail artisan sail:publish&lt;/code&gt;.&lt;/li&gt;
&lt;li&gt;Add the Xdebug configuration to &lt;code&gt;docker/8.3/php.ini&lt;/code&gt;.&lt;/li&gt;
&lt;li&gt;Update your VSCode debug configuration to listen on port &lt;code&gt;9003&lt;/code&gt;.&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;Following these steps should allow Xdebug to connect to VSCode, making it easy to step through code, inspect variables, and troubleshoot issues in your Laravel app under Sail.&lt;/p&gt;

&lt;h2&gt;
  
  
  Additional Tips
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;After making changes, you might need to rebuild the containers:
&lt;/li&gt;
&lt;/ul&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;  sail build &lt;span class="nt"&gt;--no-cache&lt;/span&gt;
  sail up &lt;span class="nt"&gt;-d&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;ul&gt;
&lt;li&gt;Consider using a browser extension like Xdebug Helper for Chrome or Firefox.

&lt;ul&gt;
&lt;li&gt;For Firefox or Chrome, set the &lt;code&gt;XDEBUG_VSCODE&lt;/code&gt; as the IDE key in the extension settings.&lt;/li&gt;
&lt;/ul&gt;


&lt;/li&gt;

&lt;/ul&gt;

&lt;p&gt;These optional steps can help you toggle debugging sessions on and off more easily.&lt;/p&gt;




&lt;p&gt;With these configurations, you’re ready to debug your Laravel application running in a Sail environment directly from VSCode!&lt;/p&gt;

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