All posts

How to Fix Permissionerror in PHP In Production

Learn how to diagnose and fix the permissionerror in PHP in production. Includes code examples and prevention tips.

Encountering a permissionerror while working with PHP? This guide covers the root cause, provides a working code example, and shows you how to prevent it from recurring.

What Triggers This

A permission error in production in PHP typically means the running process cannot read, write, or execute a resource it needs. Common causes include:

  • File or directory ownership doesn't match the application user
  • Incorrect chmod settings on critical directories like uploads, cache, or logs
  • Docker containers running as root during build but non-root at runtime
  • Production filesystem mounted with restricted permissions or read-only volumes
  • Kubernetes security contexts restricting filesystem access

The Fix

// Check directory is writable before operations
$storagePath = storage_path("logs");
if (!is_writable($storagePath)) {
    $currentUser = posix_getpwuid(posix_geteuid())['name'];
    throw new \RuntimeException(
        "Storage directory is not writable by user '$currentUser'. " .
        "Fix: chmod -R 775 storage && chown -R www-data:www-data storage"
    );
}

// Also check bootstrap/cache for Laravel
if (!is_writable(base_path("bootstrap/cache"))) {
    throw new \RuntimeException("bootstrap/cache must be writable");
}

Check both storage/ and bootstrap/cache/ permissions in Laravel. Use is_writable() with actionable error messages.

Deployment Checklist

  • Verify the application runs as the correct OS user (not root in production)
  • Set directory permissions to 755 for read/execute, 775 for directories that need write access
  • Use chown -R appuser:appuser /app/data during container builds to assign proper ownership
  • Add permission checks to your application startup sequence so failures are immediate and clear

[Bugsly](https://bugsly.dev) flags permission errors in real time across your PHP deployments, including the exact file path and user context so you can fix access issues before users notice.

Try Bugsly Free

AI-powered error tracking that explains your bugs. Set up in 2 minutes, free forever for small projects.

Get Started Free